From c55e2b55685403b13bb393d16efe4011c6533173 Mon Sep 17 00:00:00 2001 From: Marius Andra Date: Mon, 26 Aug 2024 14:52:37 +0200 Subject: [PATCH 01/21] serialize hogvm output --- .../typescript/src/__tests__/execute.test.ts | 22 +++++++++++++++++++ hogvm/typescript/src/execute.ts | 10 ++++----- plugin-server/src/cdp/cdp-api.ts | 5 ++--- plugin-server/src/cdp/hog-executor.ts | 4 ++-- 4 files changed, 31 insertions(+), 10 deletions(-) diff --git a/hogvm/typescript/src/__tests__/execute.test.ts b/hogvm/typescript/src/__tests__/execute.test.ts index 435b7d873abfe..494f6da0753c7 100644 --- a/hogvm/typescript/src/__tests__/execute.test.ts +++ b/hogvm/typescript/src/__tests__/execute.test.ts @@ -1863,4 +1863,26 @@ describe('hogvm execute', () => { new UncaughtHogVMException('RetryError', 'Not a good day', { key: 'value' }) ) }) + + test('returns serialized state', () => { + const bytecode = ['_h', op.STRING, 'key', op.STRING, 'value', op.DICT, 1, op.GET_LOCAL, 0, op.CALL, 'fetch', 1] + expect(exec(bytecode, { asyncFunctions: { fetch: async () => null } })).toEqual({ + asyncFunctionArgs: [{ key: 'value' }], // not a Map + asyncFunctionName: 'fetch', + finished: false, + result: undefined, + state: { + asyncSteps: 1, + bytecode: bytecode, + callStack: [], + declaredFunctions: {}, + ip: 12, + maxMemUsed: 64, + ops: 5, + stack: [{ key: 'value' }], // not a Map + syncDuration: 0, + throwStack: [], + }, + }) + }) }) diff --git a/hogvm/typescript/src/execute.ts b/hogvm/typescript/src/execute.ts index 389e1ded547f2..dd7865b77f0af 100644 --- a/hogvm/typescript/src/execute.ts +++ b/hogvm/typescript/src/execute.ts @@ -84,10 +84,10 @@ export async function execAsync(bytecode: any[], options?: ExecOptions): Promise const result = await options?.asyncFunctions[response.asyncFunctionName]( ...response.asyncFunctionArgs.map(convertHogToJS) ) - vmState.stack.push(convertJSToHog(result)) + vmState.stack.push(result) } else if (response.asyncFunctionName in ASYNC_STL) { const result = await ASYNC_STL[response.asyncFunctionName]( - response.asyncFunctionArgs, + response.asyncFunctionArgs.map(convertHogToJS), response.asyncFunctionName, options?.timeout ?? DEFAULT_TIMEOUT_MS ) @@ -123,7 +123,7 @@ export function exec(code: any[] | VMState, options?: ExecOptions): ExecResult { const asyncSteps = vmState ? vmState.asyncSteps : 0 const syncDuration = vmState ? vmState.syncDuration : 0 - const stack: any[] = vmState ? vmState.stack : [] + const stack: any[] = vmState ? vmState.stack.map(convertJSToHog) : [] const memStack: number[] = stack.map((s) => calculateCost(s)) const callStack: [number, number, number][] = vmState ? vmState.callStack : [] const throwStack: [number, number, number][] = vmState ? vmState.throwStack : [] @@ -436,10 +436,10 @@ export function exec(code: any[] | VMState, options?: ExecOptions): ExecResult { result: undefined, finished: false, asyncFunctionName: name, - asyncFunctionArgs: args, + asyncFunctionArgs: args.map(convertHogToJS), state: { bytecode, - stack, + stack: stack.map(convertHogToJS), callStack, throwStack, declaredFunctions, diff --git a/plugin-server/src/cdp/cdp-api.ts b/plugin-server/src/cdp/cdp-api.ts index 553e380e16cdf..943091af13814 100644 --- a/plugin-server/src/cdp/cdp-api.ts +++ b/plugin-server/src/cdp/cdp-api.ts @@ -1,4 +1,3 @@ -import { convertJSToHog } from '@posthog/hogvm' import express from 'express' import { DateTime } from 'luxon' @@ -147,7 +146,7 @@ export class CdpApi { }) // Add the state, simulating what executeAsyncResponse would do - invocation.vmState!.stack.push(convertJSToHog({ status: 200, body: {} })) + invocation.vmState!.stack.push({ status: 200, body: {} }) } else { const asyncInvocationRequest: HogFunctionInvocationAsyncRequest = { state: '', // WE don't care about the state for this level of testing @@ -166,7 +165,7 @@ export class CdpApi { message: 'Failed to execute async function', }) } - invocation.vmState!.stack.push(convertJSToHog(asyncRes?.asyncFunctionResponse.response ?? null)) + invocation.vmState!.stack.push(asyncRes?.asyncFunctionResponse.response ?? null) } logs.push(...response.logs) diff --git a/plugin-server/src/cdp/hog-executor.ts b/plugin-server/src/cdp/hog-executor.ts index 6b590994000c4..3307a9136c7c1 100644 --- a/plugin-server/src/cdp/hog-executor.ts +++ b/plugin-server/src/cdp/hog-executor.ts @@ -1,4 +1,4 @@ -import { calculateCost, convertHogToJS, convertJSToHog, exec, ExecResult } from '@posthog/hogvm' +import { calculateCost, convertHogToJS, exec, ExecResult } from '@posthog/hogvm' import { DateTime } from 'luxon' import { Histogram } from 'prom-client' @@ -217,7 +217,7 @@ export class HogExecutor { } // Add the response to the stack to continue execution - invocation.vmState.stack.push(convertJSToHog(response)) + invocation.vmState.stack.push(response) invocation.timings.push(...timings) const res = this.execute(hogFunction, invocation) From f3d7befa48f4a177c47dde82c52909e1356eecb9 Mon Sep 17 00:00:00 2001 From: Marius Andra Date: Mon, 26 Aug 2024 15:06:52 +0200 Subject: [PATCH 02/21] new hogvm version --- hogvm/typescript/package.json | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/hogvm/typescript/package.json b/hogvm/typescript/package.json index aff5560bc6973..b6e47b51cbcbc 100644 --- a/hogvm/typescript/package.json +++ b/hogvm/typescript/package.json @@ -1,6 +1,6 @@ { "name": "@posthog/hogvm", - "version": "1.0.32", + "version": "1.0.35", "description": "PostHog Hog Virtual Machine", "types": "dist/index.d.ts", "main": "dist/index.js", From cbeed5936b719fad304ded6651404c58efa3d6b3 Mon Sep 17 00:00:00 2001 From: Marius Andra Date: Mon, 26 Aug 2024 15:09:43 +0200 Subject: [PATCH 03/21] use new version --- plugin-server/package.json | 2 +- plugin-server/pnpm-lock.yaml | 9 +++++---- 2 files changed, 6 insertions(+), 5 deletions(-) diff --git a/plugin-server/package.json b/plugin-server/package.json index e5442bf51b68d..f7672084d42eb 100644 --- a/plugin-server/package.json +++ b/plugin-server/package.json @@ -52,7 +52,7 @@ "@google-cloud/storage": "^5.8.5", "@maxmind/geoip2-node": "^3.4.0", "@posthog/clickhouse": "^1.7.0", - "@posthog/hogvm": "^1.0.32", + "@posthog/hogvm": "^1.0.35", "@posthog/plugin-scaffold": "1.4.4", "@sentry/node": "^7.49.0", "@sentry/profiling-node": "^0.3.0", diff --git a/plugin-server/pnpm-lock.yaml b/plugin-server/pnpm-lock.yaml index f242e25145a74..0bb579b69c438 100644 --- a/plugin-server/pnpm-lock.yaml +++ b/plugin-server/pnpm-lock.yaml @@ -47,8 +47,8 @@ dependencies: specifier: file:../rust/cyclotron-node version: file:../rust/cyclotron-node '@posthog/hogvm': - specifier: ^1.0.32 - version: 1.0.32(luxon@3.4.4)(re2@1.20.3) + specifier: ^1.0.35 + version: 1.0.35(luxon@3.4.4)(re2@1.20.3) '@posthog/plugin-scaffold': specifier: 1.4.4 version: 1.4.4 @@ -3116,8 +3116,8 @@ packages: engines: {node: '>=12'} dev: false - /@posthog/hogvm@1.0.32(luxon@3.4.4)(re2@1.20.3): - resolution: {integrity: sha512-OjgSzs4fZ1Q0KEiON34/dH9TybfVfallANcgoRiNhUd9KstSm55Ds5cpK6HjGMfRRPpPULuDQ77RH3DBjJ2CCA==} + /@posthog/hogvm@1.0.35(luxon@3.4.4)(re2@1.20.3): + resolution: {integrity: sha512-Uq3Cpg0CGxwScdgGddfzDCs42opILFhgnM6wqly55PAZGBhXWxVHgVpejLiWLtG1z8aIMLC8HCbQx1rZheCGMQ==} peerDependencies: luxon: ^3.4.4 re2: ^1.21.3 @@ -10738,4 +10738,5 @@ packages: file:../rust/cyclotron-node: resolution: {directory: ../rust/cyclotron-node, type: directory} name: '@posthog/cyclotron' + version: 0.1.0 dev: false From 9aa0a856667086288911042542be9643942c5c96 Mon Sep 17 00:00:00 2001 From: Marius Andra Date: Mon, 26 Aug 2024 16:13:38 +0200 Subject: [PATCH 04/21] feat(hog): parser updates for lambdas --- .github/workflows/ci-hog.yml | 4 +- hogql_parser/HogQLLexer.cpp | 6 +- hogql_parser/HogQLLexer.h | 2 +- hogql_parser/HogQLParser.cpp | 3325 +++++++++---------- hogql_parser/HogQLParser.h | 95 +- hogql_parser/HogQLParser.interp | 4 +- hogql_parser/HogQLParserBaseVisitor.cpp | 2 +- hogql_parser/HogQLParserBaseVisitor.h | 18 +- hogql_parser/HogQLParserVisitor.cpp | 2 +- hogql_parser/HogQLParserVisitor.h | 10 +- hogql_parser/parser.cpp | 46 +- hogql_parser/setup.py | 2 +- posthog/hogql/ast.py | 6 + posthog/hogql/grammar/HogQLLexer.py | 4 +- posthog/hogql/grammar/HogQLParser.g4 | 16 +- posthog/hogql/grammar/HogQLParser.interp | 4 +- posthog/hogql/grammar/HogQLParser.py | 3269 +++++++++--------- posthog/hogql/grammar/HogQLParserVisitor.py | 22 +- posthog/hogql/grammar/README.md | 8 +- posthog/hogql/parser.py | 32 +- posthog/hogql/resolver.py | 6 + posthog/hogql/test/test_metadata.py | 12 +- posthog/hogql/test/test_printer.py | 5 +- posthog/hogql/visitor.py | 14 + 24 files changed, 3395 insertions(+), 3519 deletions(-) diff --git a/.github/workflows/ci-hog.yml b/.github/workflows/ci-hog.yml index 6f4c326506da6..5733393905e49 100644 --- a/.github/workflows/ci-hog.yml +++ b/.github/workflows/ci-hog.yml @@ -118,9 +118,9 @@ jobs: antlr | grep "Version" npm run grammar:build && git diff --exit-code env: - # Installing a version of ANTLR compatible with what's in Homebrew as of October 2023 (version 4.13), + # Installing a version of ANTLR compatible with what's in Homebrew as of August 2024 (version 4.13.2), # as apt-get is quite out of date. The same version must be set in hogql_parser/pyproject.toml - ANTLR_VERSION: '4.13.1' + ANTLR_VERSION: '4.13.2' - name: Run HogVM Python tests if: needs.changes.outputs.hog == 'true' diff --git a/hogql_parser/HogQLLexer.cpp b/hogql_parser/HogQLLexer.cpp index f5583b7fa4ac8..8c8c7c5a2b643 100644 --- a/hogql_parser/HogQLLexer.cpp +++ b/hogql_parser/HogQLLexer.cpp @@ -1,5 +1,5 @@ -// Generated from HogQLLexer.g4 by ANTLR 4.13.1 +// Generated from HogQLLexer.g4 by ANTLR 4.13.2 #include "HogQLLexer.h" @@ -45,7 +45,7 @@ ::antlr4::internal::OnceFlag hogqllexerLexerOnceFlag; #if ANTLR4_USE_THREAD_LOCAL_CACHE static thread_local #endif -HogQLLexerStaticData *hogqllexerLexerStaticData = nullptr; +std::unique_ptr hogqllexerLexerStaticData = nullptr; void hogqllexerLexerInitialize() { #if ANTLR4_USE_THREAD_LOCAL_CACHE @@ -673,7 +673,7 @@ void hogqllexerLexerInitialize() { for (size_t i = 0; i < count; i++) { staticData->decisionToDFA.emplace_back(staticData->atn->getDecisionState(i), i); } - hogqllexerLexerStaticData = staticData.release(); + hogqllexerLexerStaticData = std::move(staticData); } } diff --git a/hogql_parser/HogQLLexer.h b/hogql_parser/HogQLLexer.h index b54914ebc913e..d537cee2ba0cb 100644 --- a/hogql_parser/HogQLLexer.h +++ b/hogql_parser/HogQLLexer.h @@ -1,5 +1,5 @@ -// Generated from HogQLLexer.g4 by ANTLR 4.13.1 +// Generated from HogQLLexer.g4 by ANTLR 4.13.2 #pragma once diff --git a/hogql_parser/HogQLParser.cpp b/hogql_parser/HogQLParser.cpp index e2021ef8c06ae..55a2fca242632 100644 --- a/hogql_parser/HogQLParser.cpp +++ b/hogql_parser/HogQLParser.cpp @@ -1,5 +1,5 @@ -// Generated from HogQLParser.g4 by ANTLR 4.13.1 +// Generated from HogQLParser.g4 by ANTLR 4.13.2 #include "HogQLParserVisitor.h" @@ -40,7 +40,7 @@ ::antlr4::internal::OnceFlag hogqlparserParserOnceFlag; #if ANTLR4_USE_THREAD_LOCAL_CACHE static thread_local #endif -HogQLParserStaticData *hogqlparserParserStaticData = nullptr; +std::unique_ptr hogqlparserParserStaticData = nullptr; void hogqlparserParserInitialize() { #if ANTLR4_USE_THREAD_LOCAL_CACHE @@ -64,13 +64,12 @@ void hogqlparserParserInitialize() { "orderExpr", "ratioExpr", "settingExprList", "settingExpr", "windowExpr", "winPartitionByClause", "winOrderByClause", "winFrameClause", "winFrameExtend", "winFrameBound", "expr", "columnTypeExpr", "columnExprList", "columnExpr", - "columnArgList", "columnArgExpr", "columnLambdaExpr", "hogqlxTagElement", - "hogqlxTagAttribute", "withExprList", "withExpr", "columnIdentifier", - "nestedIdentifier", "tableExpr", "tableFunctionExpr", "tableIdentifier", - "tableArgList", "databaseIdentifier", "floatingLiteral", "numberLiteral", - "literal", "interval", "keyword", "keywordForAlias", "alias", "identifier", - "enumValue", "placeholder", "string", "templateString", "stringContents", - "fullTemplateString", "stringContentsFull" + "columnLambdaExpr", "hogqlxTagElement", "hogqlxTagAttribute", "withExprList", + "withExpr", "columnIdentifier", "nestedIdentifier", "tableExpr", "tableFunctionExpr", + "tableIdentifier", "tableArgList", "databaseIdentifier", "floatingLiteral", + "numberLiteral", "literal", "interval", "keyword", "keywordForAlias", + "alias", "identifier", "enumValue", "placeholder", "string", "templateString", + "stringContents", "fullTemplateString", "stringContentsFull" }, std::vector{ "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", @@ -114,7 +113,7 @@ void hogqlparserParserInitialize() { } ); static const int32_t serializedATNSegment[] = { - 4,1,159,1311,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, + 4,1,159,1303,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, @@ -126,484 +125,481 @@ void hogqlparserParserInitialize() { 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,1,0,5,0,178,8,0,10,0,12,0,181,9,0, - 1,0,1,0,1,1,1,1,3,1,187,8,1,1,2,1,2,1,3,1,3,1,3,1,3,1,3,3,3,196,8,3,1, - 4,1,4,1,4,5,4,201,8,4,10,4,12,4,204,9,4,1,4,3,4,207,8,4,1,5,1,5,1,5,1, - 5,1,5,1,5,1,5,1,5,1,5,1,5,1,5,1,5,3,5,221,8,5,1,6,1,6,3,6,225,8,6,1,6, - 3,6,228,8,6,1,7,1,7,3,7,232,8,7,1,7,3,7,235,8,7,1,8,1,8,1,8,1,8,1,8,3, - 8,242,8,8,1,8,1,8,3,8,246,8,8,1,8,1,8,1,9,1,9,1,9,5,9,253,8,9,10,9,12, - 9,256,9,9,1,9,1,9,3,9,260,8,9,1,10,1,10,1,10,1,10,1,10,1,10,1,10,3,10, - 269,8,10,1,11,1,11,1,11,1,11,1,11,1,11,3,11,277,8,11,1,12,1,12,1,12,1, - 12,1,12,3,12,284,8,12,1,12,1,12,3,12,288,8,12,1,12,1,12,1,12,1,12,3,12, - 294,8,12,1,12,1,12,1,12,3,12,299,8,12,1,13,1,13,1,13,1,13,1,13,1,13,3, - 13,307,8,13,1,13,1,13,1,13,1,13,1,13,3,13,314,8,13,1,14,1,14,1,14,1,14, - 3,14,320,8,14,1,14,1,14,1,14,1,15,1,15,1,15,1,15,1,15,1,16,1,16,3,16, - 332,8,16,1,17,1,17,1,18,1,18,5,18,338,8,18,10,18,12,18,341,9,18,1,18, - 1,18,1,19,1,19,1,19,1,19,1,20,1,20,1,20,5,20,352,8,20,10,20,12,20,355, - 9,20,1,20,3,20,358,8,20,1,21,1,21,1,21,3,21,363,8,21,1,21,1,21,1,22,1, - 22,1,22,1,22,5,22,371,8,22,10,22,12,22,374,9,22,1,23,1,23,1,23,1,23,1, - 23,1,23,3,23,382,8,23,1,24,3,24,385,8,24,1,24,1,24,3,24,389,8,24,1,24, - 3,24,392,8,24,1,24,1,24,3,24,396,8,24,1,24,3,24,399,8,24,1,24,3,24,402, - 8,24,1,24,3,24,405,8,24,1,24,3,24,408,8,24,1,24,1,24,3,24,412,8,24,1, - 24,1,24,3,24,416,8,24,1,24,3,24,419,8,24,1,24,3,24,422,8,24,1,24,3,24, - 425,8,24,1,24,1,24,3,24,429,8,24,1,24,3,24,432,8,24,1,25,1,25,1,25,1, - 26,1,26,1,26,1,26,3,26,441,8,26,1,27,1,27,1,27,1,28,3,28,447,8,28,1,28, - 1,28,1,28,1,28,1,29,1,29,1,29,1,29,1,29,1,29,1,29,1,29,1,29,1,29,1,29, - 1,29,1,29,5,29,466,8,29,10,29,12,29,469,9,29,1,30,1,30,1,30,1,31,1,31, - 1,31,1,32,1,32,1,32,1,32,1,32,1,32,1,32,1,32,3,32,485,8,32,1,33,1,33, - 1,33,1,34,1,34,1,34,1,34,1,35,1,35,1,35,1,35,1,36,1,36,1,36,1,36,3,36, - 502,8,36,1,36,1,36,1,36,1,36,3,36,508,8,36,1,36,1,36,1,36,1,36,3,36,514, - 8,36,1,36,1,36,1,36,1,36,1,36,1,36,1,36,1,36,1,36,3,36,525,8,36,3,36, - 527,8,36,1,37,1,37,1,37,1,38,1,38,1,38,1,39,1,39,1,39,3,39,538,8,39,1, - 39,3,39,541,8,39,1,39,1,39,1,39,1,39,3,39,547,8,39,1,39,1,39,1,39,1,39, - 1,39,1,39,3,39,555,8,39,1,39,1,39,1,39,1,39,5,39,561,8,39,10,39,12,39, - 564,9,39,1,40,3,40,567,8,40,1,40,1,40,1,40,3,40,572,8,40,1,40,3,40,575, - 8,40,1,40,3,40,578,8,40,1,40,1,40,3,40,582,8,40,1,40,1,40,3,40,586,8, - 40,1,40,3,40,589,8,40,3,40,591,8,40,1,40,3,40,594,8,40,1,40,1,40,3,40, - 598,8,40,1,40,1,40,3,40,602,8,40,1,40,3,40,605,8,40,3,40,607,8,40,3,40, - 609,8,40,1,41,1,41,1,41,3,41,614,8,41,1,42,1,42,1,42,1,42,1,42,1,42,1, - 42,1,42,1,42,3,42,625,8,42,1,43,1,43,1,43,1,43,3,43,631,8,43,1,44,1,44, - 1,44,5,44,636,8,44,10,44,12,44,639,9,44,1,45,1,45,3,45,643,8,45,1,45, - 1,45,3,45,647,8,45,1,45,1,45,3,45,651,8,45,1,46,1,46,1,46,1,46,3,46,657, - 8,46,3,46,659,8,46,1,47,1,47,1,47,5,47,664,8,47,10,47,12,47,667,9,47, - 1,48,1,48,1,48,1,48,1,49,3,49,674,8,49,1,49,3,49,677,8,49,1,49,3,49,680, - 8,49,1,50,1,50,1,50,1,50,1,51,1,51,1,51,1,51,1,52,1,52,1,52,1,53,1,53, - 1,53,1,53,1,53,1,53,3,53,699,8,53,1,54,1,54,1,54,1,54,1,54,1,54,1,54, - 1,54,1,54,1,54,1,54,1,54,3,54,713,8,54,1,55,1,55,1,55,1,56,1,56,1,56, - 1,56,1,56,1,56,1,56,1,56,1,56,5,56,727,8,56,10,56,12,56,730,9,56,1,56, - 3,56,733,8,56,1,56,1,56,1,56,1,56,1,56,1,56,1,56,5,56,742,8,56,10,56, - 12,56,745,9,56,1,56,3,56,748,8,56,1,56,1,56,1,56,1,56,1,56,1,56,1,56, - 5,56,757,8,56,10,56,12,56,760,9,56,1,56,3,56,763,8,56,1,56,1,56,1,56, - 1,56,1,56,3,56,770,8,56,1,56,1,56,3,56,774,8,56,1,57,1,57,1,57,5,57,779, - 8,57,10,57,12,57,782,9,57,1,57,3,57,785,8,57,1,58,1,58,1,58,3,58,790, - 8,58,1,58,1,58,1,58,1,58,1,58,4,58,797,8,58,11,58,12,58,798,1,58,1,58, - 3,58,803,8,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58, - 1,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,3,58,827,8,58, + 7,84,2,85,7,85,1,0,5,0,174,8,0,10,0,12,0,177,9,0,1,0,1,0,1,1,1,1,3,1, + 183,8,1,1,2,1,2,1,3,1,3,1,3,1,3,1,3,3,3,192,8,3,1,4,1,4,1,4,5,4,197,8, + 4,10,4,12,4,200,9,4,1,4,3,4,203,8,4,1,5,1,5,1,5,1,5,1,5,1,5,1,5,1,5,1, + 5,1,5,1,5,1,5,3,5,217,8,5,1,6,1,6,3,6,221,8,6,1,6,3,6,224,8,6,1,7,1,7, + 3,7,228,8,7,1,7,3,7,231,8,7,1,8,1,8,1,8,1,8,1,8,3,8,238,8,8,1,8,1,8,3, + 8,242,8,8,1,8,1,8,1,9,1,9,1,9,5,9,249,8,9,10,9,12,9,252,9,9,1,9,1,9,3, + 9,256,8,9,1,10,1,10,1,10,1,10,1,10,1,10,1,10,3,10,265,8,10,1,11,1,11, + 1,11,1,11,1,11,1,11,3,11,273,8,11,1,12,1,12,1,12,1,12,1,12,3,12,280,8, + 12,1,12,1,12,3,12,284,8,12,1,12,1,12,1,12,1,12,3,12,290,8,12,1,12,1,12, + 1,12,3,12,295,8,12,1,13,1,13,1,13,1,13,1,13,1,13,3,13,303,8,13,1,13,1, + 13,1,13,1,13,1,13,3,13,310,8,13,1,14,1,14,1,14,1,14,3,14,316,8,14,1,14, + 1,14,1,14,1,15,1,15,1,15,1,15,1,15,1,16,1,16,3,16,328,8,16,1,17,1,17, + 1,18,1,18,5,18,334,8,18,10,18,12,18,337,9,18,1,18,1,18,1,19,1,19,1,19, + 1,19,1,20,1,20,1,20,5,20,348,8,20,10,20,12,20,351,9,20,1,20,3,20,354, + 8,20,1,21,1,21,1,21,3,21,359,8,21,1,21,1,21,1,22,1,22,1,22,1,22,5,22, + 367,8,22,10,22,12,22,370,9,22,1,23,1,23,1,23,1,23,1,23,1,23,3,23,378, + 8,23,1,24,3,24,381,8,24,1,24,1,24,3,24,385,8,24,1,24,3,24,388,8,24,1, + 24,1,24,3,24,392,8,24,1,24,3,24,395,8,24,1,24,3,24,398,8,24,1,24,3,24, + 401,8,24,1,24,3,24,404,8,24,1,24,1,24,3,24,408,8,24,1,24,1,24,3,24,412, + 8,24,1,24,3,24,415,8,24,1,24,3,24,418,8,24,1,24,3,24,421,8,24,1,24,1, + 24,3,24,425,8,24,1,24,3,24,428,8,24,1,25,1,25,1,25,1,26,1,26,1,26,1,26, + 3,26,437,8,26,1,27,1,27,1,27,1,28,3,28,443,8,28,1,28,1,28,1,28,1,28,1, + 29,1,29,1,29,1,29,1,29,1,29,1,29,1,29,1,29,1,29,1,29,1,29,1,29,5,29,462, + 8,29,10,29,12,29,465,9,29,1,30,1,30,1,30,1,31,1,31,1,31,1,32,1,32,1,32, + 1,32,1,32,1,32,1,32,1,32,3,32,481,8,32,1,33,1,33,1,33,1,34,1,34,1,34, + 1,34,1,35,1,35,1,35,1,35,1,36,1,36,1,36,1,36,3,36,498,8,36,1,36,1,36, + 1,36,1,36,3,36,504,8,36,1,36,1,36,1,36,1,36,3,36,510,8,36,1,36,1,36,1, + 36,1,36,1,36,1,36,1,36,1,36,1,36,3,36,521,8,36,3,36,523,8,36,1,37,1,37, + 1,37,1,38,1,38,1,38,1,39,1,39,1,39,3,39,534,8,39,1,39,3,39,537,8,39,1, + 39,1,39,1,39,1,39,3,39,543,8,39,1,39,1,39,1,39,1,39,1,39,1,39,3,39,551, + 8,39,1,39,1,39,1,39,1,39,5,39,557,8,39,10,39,12,39,560,9,39,1,40,3,40, + 563,8,40,1,40,1,40,1,40,3,40,568,8,40,1,40,3,40,571,8,40,1,40,3,40,574, + 8,40,1,40,1,40,3,40,578,8,40,1,40,1,40,3,40,582,8,40,1,40,3,40,585,8, + 40,3,40,587,8,40,1,40,3,40,590,8,40,1,40,1,40,3,40,594,8,40,1,40,1,40, + 3,40,598,8,40,1,40,3,40,601,8,40,3,40,603,8,40,3,40,605,8,40,1,41,1,41, + 1,41,3,41,610,8,41,1,42,1,42,1,42,1,42,1,42,1,42,1,42,1,42,1,42,3,42, + 621,8,42,1,43,1,43,1,43,1,43,3,43,627,8,43,1,44,1,44,1,44,5,44,632,8, + 44,10,44,12,44,635,9,44,1,45,1,45,3,45,639,8,45,1,45,1,45,3,45,643,8, + 45,1,45,1,45,3,45,647,8,45,1,46,1,46,1,46,1,46,3,46,653,8,46,3,46,655, + 8,46,1,47,1,47,1,47,5,47,660,8,47,10,47,12,47,663,9,47,1,48,1,48,1,48, + 1,48,1,49,3,49,670,8,49,1,49,3,49,673,8,49,1,49,3,49,676,8,49,1,50,1, + 50,1,50,1,50,1,51,1,51,1,51,1,51,1,52,1,52,1,52,1,53,1,53,1,53,1,53,1, + 53,1,53,3,53,695,8,53,1,54,1,54,1,54,1,54,1,54,1,54,1,54,1,54,1,54,1, + 54,1,54,1,54,3,54,709,8,54,1,55,1,55,1,55,1,56,1,56,1,56,1,56,1,56,1, + 56,1,56,1,56,1,56,5,56,723,8,56,10,56,12,56,726,9,56,1,56,3,56,729,8, + 56,1,56,1,56,1,56,1,56,1,56,1,56,1,56,5,56,738,8,56,10,56,12,56,741,9, + 56,1,56,3,56,744,8,56,1,56,1,56,1,56,1,56,1,56,1,56,1,56,5,56,753,8,56, + 10,56,12,56,756,9,56,1,56,3,56,759,8,56,1,56,1,56,1,56,1,56,1,56,3,56, + 766,8,56,1,56,1,56,3,56,770,8,56,1,57,1,57,1,57,5,57,775,8,57,10,57,12, + 57,778,9,57,1,57,3,57,781,8,57,1,58,1,58,1,58,3,58,786,8,58,1,58,1,58, + 1,58,1,58,1,58,4,58,793,8,58,11,58,12,58,794,1,58,1,58,3,58,799,8,58, 1,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58, - 1,58,3,58,844,8,58,1,58,1,58,1,58,1,58,3,58,850,8,58,1,58,3,58,853,8, - 58,1,58,3,58,856,8,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,3,58,866, - 8,58,1,58,1,58,1,58,1,58,3,58,872,8,58,1,58,3,58,875,8,58,1,58,3,58,878, - 8,58,1,58,1,58,1,58,1,58,1,58,1,58,3,58,886,8,58,1,58,3,58,889,8,58,1, - 58,1,58,3,58,893,8,58,1,58,3,58,896,8,58,1,58,1,58,1,58,1,58,1,58,1,58, - 1,58,1,58,1,58,1,58,1,58,1,58,3,58,910,8,58,1,58,1,58,1,58,1,58,1,58, - 1,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,3,58,927,8,58,1,58, - 1,58,1,58,3,58,932,8,58,1,58,1,58,3,58,936,8,58,1,58,1,58,1,58,1,58,3, - 58,942,8,58,1,58,1,58,1,58,1,58,1,58,3,58,949,8,58,1,58,1,58,1,58,1,58, - 1,58,1,58,1,58,1,58,1,58,1,58,3,58,961,8,58,1,58,1,58,3,58,965,8,58,1, - 58,3,58,968,8,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,3,58,977,8,58,1,58, - 1,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,3,58,991,8,58, + 1,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,3,58,823,8,58,1,58,1,58,1,58, + 1,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,3,58,840, + 8,58,1,58,1,58,1,58,1,58,3,58,846,8,58,1,58,3,58,849,8,58,1,58,3,58,852, + 8,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,3,58,862,8,58,1,58,1,58, + 1,58,1,58,3,58,868,8,58,1,58,3,58,871,8,58,1,58,3,58,874,8,58,1,58,1, + 58,1,58,1,58,1,58,1,58,3,58,882,8,58,1,58,3,58,885,8,58,1,58,1,58,3,58, + 889,8,58,1,58,3,58,892,8,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,1, + 58,1,58,1,58,1,58,3,58,906,8,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,1, + 58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,3,58,923,8,58,1,58,1,58,1,58,3, + 58,928,8,58,1,58,1,58,1,58,3,58,933,8,58,1,58,1,58,1,58,1,58,3,58,939, + 8,58,1,58,1,58,1,58,1,58,1,58,3,58,946,8,58,1,58,1,58,1,58,1,58,1,58, + 1,58,1,58,1,58,1,58,1,58,3,58,958,8,58,1,58,1,58,3,58,962,8,58,1,58,3, + 58,965,8,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,3,58,974,8,58,1,58,1,58, + 1,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,3,58,988,8,58,1,58, + 1,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,3,58, + 1004,8,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58, 1,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58, - 1,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58, - 1,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,3,58,1030,8,58,1,58,1,58, - 1,58,1,58,1,58,1,58,3,58,1038,8,58,5,58,1040,8,58,10,58,12,58,1043,9, - 58,1,59,1,59,1,59,5,59,1048,8,59,10,59,12,59,1051,9,59,1,59,3,59,1054, - 8,59,1,60,1,60,3,60,1058,8,60,1,61,1,61,1,61,1,61,5,61,1064,8,61,10,61, - 12,61,1067,9,61,1,61,3,61,1070,8,61,1,61,1,61,1,61,1,61,1,61,5,61,1077, - 8,61,10,61,12,61,1080,9,61,1,61,3,61,1083,8,61,3,61,1085,8,61,1,61,1, - 61,1,61,1,62,1,62,1,62,5,62,1093,8,62,10,62,12,62,1096,9,62,1,62,1,62, - 1,62,1,62,1,62,1,62,5,62,1104,8,62,10,62,12,62,1107,9,62,1,62,1,62,1, - 62,1,62,1,62,1,62,3,62,1115,8,62,1,62,1,62,1,62,1,62,1,62,3,62,1122,8, - 62,1,63,1,63,1,63,1,63,1,63,1,63,1,63,1,63,1,63,1,63,1,63,3,63,1135,8, - 63,1,64,1,64,1,64,5,64,1140,8,64,10,64,12,64,1143,9,64,1,64,3,64,1146, - 8,64,1,65,1,65,1,65,1,65,1,65,1,65,1,65,1,65,1,65,1,65,3,65,1158,8,65, - 1,66,1,66,1,66,1,66,3,66,1164,8,66,1,66,3,66,1167,8,66,1,67,1,67,1,67, - 5,67,1172,8,67,10,67,12,67,1175,9,67,1,68,1,68,1,68,1,68,1,68,1,68,1, - 68,1,68,1,68,3,68,1186,8,68,1,68,1,68,1,68,1,68,3,68,1192,8,68,5,68,1194, - 8,68,10,68,12,68,1197,9,68,1,69,1,69,1,69,3,69,1202,8,69,1,69,1,69,1, - 70,1,70,1,70,3,70,1209,8,70,1,70,1,70,1,71,1,71,1,71,5,71,1216,8,71,10, - 71,12,71,1219,9,71,1,71,3,71,1222,8,71,1,72,1,72,1,73,1,73,1,73,1,73, - 1,73,1,73,3,73,1232,8,73,3,73,1234,8,73,1,74,3,74,1237,8,74,1,74,1,74, - 1,74,1,74,1,74,1,74,3,74,1245,8,74,1,75,1,75,1,75,3,75,1250,8,75,1,76, - 1,76,1,77,1,77,1,78,1,78,1,79,1,79,3,79,1260,8,79,1,80,1,80,1,80,3,80, - 1265,8,80,1,81,1,81,1,81,1,81,1,82,1,82,1,82,1,82,1,83,1,83,3,83,1277, - 8,83,1,84,1,84,5,84,1281,8,84,10,84,12,84,1284,9,84,1,84,1,84,1,85,1, - 85,1,85,1,85,1,85,3,85,1293,8,85,1,86,1,86,5,86,1297,8,86,10,86,12,86, - 1300,9,86,1,86,1,86,1,87,1,87,1,87,1,87,1,87,3,87,1309,8,87,1,87,0,3, - 78,116,136,88,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,0,16,2,0,18,18,74,74,2,0,44,44,51,51, - 3,0,1,1,4,4,8,8,4,0,1,1,3,4,8,8,80,80,2,0,51,51,73,73,2,0,1,1,4,4,2,0, - 7,7,22,23,2,0,30,30,49,49,2,0,71,71,76,76,3,0,10,10,50,50,90,90,2,0,41, - 41,53,53,1,0,107,108,2,0,118,118,139,139,7,0,21,21,38,38,55,56,70,70, - 78,78,97,97,103,103,16,0,1,13,15,20,22,28,30,30,32,37,39,42,44,51,53, - 54,58,58,60,69,71,77,79,83,85,92,94,96,98,99,101,102,4,0,20,20,30,30, - 39,39,48,48,1479,0,179,1,0,0,0,2,186,1,0,0,0,4,188,1,0,0,0,6,190,1,0, - 0,0,8,197,1,0,0,0,10,220,1,0,0,0,12,222,1,0,0,0,14,229,1,0,0,0,16,236, - 1,0,0,0,18,249,1,0,0,0,20,261,1,0,0,0,22,270,1,0,0,0,24,278,1,0,0,0,26, - 300,1,0,0,0,28,315,1,0,0,0,30,324,1,0,0,0,32,329,1,0,0,0,34,333,1,0,0, - 0,36,335,1,0,0,0,38,344,1,0,0,0,40,348,1,0,0,0,42,362,1,0,0,0,44,366, - 1,0,0,0,46,381,1,0,0,0,48,384,1,0,0,0,50,433,1,0,0,0,52,436,1,0,0,0,54, - 442,1,0,0,0,56,446,1,0,0,0,58,452,1,0,0,0,60,470,1,0,0,0,62,473,1,0,0, - 0,64,476,1,0,0,0,66,486,1,0,0,0,68,489,1,0,0,0,70,493,1,0,0,0,72,526, - 1,0,0,0,74,528,1,0,0,0,76,531,1,0,0,0,78,546,1,0,0,0,80,608,1,0,0,0,82, - 613,1,0,0,0,84,624,1,0,0,0,86,626,1,0,0,0,88,632,1,0,0,0,90,640,1,0,0, - 0,92,658,1,0,0,0,94,660,1,0,0,0,96,668,1,0,0,0,98,673,1,0,0,0,100,681, - 1,0,0,0,102,685,1,0,0,0,104,689,1,0,0,0,106,698,1,0,0,0,108,712,1,0,0, - 0,110,714,1,0,0,0,112,773,1,0,0,0,114,775,1,0,0,0,116,935,1,0,0,0,118, - 1044,1,0,0,0,120,1057,1,0,0,0,122,1084,1,0,0,0,124,1121,1,0,0,0,126,1134, - 1,0,0,0,128,1136,1,0,0,0,130,1157,1,0,0,0,132,1166,1,0,0,0,134,1168,1, - 0,0,0,136,1185,1,0,0,0,138,1198,1,0,0,0,140,1208,1,0,0,0,142,1212,1,0, - 0,0,144,1223,1,0,0,0,146,1233,1,0,0,0,148,1236,1,0,0,0,150,1249,1,0,0, - 0,152,1251,1,0,0,0,154,1253,1,0,0,0,156,1255,1,0,0,0,158,1259,1,0,0,0, - 160,1264,1,0,0,0,162,1266,1,0,0,0,164,1270,1,0,0,0,166,1276,1,0,0,0,168, - 1278,1,0,0,0,170,1292,1,0,0,0,172,1294,1,0,0,0,174,1308,1,0,0,0,176,178, - 3,2,1,0,177,176,1,0,0,0,178,181,1,0,0,0,179,177,1,0,0,0,179,180,1,0,0, - 0,180,182,1,0,0,0,181,179,1,0,0,0,182,183,5,0,0,1,183,1,1,0,0,0,184,187, - 3,6,3,0,185,187,3,10,5,0,186,184,1,0,0,0,186,185,1,0,0,0,187,3,1,0,0, - 0,188,189,3,116,58,0,189,5,1,0,0,0,190,191,5,52,0,0,191,195,3,160,80, - 0,192,193,5,115,0,0,193,194,5,122,0,0,194,196,3,4,2,0,195,192,1,0,0,0, - 195,196,1,0,0,0,196,7,1,0,0,0,197,202,3,160,80,0,198,199,5,116,0,0,199, - 201,3,160,80,0,200,198,1,0,0,0,201,204,1,0,0,0,202,200,1,0,0,0,202,203, - 1,0,0,0,203,206,1,0,0,0,204,202,1,0,0,0,205,207,5,116,0,0,206,205,1,0, - 0,0,206,207,1,0,0,0,207,9,1,0,0,0,208,221,3,12,6,0,209,221,3,14,7,0,210, - 221,3,18,9,0,211,221,3,20,10,0,212,221,3,22,11,0,213,221,3,26,13,0,214, - 221,3,24,12,0,215,221,3,28,14,0,216,221,3,30,15,0,217,221,3,36,18,0,218, - 221,3,32,16,0,219,221,3,34,17,0,220,208,1,0,0,0,220,209,1,0,0,0,220,210, - 1,0,0,0,220,211,1,0,0,0,220,212,1,0,0,0,220,213,1,0,0,0,220,214,1,0,0, - 0,220,215,1,0,0,0,220,216,1,0,0,0,220,217,1,0,0,0,220,218,1,0,0,0,220, - 219,1,0,0,0,221,11,1,0,0,0,222,224,5,72,0,0,223,225,3,4,2,0,224,223,1, - 0,0,0,224,225,1,0,0,0,225,227,1,0,0,0,226,228,5,150,0,0,227,226,1,0,0, - 0,227,228,1,0,0,0,228,13,1,0,0,0,229,231,5,84,0,0,230,232,3,4,2,0,231, - 230,1,0,0,0,231,232,1,0,0,0,232,234,1,0,0,0,233,235,5,150,0,0,234,233, - 1,0,0,0,234,235,1,0,0,0,235,15,1,0,0,0,236,245,5,14,0,0,237,238,5,130, - 0,0,238,241,3,160,80,0,239,240,5,115,0,0,240,242,3,160,80,0,241,239,1, - 0,0,0,241,242,1,0,0,0,242,243,1,0,0,0,243,244,5,149,0,0,244,246,1,0,0, - 0,245,237,1,0,0,0,245,246,1,0,0,0,246,247,1,0,0,0,247,248,3,36,18,0,248, - 17,1,0,0,0,249,250,5,93,0,0,250,254,3,36,18,0,251,253,3,16,8,0,252,251, - 1,0,0,0,253,256,1,0,0,0,254,252,1,0,0,0,254,255,1,0,0,0,255,259,1,0,0, - 0,256,254,1,0,0,0,257,258,5,29,0,0,258,260,3,36,18,0,259,257,1,0,0,0, - 259,260,1,0,0,0,260,19,1,0,0,0,261,262,5,40,0,0,262,263,5,130,0,0,263, - 264,3,4,2,0,264,265,5,149,0,0,265,268,3,10,5,0,266,267,5,25,0,0,267,269, - 3,10,5,0,268,266,1,0,0,0,268,269,1,0,0,0,269,21,1,0,0,0,270,271,5,100, - 0,0,271,272,5,130,0,0,272,273,3,4,2,0,273,274,5,149,0,0,274,276,3,10, - 5,0,275,277,5,150,0,0,276,275,1,0,0,0,276,277,1,0,0,0,277,23,1,0,0,0, - 278,279,5,33,0,0,279,283,5,130,0,0,280,284,3,6,3,0,281,284,3,30,15,0, - 282,284,3,4,2,0,283,280,1,0,0,0,283,281,1,0,0,0,283,282,1,0,0,0,283,284, - 1,0,0,0,284,285,1,0,0,0,285,287,5,150,0,0,286,288,3,4,2,0,287,286,1,0, - 0,0,287,288,1,0,0,0,288,289,1,0,0,0,289,293,5,150,0,0,290,294,3,6,3,0, - 291,294,3,30,15,0,292,294,3,4,2,0,293,290,1,0,0,0,293,291,1,0,0,0,293, - 292,1,0,0,0,293,294,1,0,0,0,294,295,1,0,0,0,295,296,5,149,0,0,296,298, - 3,10,5,0,297,299,5,150,0,0,298,297,1,0,0,0,298,299,1,0,0,0,299,25,1,0, - 0,0,300,301,5,33,0,0,301,302,5,130,0,0,302,303,5,52,0,0,303,306,3,160, - 80,0,304,305,5,116,0,0,305,307,3,160,80,0,306,304,1,0,0,0,306,307,1,0, - 0,0,307,308,1,0,0,0,308,309,5,42,0,0,309,310,3,4,2,0,310,311,5,149,0, - 0,311,313,3,10,5,0,312,314,5,150,0,0,313,312,1,0,0,0,313,314,1,0,0,0, - 314,27,1,0,0,0,315,316,5,31,0,0,316,317,3,160,80,0,317,319,5,130,0,0, - 318,320,3,8,4,0,319,318,1,0,0,0,319,320,1,0,0,0,320,321,1,0,0,0,321,322, - 5,149,0,0,322,323,3,36,18,0,323,29,1,0,0,0,324,325,3,4,2,0,325,326,5, - 115,0,0,326,327,5,122,0,0,327,328,3,4,2,0,328,31,1,0,0,0,329,331,3,4, - 2,0,330,332,5,150,0,0,331,330,1,0,0,0,331,332,1,0,0,0,332,33,1,0,0,0, - 333,334,5,150,0,0,334,35,1,0,0,0,335,339,5,128,0,0,336,338,3,2,1,0,337, - 336,1,0,0,0,338,341,1,0,0,0,339,337,1,0,0,0,339,340,1,0,0,0,340,342,1, - 0,0,0,341,339,1,0,0,0,342,343,5,147,0,0,343,37,1,0,0,0,344,345,3,4,2, - 0,345,346,5,115,0,0,346,347,3,4,2,0,347,39,1,0,0,0,348,353,3,38,19,0, - 349,350,5,116,0,0,350,352,3,38,19,0,351,349,1,0,0,0,352,355,1,0,0,0,353, - 351,1,0,0,0,353,354,1,0,0,0,354,357,1,0,0,0,355,353,1,0,0,0,356,358,5, - 116,0,0,357,356,1,0,0,0,357,358,1,0,0,0,358,41,1,0,0,0,359,363,3,44,22, - 0,360,363,3,48,24,0,361,363,3,124,62,0,362,359,1,0,0,0,362,360,1,0,0, - 0,362,361,1,0,0,0,363,364,1,0,0,0,364,365,5,0,0,1,365,43,1,0,0,0,366, - 372,3,46,23,0,367,368,5,95,0,0,368,369,5,1,0,0,369,371,3,46,23,0,370, - 367,1,0,0,0,371,374,1,0,0,0,372,370,1,0,0,0,372,373,1,0,0,0,373,45,1, - 0,0,0,374,372,1,0,0,0,375,382,3,48,24,0,376,377,5,130,0,0,377,378,3,44, - 22,0,378,379,5,149,0,0,379,382,1,0,0,0,380,382,3,164,82,0,381,375,1,0, - 0,0,381,376,1,0,0,0,381,380,1,0,0,0,382,47,1,0,0,0,383,385,3,50,25,0, - 384,383,1,0,0,0,384,385,1,0,0,0,385,386,1,0,0,0,386,388,5,79,0,0,387, - 389,5,24,0,0,388,387,1,0,0,0,388,389,1,0,0,0,389,391,1,0,0,0,390,392, - 3,52,26,0,391,390,1,0,0,0,391,392,1,0,0,0,392,393,1,0,0,0,393,395,3,114, - 57,0,394,396,3,54,27,0,395,394,1,0,0,0,395,396,1,0,0,0,396,398,1,0,0, - 0,397,399,3,56,28,0,398,397,1,0,0,0,398,399,1,0,0,0,399,401,1,0,0,0,400, - 402,3,60,30,0,401,400,1,0,0,0,401,402,1,0,0,0,402,404,1,0,0,0,403,405, - 3,62,31,0,404,403,1,0,0,0,404,405,1,0,0,0,405,407,1,0,0,0,406,408,3,64, - 32,0,407,406,1,0,0,0,407,408,1,0,0,0,408,411,1,0,0,0,409,410,5,102,0, - 0,410,412,7,0,0,0,411,409,1,0,0,0,411,412,1,0,0,0,412,415,1,0,0,0,413, - 414,5,102,0,0,414,416,5,89,0,0,415,413,1,0,0,0,415,416,1,0,0,0,416,418, - 1,0,0,0,417,419,3,66,33,0,418,417,1,0,0,0,418,419,1,0,0,0,419,421,1,0, - 0,0,420,422,3,58,29,0,421,420,1,0,0,0,421,422,1,0,0,0,422,424,1,0,0,0, - 423,425,3,68,34,0,424,423,1,0,0,0,424,425,1,0,0,0,425,428,1,0,0,0,426, - 429,3,72,36,0,427,429,3,74,37,0,428,426,1,0,0,0,428,427,1,0,0,0,428,429, - 1,0,0,0,429,431,1,0,0,0,430,432,3,76,38,0,431,430,1,0,0,0,431,432,1,0, - 0,0,432,49,1,0,0,0,433,434,5,102,0,0,434,435,3,128,64,0,435,51,1,0,0, - 0,436,437,5,88,0,0,437,440,5,108,0,0,438,439,5,102,0,0,439,441,5,85,0, - 0,440,438,1,0,0,0,440,441,1,0,0,0,441,53,1,0,0,0,442,443,5,34,0,0,443, - 444,3,78,39,0,444,55,1,0,0,0,445,447,7,1,0,0,446,445,1,0,0,0,446,447, - 1,0,0,0,447,448,1,0,0,0,448,449,5,5,0,0,449,450,5,47,0,0,450,451,3,114, - 57,0,451,57,1,0,0,0,452,453,5,101,0,0,453,454,3,160,80,0,454,455,5,6, - 0,0,455,456,5,130,0,0,456,457,3,98,49,0,457,467,5,149,0,0,458,459,5,116, - 0,0,459,460,3,160,80,0,460,461,5,6,0,0,461,462,5,130,0,0,462,463,3,98, - 49,0,463,464,5,149,0,0,464,466,1,0,0,0,465,458,1,0,0,0,466,469,1,0,0, - 0,467,465,1,0,0,0,467,468,1,0,0,0,468,59,1,0,0,0,469,467,1,0,0,0,470, - 471,5,69,0,0,471,472,3,116,58,0,472,61,1,0,0,0,473,474,5,99,0,0,474,475, - 3,116,58,0,475,63,1,0,0,0,476,477,5,36,0,0,477,484,5,11,0,0,478,479,7, - 0,0,0,479,480,5,130,0,0,480,481,3,114,57,0,481,482,5,149,0,0,482,485, - 1,0,0,0,483,485,3,114,57,0,484,478,1,0,0,0,484,483,1,0,0,0,485,65,1,0, - 0,0,486,487,5,37,0,0,487,488,3,116,58,0,488,67,1,0,0,0,489,490,5,64,0, - 0,490,491,5,11,0,0,491,492,3,88,44,0,492,69,1,0,0,0,493,494,5,64,0,0, - 494,495,5,11,0,0,495,496,3,114,57,0,496,71,1,0,0,0,497,498,5,54,0,0,498, - 501,3,116,58,0,499,500,5,116,0,0,500,502,3,116,58,0,501,499,1,0,0,0,501, - 502,1,0,0,0,502,507,1,0,0,0,503,504,5,102,0,0,504,508,5,85,0,0,505,506, - 5,11,0,0,506,508,3,114,57,0,507,503,1,0,0,0,507,505,1,0,0,0,507,508,1, - 0,0,0,508,527,1,0,0,0,509,510,5,54,0,0,510,513,3,116,58,0,511,512,5,102, - 0,0,512,514,5,85,0,0,513,511,1,0,0,0,513,514,1,0,0,0,514,515,1,0,0,0, - 515,516,5,61,0,0,516,517,3,116,58,0,517,527,1,0,0,0,518,519,5,54,0,0, - 519,520,3,116,58,0,520,521,5,61,0,0,521,524,3,116,58,0,522,523,5,11,0, - 0,523,525,3,114,57,0,524,522,1,0,0,0,524,525,1,0,0,0,525,527,1,0,0,0, - 526,497,1,0,0,0,526,509,1,0,0,0,526,518,1,0,0,0,527,73,1,0,0,0,528,529, - 5,61,0,0,529,530,3,116,58,0,530,75,1,0,0,0,531,532,5,81,0,0,532,533,3, - 94,47,0,533,77,1,0,0,0,534,535,6,39,-1,0,535,537,3,136,68,0,536,538,5, - 28,0,0,537,536,1,0,0,0,537,538,1,0,0,0,538,540,1,0,0,0,539,541,3,86,43, - 0,540,539,1,0,0,0,540,541,1,0,0,0,541,547,1,0,0,0,542,543,5,130,0,0,543, - 544,3,78,39,0,544,545,5,149,0,0,545,547,1,0,0,0,546,534,1,0,0,0,546,542, - 1,0,0,0,547,562,1,0,0,0,548,549,10,3,0,0,549,550,3,82,41,0,550,551,3, - 78,39,4,551,561,1,0,0,0,552,554,10,4,0,0,553,555,3,80,40,0,554,553,1, - 0,0,0,554,555,1,0,0,0,555,556,1,0,0,0,556,557,5,47,0,0,557,558,3,78,39, - 0,558,559,3,84,42,0,559,561,1,0,0,0,560,548,1,0,0,0,560,552,1,0,0,0,561, - 564,1,0,0,0,562,560,1,0,0,0,562,563,1,0,0,0,563,79,1,0,0,0,564,562,1, - 0,0,0,565,567,7,2,0,0,566,565,1,0,0,0,566,567,1,0,0,0,567,568,1,0,0,0, - 568,575,5,44,0,0,569,571,5,44,0,0,570,572,7,2,0,0,571,570,1,0,0,0,571, - 572,1,0,0,0,572,575,1,0,0,0,573,575,7,2,0,0,574,566,1,0,0,0,574,569,1, - 0,0,0,574,573,1,0,0,0,575,609,1,0,0,0,576,578,7,3,0,0,577,576,1,0,0,0, - 577,578,1,0,0,0,578,579,1,0,0,0,579,581,7,4,0,0,580,582,5,65,0,0,581, - 580,1,0,0,0,581,582,1,0,0,0,582,591,1,0,0,0,583,585,7,4,0,0,584,586,5, - 65,0,0,585,584,1,0,0,0,585,586,1,0,0,0,586,588,1,0,0,0,587,589,7,3,0, - 0,588,587,1,0,0,0,588,589,1,0,0,0,589,591,1,0,0,0,590,577,1,0,0,0,590, - 583,1,0,0,0,591,609,1,0,0,0,592,594,7,5,0,0,593,592,1,0,0,0,593,594,1, - 0,0,0,594,595,1,0,0,0,595,597,5,35,0,0,596,598,5,65,0,0,597,596,1,0,0, - 0,597,598,1,0,0,0,598,607,1,0,0,0,599,601,5,35,0,0,600,602,5,65,0,0,601, - 600,1,0,0,0,601,602,1,0,0,0,602,604,1,0,0,0,603,605,7,5,0,0,604,603,1, - 0,0,0,604,605,1,0,0,0,605,607,1,0,0,0,606,593,1,0,0,0,606,599,1,0,0,0, - 607,609,1,0,0,0,608,574,1,0,0,0,608,590,1,0,0,0,608,606,1,0,0,0,609,81, - 1,0,0,0,610,611,5,17,0,0,611,614,5,47,0,0,612,614,5,116,0,0,613,610,1, - 0,0,0,613,612,1,0,0,0,614,83,1,0,0,0,615,616,5,62,0,0,616,625,3,114,57, - 0,617,618,5,96,0,0,618,619,5,130,0,0,619,620,3,114,57,0,620,621,5,149, - 0,0,621,625,1,0,0,0,622,623,5,96,0,0,623,625,3,114,57,0,624,615,1,0,0, - 0,624,617,1,0,0,0,624,622,1,0,0,0,625,85,1,0,0,0,626,627,5,77,0,0,627, - 630,3,92,46,0,628,629,5,61,0,0,629,631,3,92,46,0,630,628,1,0,0,0,630, - 631,1,0,0,0,631,87,1,0,0,0,632,637,3,90,45,0,633,634,5,116,0,0,634,636, - 3,90,45,0,635,633,1,0,0,0,636,639,1,0,0,0,637,635,1,0,0,0,637,638,1,0, - 0,0,638,89,1,0,0,0,639,637,1,0,0,0,640,642,3,116,58,0,641,643,7,6,0,0, - 642,641,1,0,0,0,642,643,1,0,0,0,643,646,1,0,0,0,644,645,5,60,0,0,645, - 647,7,7,0,0,646,644,1,0,0,0,646,647,1,0,0,0,647,650,1,0,0,0,648,649,5, - 16,0,0,649,651,5,110,0,0,650,648,1,0,0,0,650,651,1,0,0,0,651,91,1,0,0, - 0,652,659,3,164,82,0,653,656,3,148,74,0,654,655,5,151,0,0,655,657,3,148, - 74,0,656,654,1,0,0,0,656,657,1,0,0,0,657,659,1,0,0,0,658,652,1,0,0,0, - 658,653,1,0,0,0,659,93,1,0,0,0,660,665,3,96,48,0,661,662,5,116,0,0,662, - 664,3,96,48,0,663,661,1,0,0,0,664,667,1,0,0,0,665,663,1,0,0,0,665,666, - 1,0,0,0,666,95,1,0,0,0,667,665,1,0,0,0,668,669,3,160,80,0,669,670,5,122, - 0,0,670,671,3,150,75,0,671,97,1,0,0,0,672,674,3,100,50,0,673,672,1,0, - 0,0,673,674,1,0,0,0,674,676,1,0,0,0,675,677,3,102,51,0,676,675,1,0,0, - 0,676,677,1,0,0,0,677,679,1,0,0,0,678,680,3,104,52,0,679,678,1,0,0,0, - 679,680,1,0,0,0,680,99,1,0,0,0,681,682,5,67,0,0,682,683,5,11,0,0,683, - 684,3,114,57,0,684,101,1,0,0,0,685,686,5,64,0,0,686,687,5,11,0,0,687, - 688,3,88,44,0,688,103,1,0,0,0,689,690,7,8,0,0,690,691,3,106,53,0,691, - 105,1,0,0,0,692,699,3,108,54,0,693,694,5,9,0,0,694,695,3,108,54,0,695, - 696,5,2,0,0,696,697,3,108,54,0,697,699,1,0,0,0,698,692,1,0,0,0,698,693, - 1,0,0,0,699,107,1,0,0,0,700,701,5,19,0,0,701,713,5,75,0,0,702,703,5,94, - 0,0,703,713,5,68,0,0,704,705,5,94,0,0,705,713,5,32,0,0,706,707,3,148, - 74,0,707,708,5,68,0,0,708,713,1,0,0,0,709,710,3,148,74,0,710,711,5,32, - 0,0,711,713,1,0,0,0,712,700,1,0,0,0,712,702,1,0,0,0,712,704,1,0,0,0,712, - 706,1,0,0,0,712,709,1,0,0,0,713,109,1,0,0,0,714,715,3,116,58,0,715,716, - 5,0,0,1,716,111,1,0,0,0,717,774,3,160,80,0,718,719,3,160,80,0,719,720, - 5,130,0,0,720,721,3,160,80,0,721,728,3,112,56,0,722,723,5,116,0,0,723, - 724,3,160,80,0,724,725,3,112,56,0,725,727,1,0,0,0,726,722,1,0,0,0,727, - 730,1,0,0,0,728,726,1,0,0,0,728,729,1,0,0,0,729,732,1,0,0,0,730,728,1, - 0,0,0,731,733,5,116,0,0,732,731,1,0,0,0,732,733,1,0,0,0,733,734,1,0,0, - 0,734,735,5,149,0,0,735,774,1,0,0,0,736,737,3,160,80,0,737,738,5,130, - 0,0,738,743,3,162,81,0,739,740,5,116,0,0,740,742,3,162,81,0,741,739,1, - 0,0,0,742,745,1,0,0,0,743,741,1,0,0,0,743,744,1,0,0,0,744,747,1,0,0,0, - 745,743,1,0,0,0,746,748,5,116,0,0,747,746,1,0,0,0,747,748,1,0,0,0,748, - 749,1,0,0,0,749,750,5,149,0,0,750,774,1,0,0,0,751,752,3,160,80,0,752, - 753,5,130,0,0,753,758,3,112,56,0,754,755,5,116,0,0,755,757,3,112,56,0, - 756,754,1,0,0,0,757,760,1,0,0,0,758,756,1,0,0,0,758,759,1,0,0,0,759,762, - 1,0,0,0,760,758,1,0,0,0,761,763,5,116,0,0,762,761,1,0,0,0,762,763,1,0, - 0,0,763,764,1,0,0,0,764,765,5,149,0,0,765,774,1,0,0,0,766,767,3,160,80, - 0,767,769,5,130,0,0,768,770,3,114,57,0,769,768,1,0,0,0,769,770,1,0,0, - 0,770,771,1,0,0,0,771,772,5,149,0,0,772,774,1,0,0,0,773,717,1,0,0,0,773, - 718,1,0,0,0,773,736,1,0,0,0,773,751,1,0,0,0,773,766,1,0,0,0,774,113,1, - 0,0,0,775,780,3,116,58,0,776,777,5,116,0,0,777,779,3,116,58,0,778,776, - 1,0,0,0,779,782,1,0,0,0,780,778,1,0,0,0,780,781,1,0,0,0,781,784,1,0,0, - 0,782,780,1,0,0,0,783,785,5,116,0,0,784,783,1,0,0,0,784,785,1,0,0,0,785, - 115,1,0,0,0,786,787,6,58,-1,0,787,789,5,12,0,0,788,790,3,116,58,0,789, - 788,1,0,0,0,789,790,1,0,0,0,790,796,1,0,0,0,791,792,5,98,0,0,792,793, - 3,116,58,0,793,794,5,83,0,0,794,795,3,116,58,0,795,797,1,0,0,0,796,791, - 1,0,0,0,797,798,1,0,0,0,798,796,1,0,0,0,798,799,1,0,0,0,799,802,1,0,0, - 0,800,801,5,25,0,0,801,803,3,116,58,0,802,800,1,0,0,0,802,803,1,0,0,0, - 803,804,1,0,0,0,804,805,5,26,0,0,805,936,1,0,0,0,806,807,5,13,0,0,807, - 808,5,130,0,0,808,809,3,116,58,0,809,810,5,6,0,0,810,811,3,112,56,0,811, - 812,5,149,0,0,812,936,1,0,0,0,813,814,5,20,0,0,814,936,5,110,0,0,815, - 816,5,45,0,0,816,817,3,116,58,0,817,818,3,152,76,0,818,936,1,0,0,0,819, - 820,5,82,0,0,820,821,5,130,0,0,821,822,3,116,58,0,822,823,5,34,0,0,823, - 826,3,116,58,0,824,825,5,33,0,0,825,827,3,116,58,0,826,824,1,0,0,0,826, - 827,1,0,0,0,827,828,1,0,0,0,828,829,5,149,0,0,829,936,1,0,0,0,830,831, - 5,86,0,0,831,936,5,110,0,0,832,833,5,91,0,0,833,834,5,130,0,0,834,835, - 7,9,0,0,835,836,3,166,83,0,836,837,5,34,0,0,837,838,3,116,58,0,838,839, - 5,149,0,0,839,936,1,0,0,0,840,841,3,160,80,0,841,843,5,130,0,0,842,844, - 3,114,57,0,843,842,1,0,0,0,843,844,1,0,0,0,844,845,1,0,0,0,845,846,5, - 149,0,0,846,855,1,0,0,0,847,849,5,130,0,0,848,850,5,24,0,0,849,848,1, - 0,0,0,849,850,1,0,0,0,850,852,1,0,0,0,851,853,3,118,59,0,852,851,1,0, - 0,0,852,853,1,0,0,0,853,854,1,0,0,0,854,856,5,149,0,0,855,847,1,0,0,0, - 855,856,1,0,0,0,856,857,1,0,0,0,857,858,5,66,0,0,858,859,5,130,0,0,859, - 860,3,98,49,0,860,861,5,149,0,0,861,936,1,0,0,0,862,863,3,160,80,0,863, - 865,5,130,0,0,864,866,3,114,57,0,865,864,1,0,0,0,865,866,1,0,0,0,866, - 867,1,0,0,0,867,868,5,149,0,0,868,877,1,0,0,0,869,871,5,130,0,0,870,872, - 5,24,0,0,871,870,1,0,0,0,871,872,1,0,0,0,872,874,1,0,0,0,873,875,3,118, - 59,0,874,873,1,0,0,0,874,875,1,0,0,0,875,876,1,0,0,0,876,878,5,149,0, - 0,877,869,1,0,0,0,877,878,1,0,0,0,878,879,1,0,0,0,879,880,5,66,0,0,880, - 881,3,160,80,0,881,936,1,0,0,0,882,888,3,160,80,0,883,885,5,130,0,0,884, - 886,3,114,57,0,885,884,1,0,0,0,885,886,1,0,0,0,886,887,1,0,0,0,887,889, - 5,149,0,0,888,883,1,0,0,0,888,889,1,0,0,0,889,890,1,0,0,0,890,892,5,130, - 0,0,891,893,5,24,0,0,892,891,1,0,0,0,892,893,1,0,0,0,893,895,1,0,0,0, - 894,896,3,118,59,0,895,894,1,0,0,0,895,896,1,0,0,0,896,897,1,0,0,0,897, - 898,5,149,0,0,898,936,1,0,0,0,899,936,3,124,62,0,900,936,3,168,84,0,901, - 936,3,150,75,0,902,903,5,118,0,0,903,936,3,116,58,19,904,905,5,58,0,0, - 905,936,3,116,58,13,906,907,3,140,70,0,907,908,5,120,0,0,908,910,1,0, - 0,0,909,906,1,0,0,0,909,910,1,0,0,0,910,911,1,0,0,0,911,936,5,112,0,0, - 912,913,5,130,0,0,913,914,3,44,22,0,914,915,5,149,0,0,915,936,1,0,0,0, - 916,917,5,130,0,0,917,918,3,116,58,0,918,919,5,149,0,0,919,936,1,0,0, - 0,920,921,5,130,0,0,921,922,3,114,57,0,922,923,5,149,0,0,923,936,1,0, - 0,0,924,926,5,129,0,0,925,927,3,114,57,0,926,925,1,0,0,0,926,927,1,0, - 0,0,927,928,1,0,0,0,928,936,5,148,0,0,929,931,5,128,0,0,930,932,3,40, - 20,0,931,930,1,0,0,0,931,932,1,0,0,0,932,933,1,0,0,0,933,936,5,147,0, - 0,934,936,3,132,66,0,935,786,1,0,0,0,935,806,1,0,0,0,935,813,1,0,0,0, - 935,815,1,0,0,0,935,819,1,0,0,0,935,830,1,0,0,0,935,832,1,0,0,0,935,840, - 1,0,0,0,935,862,1,0,0,0,935,882,1,0,0,0,935,899,1,0,0,0,935,900,1,0,0, - 0,935,901,1,0,0,0,935,902,1,0,0,0,935,904,1,0,0,0,935,909,1,0,0,0,935, - 912,1,0,0,0,935,916,1,0,0,0,935,920,1,0,0,0,935,924,1,0,0,0,935,929,1, - 0,0,0,935,934,1,0,0,0,936,1041,1,0,0,0,937,941,10,18,0,0,938,942,5,112, - 0,0,939,942,5,151,0,0,940,942,5,138,0,0,941,938,1,0,0,0,941,939,1,0,0, - 0,941,940,1,0,0,0,942,943,1,0,0,0,943,1040,3,116,58,19,944,948,10,17, - 0,0,945,949,5,139,0,0,946,949,5,118,0,0,947,949,5,117,0,0,948,945,1,0, - 0,0,948,946,1,0,0,0,948,947,1,0,0,0,949,950,1,0,0,0,950,1040,3,116,58, - 18,951,976,10,16,0,0,952,977,5,121,0,0,953,977,5,122,0,0,954,977,5,133, - 0,0,955,977,5,131,0,0,956,977,5,132,0,0,957,977,5,123,0,0,958,977,5,124, - 0,0,959,961,5,58,0,0,960,959,1,0,0,0,960,961,1,0,0,0,961,962,1,0,0,0, - 962,964,5,42,0,0,963,965,5,15,0,0,964,963,1,0,0,0,964,965,1,0,0,0,965, - 977,1,0,0,0,966,968,5,58,0,0,967,966,1,0,0,0,967,968,1,0,0,0,968,969, - 1,0,0,0,969,977,7,10,0,0,970,977,5,145,0,0,971,977,5,146,0,0,972,977, - 5,135,0,0,973,977,5,126,0,0,974,977,5,127,0,0,975,977,5,134,0,0,976,952, - 1,0,0,0,976,953,1,0,0,0,976,954,1,0,0,0,976,955,1,0,0,0,976,956,1,0,0, - 0,976,957,1,0,0,0,976,958,1,0,0,0,976,960,1,0,0,0,976,967,1,0,0,0,976, - 970,1,0,0,0,976,971,1,0,0,0,976,972,1,0,0,0,976,973,1,0,0,0,976,974,1, - 0,0,0,976,975,1,0,0,0,977,978,1,0,0,0,978,1040,3,116,58,17,979,980,10, - 14,0,0,980,981,5,137,0,0,981,1040,3,116,58,15,982,983,10,12,0,0,983,984, - 5,2,0,0,984,1040,3,116,58,13,985,986,10,11,0,0,986,987,5,63,0,0,987,1040, - 3,116,58,12,988,990,10,10,0,0,989,991,5,58,0,0,990,989,1,0,0,0,990,991, - 1,0,0,0,991,992,1,0,0,0,992,993,5,9,0,0,993,994,3,116,58,0,994,995,5, - 2,0,0,995,996,3,116,58,11,996,1040,1,0,0,0,997,998,10,9,0,0,998,999,5, - 140,0,0,999,1000,3,116,58,0,1000,1001,5,115,0,0,1001,1002,3,116,58,9, - 1002,1040,1,0,0,0,1003,1004,10,25,0,0,1004,1005,5,129,0,0,1005,1006,3, - 116,58,0,1006,1007,5,148,0,0,1007,1040,1,0,0,0,1008,1009,10,24,0,0,1009, - 1010,5,120,0,0,1010,1040,5,108,0,0,1011,1012,10,23,0,0,1012,1013,5,120, - 0,0,1013,1040,3,160,80,0,1014,1015,10,22,0,0,1015,1016,5,136,0,0,1016, - 1017,5,129,0,0,1017,1018,3,116,58,0,1018,1019,5,148,0,0,1019,1040,1,0, - 0,0,1020,1021,10,21,0,0,1021,1022,5,136,0,0,1022,1040,5,108,0,0,1023, - 1024,10,20,0,0,1024,1025,5,136,0,0,1025,1040,3,160,80,0,1026,1027,10, - 15,0,0,1027,1029,5,46,0,0,1028,1030,5,58,0,0,1029,1028,1,0,0,0,1029,1030, - 1,0,0,0,1030,1031,1,0,0,0,1031,1040,5,59,0,0,1032,1037,10,8,0,0,1033, - 1034,5,6,0,0,1034,1038,3,160,80,0,1035,1036,5,6,0,0,1036,1038,5,110,0, - 0,1037,1033,1,0,0,0,1037,1035,1,0,0,0,1038,1040,1,0,0,0,1039,937,1,0, - 0,0,1039,944,1,0,0,0,1039,951,1,0,0,0,1039,979,1,0,0,0,1039,982,1,0,0, - 0,1039,985,1,0,0,0,1039,988,1,0,0,0,1039,997,1,0,0,0,1039,1003,1,0,0, - 0,1039,1008,1,0,0,0,1039,1011,1,0,0,0,1039,1014,1,0,0,0,1039,1020,1,0, - 0,0,1039,1023,1,0,0,0,1039,1026,1,0,0,0,1039,1032,1,0,0,0,1040,1043,1, - 0,0,0,1041,1039,1,0,0,0,1041,1042,1,0,0,0,1042,117,1,0,0,0,1043,1041, - 1,0,0,0,1044,1049,3,120,60,0,1045,1046,5,116,0,0,1046,1048,3,120,60,0, - 1047,1045,1,0,0,0,1048,1051,1,0,0,0,1049,1047,1,0,0,0,1049,1050,1,0,0, - 0,1050,1053,1,0,0,0,1051,1049,1,0,0,0,1052,1054,5,116,0,0,1053,1052,1, - 0,0,0,1053,1054,1,0,0,0,1054,119,1,0,0,0,1055,1058,3,122,61,0,1056,1058, - 3,116,58,0,1057,1055,1,0,0,0,1057,1056,1,0,0,0,1058,121,1,0,0,0,1059, - 1060,5,130,0,0,1060,1065,3,160,80,0,1061,1062,5,116,0,0,1062,1064,3,160, - 80,0,1063,1061,1,0,0,0,1064,1067,1,0,0,0,1065,1063,1,0,0,0,1065,1066, - 1,0,0,0,1066,1069,1,0,0,0,1067,1065,1,0,0,0,1068,1070,5,116,0,0,1069, - 1068,1,0,0,0,1069,1070,1,0,0,0,1070,1071,1,0,0,0,1071,1072,5,149,0,0, - 1072,1085,1,0,0,0,1073,1078,3,160,80,0,1074,1075,5,116,0,0,1075,1077, - 3,160,80,0,1076,1074,1,0,0,0,1077,1080,1,0,0,0,1078,1076,1,0,0,0,1078, - 1079,1,0,0,0,1079,1082,1,0,0,0,1080,1078,1,0,0,0,1081,1083,5,116,0,0, - 1082,1081,1,0,0,0,1082,1083,1,0,0,0,1083,1085,1,0,0,0,1084,1059,1,0,0, - 0,1084,1073,1,0,0,0,1085,1086,1,0,0,0,1086,1087,5,111,0,0,1087,1088,3, - 116,58,0,1088,123,1,0,0,0,1089,1090,5,132,0,0,1090,1094,3,160,80,0,1091, - 1093,3,126,63,0,1092,1091,1,0,0,0,1093,1096,1,0,0,0,1094,1092,1,0,0,0, - 1094,1095,1,0,0,0,1095,1097,1,0,0,0,1096,1094,1,0,0,0,1097,1098,5,151, - 0,0,1098,1099,5,124,0,0,1099,1122,1,0,0,0,1100,1101,5,132,0,0,1101,1105, - 3,160,80,0,1102,1104,3,126,63,0,1103,1102,1,0,0,0,1104,1107,1,0,0,0,1105, - 1103,1,0,0,0,1105,1106,1,0,0,0,1106,1108,1,0,0,0,1107,1105,1,0,0,0,1108, - 1114,5,124,0,0,1109,1115,3,124,62,0,1110,1111,5,128,0,0,1111,1112,3,116, - 58,0,1112,1113,5,147,0,0,1113,1115,1,0,0,0,1114,1109,1,0,0,0,1114,1110, - 1,0,0,0,1114,1115,1,0,0,0,1115,1116,1,0,0,0,1116,1117,5,132,0,0,1117, - 1118,5,151,0,0,1118,1119,3,160,80,0,1119,1120,5,124,0,0,1120,1122,1,0, - 0,0,1121,1089,1,0,0,0,1121,1100,1,0,0,0,1122,125,1,0,0,0,1123,1124,3, - 160,80,0,1124,1125,5,122,0,0,1125,1126,3,166,83,0,1126,1135,1,0,0,0,1127, - 1128,3,160,80,0,1128,1129,5,122,0,0,1129,1130,5,128,0,0,1130,1131,3,116, - 58,0,1131,1132,5,147,0,0,1132,1135,1,0,0,0,1133,1135,3,160,80,0,1134, - 1123,1,0,0,0,1134,1127,1,0,0,0,1134,1133,1,0,0,0,1135,127,1,0,0,0,1136, - 1141,3,130,65,0,1137,1138,5,116,0,0,1138,1140,3,130,65,0,1139,1137,1, - 0,0,0,1140,1143,1,0,0,0,1141,1139,1,0,0,0,1141,1142,1,0,0,0,1142,1145, - 1,0,0,0,1143,1141,1,0,0,0,1144,1146,5,116,0,0,1145,1144,1,0,0,0,1145, - 1146,1,0,0,0,1146,129,1,0,0,0,1147,1148,3,160,80,0,1148,1149,5,6,0,0, - 1149,1150,5,130,0,0,1150,1151,3,44,22,0,1151,1152,5,149,0,0,1152,1158, - 1,0,0,0,1153,1154,3,116,58,0,1154,1155,5,6,0,0,1155,1156,3,160,80,0,1156, - 1158,1,0,0,0,1157,1147,1,0,0,0,1157,1153,1,0,0,0,1158,131,1,0,0,0,1159, - 1167,3,164,82,0,1160,1161,3,140,70,0,1161,1162,5,120,0,0,1162,1164,1, - 0,0,0,1163,1160,1,0,0,0,1163,1164,1,0,0,0,1164,1165,1,0,0,0,1165,1167, - 3,134,67,0,1166,1159,1,0,0,0,1166,1163,1,0,0,0,1167,133,1,0,0,0,1168, - 1173,3,160,80,0,1169,1170,5,120,0,0,1170,1172,3,160,80,0,1171,1169,1, - 0,0,0,1172,1175,1,0,0,0,1173,1171,1,0,0,0,1173,1174,1,0,0,0,1174,135, - 1,0,0,0,1175,1173,1,0,0,0,1176,1177,6,68,-1,0,1177,1186,3,140,70,0,1178, - 1186,3,138,69,0,1179,1180,5,130,0,0,1180,1181,3,44,22,0,1181,1182,5,149, - 0,0,1182,1186,1,0,0,0,1183,1186,3,124,62,0,1184,1186,3,164,82,0,1185, - 1176,1,0,0,0,1185,1178,1,0,0,0,1185,1179,1,0,0,0,1185,1183,1,0,0,0,1185, - 1184,1,0,0,0,1186,1195,1,0,0,0,1187,1191,10,3,0,0,1188,1192,3,158,79, - 0,1189,1190,5,6,0,0,1190,1192,3,160,80,0,1191,1188,1,0,0,0,1191,1189, - 1,0,0,0,1192,1194,1,0,0,0,1193,1187,1,0,0,0,1194,1197,1,0,0,0,1195,1193, - 1,0,0,0,1195,1196,1,0,0,0,1196,137,1,0,0,0,1197,1195,1,0,0,0,1198,1199, - 3,160,80,0,1199,1201,5,130,0,0,1200,1202,3,142,71,0,1201,1200,1,0,0,0, - 1201,1202,1,0,0,0,1202,1203,1,0,0,0,1203,1204,5,149,0,0,1204,139,1,0, - 0,0,1205,1206,3,144,72,0,1206,1207,5,120,0,0,1207,1209,1,0,0,0,1208,1205, - 1,0,0,0,1208,1209,1,0,0,0,1209,1210,1,0,0,0,1210,1211,3,160,80,0,1211, - 141,1,0,0,0,1212,1217,3,116,58,0,1213,1214,5,116,0,0,1214,1216,3,116, - 58,0,1215,1213,1,0,0,0,1216,1219,1,0,0,0,1217,1215,1,0,0,0,1217,1218, - 1,0,0,0,1218,1221,1,0,0,0,1219,1217,1,0,0,0,1220,1222,5,116,0,0,1221, - 1220,1,0,0,0,1221,1222,1,0,0,0,1222,143,1,0,0,0,1223,1224,3,160,80,0, - 1224,145,1,0,0,0,1225,1234,5,106,0,0,1226,1227,5,120,0,0,1227,1234,7, - 11,0,0,1228,1229,5,108,0,0,1229,1231,5,120,0,0,1230,1232,7,11,0,0,1231, - 1230,1,0,0,0,1231,1232,1,0,0,0,1232,1234,1,0,0,0,1233,1225,1,0,0,0,1233, - 1226,1,0,0,0,1233,1228,1,0,0,0,1234,147,1,0,0,0,1235,1237,7,12,0,0,1236, - 1235,1,0,0,0,1236,1237,1,0,0,0,1237,1244,1,0,0,0,1238,1245,3,146,73,0, - 1239,1245,5,107,0,0,1240,1245,5,108,0,0,1241,1245,5,109,0,0,1242,1245, - 5,43,0,0,1243,1245,5,57,0,0,1244,1238,1,0,0,0,1244,1239,1,0,0,0,1244, - 1240,1,0,0,0,1244,1241,1,0,0,0,1244,1242,1,0,0,0,1244,1243,1,0,0,0,1245, - 149,1,0,0,0,1246,1250,3,148,74,0,1247,1250,5,110,0,0,1248,1250,5,59,0, - 0,1249,1246,1,0,0,0,1249,1247,1,0,0,0,1249,1248,1,0,0,0,1250,151,1,0, - 0,0,1251,1252,7,13,0,0,1252,153,1,0,0,0,1253,1254,7,14,0,0,1254,155,1, - 0,0,0,1255,1256,7,15,0,0,1256,157,1,0,0,0,1257,1260,5,105,0,0,1258,1260, - 3,156,78,0,1259,1257,1,0,0,0,1259,1258,1,0,0,0,1260,159,1,0,0,0,1261, - 1265,5,105,0,0,1262,1265,3,152,76,0,1263,1265,3,154,77,0,1264,1261,1, - 0,0,0,1264,1262,1,0,0,0,1264,1263,1,0,0,0,1265,161,1,0,0,0,1266,1267, - 3,166,83,0,1267,1268,5,122,0,0,1268,1269,3,148,74,0,1269,163,1,0,0,0, - 1270,1271,5,128,0,0,1271,1272,3,134,67,0,1272,1273,5,147,0,0,1273,165, - 1,0,0,0,1274,1277,5,110,0,0,1275,1277,3,168,84,0,1276,1274,1,0,0,0,1276, - 1275,1,0,0,0,1277,167,1,0,0,0,1278,1282,5,142,0,0,1279,1281,3,170,85, - 0,1280,1279,1,0,0,0,1281,1284,1,0,0,0,1282,1280,1,0,0,0,1282,1283,1,0, - 0,0,1283,1285,1,0,0,0,1284,1282,1,0,0,0,1285,1286,5,144,0,0,1286,169, - 1,0,0,0,1287,1288,5,157,0,0,1288,1289,3,116,58,0,1289,1290,5,147,0,0, - 1290,1293,1,0,0,0,1291,1293,5,156,0,0,1292,1287,1,0,0,0,1292,1291,1,0, - 0,0,1293,171,1,0,0,0,1294,1298,5,143,0,0,1295,1297,3,174,87,0,1296,1295, - 1,0,0,0,1297,1300,1,0,0,0,1298,1296,1,0,0,0,1298,1299,1,0,0,0,1299,1301, - 1,0,0,0,1300,1298,1,0,0,0,1301,1302,5,0,0,1,1302,173,1,0,0,0,1303,1304, - 5,159,0,0,1304,1305,3,116,58,0,1305,1306,5,147,0,0,1306,1309,1,0,0,0, - 1307,1309,5,158,0,0,1308,1303,1,0,0,0,1308,1307,1,0,0,0,1309,175,1,0, - 0,0,168,179,186,195,202,206,220,224,227,231,234,241,245,254,259,268,276, - 283,287,293,298,306,313,319,331,339,353,357,362,372,381,384,388,391,395, - 398,401,404,407,411,415,418,421,424,428,431,440,446,467,484,501,507,513, - 524,526,537,540,546,554,560,562,566,571,574,577,581,585,588,590,593,597, - 601,604,606,608,613,624,630,637,642,646,650,656,658,665,673,676,679,698, - 712,728,732,743,747,758,762,769,773,780,784,789,798,802,826,843,849,852, - 855,865,871,874,877,885,888,892,895,909,926,931,935,941,948,960,964,967, - 976,990,1029,1037,1039,1041,1049,1053,1057,1065,1069,1078,1082,1084,1094, - 1105,1114,1121,1134,1141,1145,1157,1163,1166,1173,1185,1191,1195,1201, - 1208,1217,1221,1231,1233,1236,1244,1249,1259,1264,1276,1282,1292,1298, - 1308 + 1,58,3,58,1033,8,58,1,58,1,58,1,58,1,58,1,58,1,58,3,58,1041,8,58,5,58, + 1043,8,58,10,58,12,58,1046,9,58,1,59,1,59,1,59,1,59,5,59,1052,8,59,10, + 59,12,59,1055,9,59,1,59,3,59,1058,8,59,1,59,1,59,1,59,1,59,1,59,5,59, + 1065,8,59,10,59,12,59,1068,9,59,1,59,3,59,1071,8,59,1,59,1,59,3,59,1075, + 8,59,1,59,1,59,1,59,3,59,1080,8,59,1,60,1,60,1,60,5,60,1085,8,60,10,60, + 12,60,1088,9,60,1,60,1,60,1,60,1,60,1,60,1,60,5,60,1096,8,60,10,60,12, + 60,1099,9,60,1,60,1,60,1,60,1,60,1,60,1,60,3,60,1107,8,60,1,60,1,60,1, + 60,1,60,1,60,3,60,1114,8,60,1,61,1,61,1,61,1,61,1,61,1,61,1,61,1,61,1, + 61,1,61,1,61,3,61,1127,8,61,1,62,1,62,1,62,5,62,1132,8,62,10,62,12,62, + 1135,9,62,1,62,3,62,1138,8,62,1,63,1,63,1,63,1,63,1,63,1,63,1,63,1,63, + 1,63,1,63,3,63,1150,8,63,1,64,1,64,1,64,1,64,3,64,1156,8,64,1,64,3,64, + 1159,8,64,1,65,1,65,1,65,5,65,1164,8,65,10,65,12,65,1167,9,65,1,66,1, + 66,1,66,1,66,1,66,1,66,1,66,1,66,1,66,3,66,1178,8,66,1,66,1,66,1,66,1, + 66,3,66,1184,8,66,5,66,1186,8,66,10,66,12,66,1189,9,66,1,67,1,67,1,67, + 3,67,1194,8,67,1,67,1,67,1,68,1,68,1,68,3,68,1201,8,68,1,68,1,68,1,69, + 1,69,1,69,5,69,1208,8,69,10,69,12,69,1211,9,69,1,69,3,69,1214,8,69,1, + 70,1,70,1,71,1,71,1,71,1,71,1,71,1,71,3,71,1224,8,71,3,71,1226,8,71,1, + 72,3,72,1229,8,72,1,72,1,72,1,72,1,72,1,72,1,72,3,72,1237,8,72,1,73,1, + 73,1,73,3,73,1242,8,73,1,74,1,74,1,75,1,75,1,76,1,76,1,77,1,77,3,77,1252, + 8,77,1,78,1,78,1,78,3,78,1257,8,78,1,79,1,79,1,79,1,79,1,80,1,80,1,80, + 1,80,1,81,1,81,3,81,1269,8,81,1,82,1,82,5,82,1273,8,82,10,82,12,82,1276, + 9,82,1,82,1,82,1,83,1,83,1,83,1,83,1,83,3,83,1285,8,83,1,84,1,84,5,84, + 1289,8,84,10,84,12,84,1292,9,84,1,84,1,84,1,85,1,85,1,85,1,85,1,85,3, + 85,1301,8,85,1,85,0,3,78,116,132,86,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,0,16,2,0,18,18,74,74,2,0, + 44,44,51,51,3,0,1,1,4,4,8,8,4,0,1,1,3,4,8,8,80,80,2,0,51,51,73,73,2,0, + 1,1,4,4,2,0,7,7,22,23,2,0,30,30,49,49,2,0,71,71,76,76,3,0,10,10,50,50, + 90,90,2,0,41,41,53,53,1,0,107,108,2,0,118,118,139,139,7,0,21,21,38,38, + 55,56,70,70,78,78,97,97,103,103,16,0,1,13,15,20,22,28,30,30,32,37,39, + 42,44,51,53,54,58,58,60,69,71,77,79,83,85,92,94,96,98,99,101,102,4,0, + 20,20,30,30,39,39,48,48,1475,0,175,1,0,0,0,2,182,1,0,0,0,4,184,1,0,0, + 0,6,186,1,0,0,0,8,193,1,0,0,0,10,216,1,0,0,0,12,218,1,0,0,0,14,225,1, + 0,0,0,16,232,1,0,0,0,18,245,1,0,0,0,20,257,1,0,0,0,22,266,1,0,0,0,24, + 274,1,0,0,0,26,296,1,0,0,0,28,311,1,0,0,0,30,320,1,0,0,0,32,325,1,0,0, + 0,34,329,1,0,0,0,36,331,1,0,0,0,38,340,1,0,0,0,40,344,1,0,0,0,42,358, + 1,0,0,0,44,362,1,0,0,0,46,377,1,0,0,0,48,380,1,0,0,0,50,429,1,0,0,0,52, + 432,1,0,0,0,54,438,1,0,0,0,56,442,1,0,0,0,58,448,1,0,0,0,60,466,1,0,0, + 0,62,469,1,0,0,0,64,472,1,0,0,0,66,482,1,0,0,0,68,485,1,0,0,0,70,489, + 1,0,0,0,72,522,1,0,0,0,74,524,1,0,0,0,76,527,1,0,0,0,78,542,1,0,0,0,80, + 604,1,0,0,0,82,609,1,0,0,0,84,620,1,0,0,0,86,622,1,0,0,0,88,628,1,0,0, + 0,90,636,1,0,0,0,92,654,1,0,0,0,94,656,1,0,0,0,96,664,1,0,0,0,98,669, + 1,0,0,0,100,677,1,0,0,0,102,681,1,0,0,0,104,685,1,0,0,0,106,694,1,0,0, + 0,108,708,1,0,0,0,110,710,1,0,0,0,112,769,1,0,0,0,114,771,1,0,0,0,116, + 932,1,0,0,0,118,1074,1,0,0,0,120,1113,1,0,0,0,122,1126,1,0,0,0,124,1128, + 1,0,0,0,126,1149,1,0,0,0,128,1158,1,0,0,0,130,1160,1,0,0,0,132,1177,1, + 0,0,0,134,1190,1,0,0,0,136,1200,1,0,0,0,138,1204,1,0,0,0,140,1215,1,0, + 0,0,142,1225,1,0,0,0,144,1228,1,0,0,0,146,1241,1,0,0,0,148,1243,1,0,0, + 0,150,1245,1,0,0,0,152,1247,1,0,0,0,154,1251,1,0,0,0,156,1256,1,0,0,0, + 158,1258,1,0,0,0,160,1262,1,0,0,0,162,1268,1,0,0,0,164,1270,1,0,0,0,166, + 1284,1,0,0,0,168,1286,1,0,0,0,170,1300,1,0,0,0,172,174,3,2,1,0,173,172, + 1,0,0,0,174,177,1,0,0,0,175,173,1,0,0,0,175,176,1,0,0,0,176,178,1,0,0, + 0,177,175,1,0,0,0,178,179,5,0,0,1,179,1,1,0,0,0,180,183,3,6,3,0,181,183, + 3,10,5,0,182,180,1,0,0,0,182,181,1,0,0,0,183,3,1,0,0,0,184,185,3,116, + 58,0,185,5,1,0,0,0,186,187,5,52,0,0,187,191,3,156,78,0,188,189,5,115, + 0,0,189,190,5,122,0,0,190,192,3,4,2,0,191,188,1,0,0,0,191,192,1,0,0,0, + 192,7,1,0,0,0,193,198,3,156,78,0,194,195,5,116,0,0,195,197,3,156,78,0, + 196,194,1,0,0,0,197,200,1,0,0,0,198,196,1,0,0,0,198,199,1,0,0,0,199,202, + 1,0,0,0,200,198,1,0,0,0,201,203,5,116,0,0,202,201,1,0,0,0,202,203,1,0, + 0,0,203,9,1,0,0,0,204,217,3,12,6,0,205,217,3,14,7,0,206,217,3,18,9,0, + 207,217,3,20,10,0,208,217,3,22,11,0,209,217,3,26,13,0,210,217,3,24,12, + 0,211,217,3,28,14,0,212,217,3,30,15,0,213,217,3,36,18,0,214,217,3,32, + 16,0,215,217,3,34,17,0,216,204,1,0,0,0,216,205,1,0,0,0,216,206,1,0,0, + 0,216,207,1,0,0,0,216,208,1,0,0,0,216,209,1,0,0,0,216,210,1,0,0,0,216, + 211,1,0,0,0,216,212,1,0,0,0,216,213,1,0,0,0,216,214,1,0,0,0,216,215,1, + 0,0,0,217,11,1,0,0,0,218,220,5,72,0,0,219,221,3,4,2,0,220,219,1,0,0,0, + 220,221,1,0,0,0,221,223,1,0,0,0,222,224,5,150,0,0,223,222,1,0,0,0,223, + 224,1,0,0,0,224,13,1,0,0,0,225,227,5,84,0,0,226,228,3,4,2,0,227,226,1, + 0,0,0,227,228,1,0,0,0,228,230,1,0,0,0,229,231,5,150,0,0,230,229,1,0,0, + 0,230,231,1,0,0,0,231,15,1,0,0,0,232,241,5,14,0,0,233,234,5,130,0,0,234, + 237,3,156,78,0,235,236,5,115,0,0,236,238,3,156,78,0,237,235,1,0,0,0,237, + 238,1,0,0,0,238,239,1,0,0,0,239,240,5,149,0,0,240,242,1,0,0,0,241,233, + 1,0,0,0,241,242,1,0,0,0,242,243,1,0,0,0,243,244,3,36,18,0,244,17,1,0, + 0,0,245,246,5,93,0,0,246,250,3,36,18,0,247,249,3,16,8,0,248,247,1,0,0, + 0,249,252,1,0,0,0,250,248,1,0,0,0,250,251,1,0,0,0,251,255,1,0,0,0,252, + 250,1,0,0,0,253,254,5,29,0,0,254,256,3,36,18,0,255,253,1,0,0,0,255,256, + 1,0,0,0,256,19,1,0,0,0,257,258,5,40,0,0,258,259,5,130,0,0,259,260,3,4, + 2,0,260,261,5,149,0,0,261,264,3,10,5,0,262,263,5,25,0,0,263,265,3,10, + 5,0,264,262,1,0,0,0,264,265,1,0,0,0,265,21,1,0,0,0,266,267,5,100,0,0, + 267,268,5,130,0,0,268,269,3,4,2,0,269,270,5,149,0,0,270,272,3,10,5,0, + 271,273,5,150,0,0,272,271,1,0,0,0,272,273,1,0,0,0,273,23,1,0,0,0,274, + 275,5,33,0,0,275,279,5,130,0,0,276,280,3,6,3,0,277,280,3,30,15,0,278, + 280,3,4,2,0,279,276,1,0,0,0,279,277,1,0,0,0,279,278,1,0,0,0,279,280,1, + 0,0,0,280,281,1,0,0,0,281,283,5,150,0,0,282,284,3,4,2,0,283,282,1,0,0, + 0,283,284,1,0,0,0,284,285,1,0,0,0,285,289,5,150,0,0,286,290,3,6,3,0,287, + 290,3,30,15,0,288,290,3,4,2,0,289,286,1,0,0,0,289,287,1,0,0,0,289,288, + 1,0,0,0,289,290,1,0,0,0,290,291,1,0,0,0,291,292,5,149,0,0,292,294,3,10, + 5,0,293,295,5,150,0,0,294,293,1,0,0,0,294,295,1,0,0,0,295,25,1,0,0,0, + 296,297,5,33,0,0,297,298,5,130,0,0,298,299,5,52,0,0,299,302,3,156,78, + 0,300,301,5,116,0,0,301,303,3,156,78,0,302,300,1,0,0,0,302,303,1,0,0, + 0,303,304,1,0,0,0,304,305,5,42,0,0,305,306,3,4,2,0,306,307,5,149,0,0, + 307,309,3,10,5,0,308,310,5,150,0,0,309,308,1,0,0,0,309,310,1,0,0,0,310, + 27,1,0,0,0,311,312,5,31,0,0,312,313,3,156,78,0,313,315,5,130,0,0,314, + 316,3,8,4,0,315,314,1,0,0,0,315,316,1,0,0,0,316,317,1,0,0,0,317,318,5, + 149,0,0,318,319,3,36,18,0,319,29,1,0,0,0,320,321,3,4,2,0,321,322,5,115, + 0,0,322,323,5,122,0,0,323,324,3,4,2,0,324,31,1,0,0,0,325,327,3,4,2,0, + 326,328,5,150,0,0,327,326,1,0,0,0,327,328,1,0,0,0,328,33,1,0,0,0,329, + 330,5,150,0,0,330,35,1,0,0,0,331,335,5,128,0,0,332,334,3,2,1,0,333,332, + 1,0,0,0,334,337,1,0,0,0,335,333,1,0,0,0,335,336,1,0,0,0,336,338,1,0,0, + 0,337,335,1,0,0,0,338,339,5,147,0,0,339,37,1,0,0,0,340,341,3,4,2,0,341, + 342,5,115,0,0,342,343,3,4,2,0,343,39,1,0,0,0,344,349,3,38,19,0,345,346, + 5,116,0,0,346,348,3,38,19,0,347,345,1,0,0,0,348,351,1,0,0,0,349,347,1, + 0,0,0,349,350,1,0,0,0,350,353,1,0,0,0,351,349,1,0,0,0,352,354,5,116,0, + 0,353,352,1,0,0,0,353,354,1,0,0,0,354,41,1,0,0,0,355,359,3,44,22,0,356, + 359,3,48,24,0,357,359,3,120,60,0,358,355,1,0,0,0,358,356,1,0,0,0,358, + 357,1,0,0,0,359,360,1,0,0,0,360,361,5,0,0,1,361,43,1,0,0,0,362,368,3, + 46,23,0,363,364,5,95,0,0,364,365,5,1,0,0,365,367,3,46,23,0,366,363,1, + 0,0,0,367,370,1,0,0,0,368,366,1,0,0,0,368,369,1,0,0,0,369,45,1,0,0,0, + 370,368,1,0,0,0,371,378,3,48,24,0,372,373,5,130,0,0,373,374,3,44,22,0, + 374,375,5,149,0,0,375,378,1,0,0,0,376,378,3,160,80,0,377,371,1,0,0,0, + 377,372,1,0,0,0,377,376,1,0,0,0,378,47,1,0,0,0,379,381,3,50,25,0,380, + 379,1,0,0,0,380,381,1,0,0,0,381,382,1,0,0,0,382,384,5,79,0,0,383,385, + 5,24,0,0,384,383,1,0,0,0,384,385,1,0,0,0,385,387,1,0,0,0,386,388,3,52, + 26,0,387,386,1,0,0,0,387,388,1,0,0,0,388,389,1,0,0,0,389,391,3,114,57, + 0,390,392,3,54,27,0,391,390,1,0,0,0,391,392,1,0,0,0,392,394,1,0,0,0,393, + 395,3,56,28,0,394,393,1,0,0,0,394,395,1,0,0,0,395,397,1,0,0,0,396,398, + 3,60,30,0,397,396,1,0,0,0,397,398,1,0,0,0,398,400,1,0,0,0,399,401,3,62, + 31,0,400,399,1,0,0,0,400,401,1,0,0,0,401,403,1,0,0,0,402,404,3,64,32, + 0,403,402,1,0,0,0,403,404,1,0,0,0,404,407,1,0,0,0,405,406,5,102,0,0,406, + 408,7,0,0,0,407,405,1,0,0,0,407,408,1,0,0,0,408,411,1,0,0,0,409,410,5, + 102,0,0,410,412,5,89,0,0,411,409,1,0,0,0,411,412,1,0,0,0,412,414,1,0, + 0,0,413,415,3,66,33,0,414,413,1,0,0,0,414,415,1,0,0,0,415,417,1,0,0,0, + 416,418,3,58,29,0,417,416,1,0,0,0,417,418,1,0,0,0,418,420,1,0,0,0,419, + 421,3,68,34,0,420,419,1,0,0,0,420,421,1,0,0,0,421,424,1,0,0,0,422,425, + 3,72,36,0,423,425,3,74,37,0,424,422,1,0,0,0,424,423,1,0,0,0,424,425,1, + 0,0,0,425,427,1,0,0,0,426,428,3,76,38,0,427,426,1,0,0,0,427,428,1,0,0, + 0,428,49,1,0,0,0,429,430,5,102,0,0,430,431,3,124,62,0,431,51,1,0,0,0, + 432,433,5,88,0,0,433,436,5,108,0,0,434,435,5,102,0,0,435,437,5,85,0,0, + 436,434,1,0,0,0,436,437,1,0,0,0,437,53,1,0,0,0,438,439,5,34,0,0,439,440, + 3,78,39,0,440,55,1,0,0,0,441,443,7,1,0,0,442,441,1,0,0,0,442,443,1,0, + 0,0,443,444,1,0,0,0,444,445,5,5,0,0,445,446,5,47,0,0,446,447,3,114,57, + 0,447,57,1,0,0,0,448,449,5,101,0,0,449,450,3,156,78,0,450,451,5,6,0,0, + 451,452,5,130,0,0,452,453,3,98,49,0,453,463,5,149,0,0,454,455,5,116,0, + 0,455,456,3,156,78,0,456,457,5,6,0,0,457,458,5,130,0,0,458,459,3,98,49, + 0,459,460,5,149,0,0,460,462,1,0,0,0,461,454,1,0,0,0,462,465,1,0,0,0,463, + 461,1,0,0,0,463,464,1,0,0,0,464,59,1,0,0,0,465,463,1,0,0,0,466,467,5, + 69,0,0,467,468,3,116,58,0,468,61,1,0,0,0,469,470,5,99,0,0,470,471,3,116, + 58,0,471,63,1,0,0,0,472,473,5,36,0,0,473,480,5,11,0,0,474,475,7,0,0,0, + 475,476,5,130,0,0,476,477,3,114,57,0,477,478,5,149,0,0,478,481,1,0,0, + 0,479,481,3,114,57,0,480,474,1,0,0,0,480,479,1,0,0,0,481,65,1,0,0,0,482, + 483,5,37,0,0,483,484,3,116,58,0,484,67,1,0,0,0,485,486,5,64,0,0,486,487, + 5,11,0,0,487,488,3,88,44,0,488,69,1,0,0,0,489,490,5,64,0,0,490,491,5, + 11,0,0,491,492,3,114,57,0,492,71,1,0,0,0,493,494,5,54,0,0,494,497,3,116, + 58,0,495,496,5,116,0,0,496,498,3,116,58,0,497,495,1,0,0,0,497,498,1,0, + 0,0,498,503,1,0,0,0,499,500,5,102,0,0,500,504,5,85,0,0,501,502,5,11,0, + 0,502,504,3,114,57,0,503,499,1,0,0,0,503,501,1,0,0,0,503,504,1,0,0,0, + 504,523,1,0,0,0,505,506,5,54,0,0,506,509,3,116,58,0,507,508,5,102,0,0, + 508,510,5,85,0,0,509,507,1,0,0,0,509,510,1,0,0,0,510,511,1,0,0,0,511, + 512,5,61,0,0,512,513,3,116,58,0,513,523,1,0,0,0,514,515,5,54,0,0,515, + 516,3,116,58,0,516,517,5,61,0,0,517,520,3,116,58,0,518,519,5,11,0,0,519, + 521,3,114,57,0,520,518,1,0,0,0,520,521,1,0,0,0,521,523,1,0,0,0,522,493, + 1,0,0,0,522,505,1,0,0,0,522,514,1,0,0,0,523,73,1,0,0,0,524,525,5,61,0, + 0,525,526,3,116,58,0,526,75,1,0,0,0,527,528,5,81,0,0,528,529,3,94,47, + 0,529,77,1,0,0,0,530,531,6,39,-1,0,531,533,3,132,66,0,532,534,5,28,0, + 0,533,532,1,0,0,0,533,534,1,0,0,0,534,536,1,0,0,0,535,537,3,86,43,0,536, + 535,1,0,0,0,536,537,1,0,0,0,537,543,1,0,0,0,538,539,5,130,0,0,539,540, + 3,78,39,0,540,541,5,149,0,0,541,543,1,0,0,0,542,530,1,0,0,0,542,538,1, + 0,0,0,543,558,1,0,0,0,544,545,10,3,0,0,545,546,3,82,41,0,546,547,3,78, + 39,4,547,557,1,0,0,0,548,550,10,4,0,0,549,551,3,80,40,0,550,549,1,0,0, + 0,550,551,1,0,0,0,551,552,1,0,0,0,552,553,5,47,0,0,553,554,3,78,39,0, + 554,555,3,84,42,0,555,557,1,0,0,0,556,544,1,0,0,0,556,548,1,0,0,0,557, + 560,1,0,0,0,558,556,1,0,0,0,558,559,1,0,0,0,559,79,1,0,0,0,560,558,1, + 0,0,0,561,563,7,2,0,0,562,561,1,0,0,0,562,563,1,0,0,0,563,564,1,0,0,0, + 564,571,5,44,0,0,565,567,5,44,0,0,566,568,7,2,0,0,567,566,1,0,0,0,567, + 568,1,0,0,0,568,571,1,0,0,0,569,571,7,2,0,0,570,562,1,0,0,0,570,565,1, + 0,0,0,570,569,1,0,0,0,571,605,1,0,0,0,572,574,7,3,0,0,573,572,1,0,0,0, + 573,574,1,0,0,0,574,575,1,0,0,0,575,577,7,4,0,0,576,578,5,65,0,0,577, + 576,1,0,0,0,577,578,1,0,0,0,578,587,1,0,0,0,579,581,7,4,0,0,580,582,5, + 65,0,0,581,580,1,0,0,0,581,582,1,0,0,0,582,584,1,0,0,0,583,585,7,3,0, + 0,584,583,1,0,0,0,584,585,1,0,0,0,585,587,1,0,0,0,586,573,1,0,0,0,586, + 579,1,0,0,0,587,605,1,0,0,0,588,590,7,5,0,0,589,588,1,0,0,0,589,590,1, + 0,0,0,590,591,1,0,0,0,591,593,5,35,0,0,592,594,5,65,0,0,593,592,1,0,0, + 0,593,594,1,0,0,0,594,603,1,0,0,0,595,597,5,35,0,0,596,598,5,65,0,0,597, + 596,1,0,0,0,597,598,1,0,0,0,598,600,1,0,0,0,599,601,7,5,0,0,600,599,1, + 0,0,0,600,601,1,0,0,0,601,603,1,0,0,0,602,589,1,0,0,0,602,595,1,0,0,0, + 603,605,1,0,0,0,604,570,1,0,0,0,604,586,1,0,0,0,604,602,1,0,0,0,605,81, + 1,0,0,0,606,607,5,17,0,0,607,610,5,47,0,0,608,610,5,116,0,0,609,606,1, + 0,0,0,609,608,1,0,0,0,610,83,1,0,0,0,611,612,5,62,0,0,612,621,3,114,57, + 0,613,614,5,96,0,0,614,615,5,130,0,0,615,616,3,114,57,0,616,617,5,149, + 0,0,617,621,1,0,0,0,618,619,5,96,0,0,619,621,3,114,57,0,620,611,1,0,0, + 0,620,613,1,0,0,0,620,618,1,0,0,0,621,85,1,0,0,0,622,623,5,77,0,0,623, + 626,3,92,46,0,624,625,5,61,0,0,625,627,3,92,46,0,626,624,1,0,0,0,626, + 627,1,0,0,0,627,87,1,0,0,0,628,633,3,90,45,0,629,630,5,116,0,0,630,632, + 3,90,45,0,631,629,1,0,0,0,632,635,1,0,0,0,633,631,1,0,0,0,633,634,1,0, + 0,0,634,89,1,0,0,0,635,633,1,0,0,0,636,638,3,116,58,0,637,639,7,6,0,0, + 638,637,1,0,0,0,638,639,1,0,0,0,639,642,1,0,0,0,640,641,5,60,0,0,641, + 643,7,7,0,0,642,640,1,0,0,0,642,643,1,0,0,0,643,646,1,0,0,0,644,645,5, + 16,0,0,645,647,5,110,0,0,646,644,1,0,0,0,646,647,1,0,0,0,647,91,1,0,0, + 0,648,655,3,160,80,0,649,652,3,144,72,0,650,651,5,151,0,0,651,653,3,144, + 72,0,652,650,1,0,0,0,652,653,1,0,0,0,653,655,1,0,0,0,654,648,1,0,0,0, + 654,649,1,0,0,0,655,93,1,0,0,0,656,661,3,96,48,0,657,658,5,116,0,0,658, + 660,3,96,48,0,659,657,1,0,0,0,660,663,1,0,0,0,661,659,1,0,0,0,661,662, + 1,0,0,0,662,95,1,0,0,0,663,661,1,0,0,0,664,665,3,156,78,0,665,666,5,122, + 0,0,666,667,3,146,73,0,667,97,1,0,0,0,668,670,3,100,50,0,669,668,1,0, + 0,0,669,670,1,0,0,0,670,672,1,0,0,0,671,673,3,102,51,0,672,671,1,0,0, + 0,672,673,1,0,0,0,673,675,1,0,0,0,674,676,3,104,52,0,675,674,1,0,0,0, + 675,676,1,0,0,0,676,99,1,0,0,0,677,678,5,67,0,0,678,679,5,11,0,0,679, + 680,3,114,57,0,680,101,1,0,0,0,681,682,5,64,0,0,682,683,5,11,0,0,683, + 684,3,88,44,0,684,103,1,0,0,0,685,686,7,8,0,0,686,687,3,106,53,0,687, + 105,1,0,0,0,688,695,3,108,54,0,689,690,5,9,0,0,690,691,3,108,54,0,691, + 692,5,2,0,0,692,693,3,108,54,0,693,695,1,0,0,0,694,688,1,0,0,0,694,689, + 1,0,0,0,695,107,1,0,0,0,696,697,5,19,0,0,697,709,5,75,0,0,698,699,5,94, + 0,0,699,709,5,68,0,0,700,701,5,94,0,0,701,709,5,32,0,0,702,703,3,144, + 72,0,703,704,5,68,0,0,704,709,1,0,0,0,705,706,3,144,72,0,706,707,5,32, + 0,0,707,709,1,0,0,0,708,696,1,0,0,0,708,698,1,0,0,0,708,700,1,0,0,0,708, + 702,1,0,0,0,708,705,1,0,0,0,709,109,1,0,0,0,710,711,3,116,58,0,711,712, + 5,0,0,1,712,111,1,0,0,0,713,770,3,156,78,0,714,715,3,156,78,0,715,716, + 5,130,0,0,716,717,3,156,78,0,717,724,3,112,56,0,718,719,5,116,0,0,719, + 720,3,156,78,0,720,721,3,112,56,0,721,723,1,0,0,0,722,718,1,0,0,0,723, + 726,1,0,0,0,724,722,1,0,0,0,724,725,1,0,0,0,725,728,1,0,0,0,726,724,1, + 0,0,0,727,729,5,116,0,0,728,727,1,0,0,0,728,729,1,0,0,0,729,730,1,0,0, + 0,730,731,5,149,0,0,731,770,1,0,0,0,732,733,3,156,78,0,733,734,5,130, + 0,0,734,739,3,158,79,0,735,736,5,116,0,0,736,738,3,158,79,0,737,735,1, + 0,0,0,738,741,1,0,0,0,739,737,1,0,0,0,739,740,1,0,0,0,740,743,1,0,0,0, + 741,739,1,0,0,0,742,744,5,116,0,0,743,742,1,0,0,0,743,744,1,0,0,0,744, + 745,1,0,0,0,745,746,5,149,0,0,746,770,1,0,0,0,747,748,3,156,78,0,748, + 749,5,130,0,0,749,754,3,112,56,0,750,751,5,116,0,0,751,753,3,112,56,0, + 752,750,1,0,0,0,753,756,1,0,0,0,754,752,1,0,0,0,754,755,1,0,0,0,755,758, + 1,0,0,0,756,754,1,0,0,0,757,759,5,116,0,0,758,757,1,0,0,0,758,759,1,0, + 0,0,759,760,1,0,0,0,760,761,5,149,0,0,761,770,1,0,0,0,762,763,3,156,78, + 0,763,765,5,130,0,0,764,766,3,114,57,0,765,764,1,0,0,0,765,766,1,0,0, + 0,766,767,1,0,0,0,767,768,5,149,0,0,768,770,1,0,0,0,769,713,1,0,0,0,769, + 714,1,0,0,0,769,732,1,0,0,0,769,747,1,0,0,0,769,762,1,0,0,0,770,113,1, + 0,0,0,771,776,3,116,58,0,772,773,5,116,0,0,773,775,3,116,58,0,774,772, + 1,0,0,0,775,778,1,0,0,0,776,774,1,0,0,0,776,777,1,0,0,0,777,780,1,0,0, + 0,778,776,1,0,0,0,779,781,5,116,0,0,780,779,1,0,0,0,780,781,1,0,0,0,781, + 115,1,0,0,0,782,783,6,58,-1,0,783,785,5,12,0,0,784,786,3,116,58,0,785, + 784,1,0,0,0,785,786,1,0,0,0,786,792,1,0,0,0,787,788,5,98,0,0,788,789, + 3,116,58,0,789,790,5,83,0,0,790,791,3,116,58,0,791,793,1,0,0,0,792,787, + 1,0,0,0,793,794,1,0,0,0,794,792,1,0,0,0,794,795,1,0,0,0,795,798,1,0,0, + 0,796,797,5,25,0,0,797,799,3,116,58,0,798,796,1,0,0,0,798,799,1,0,0,0, + 799,800,1,0,0,0,800,801,5,26,0,0,801,933,1,0,0,0,802,803,5,13,0,0,803, + 804,5,130,0,0,804,805,3,116,58,0,805,806,5,6,0,0,806,807,3,112,56,0,807, + 808,5,149,0,0,808,933,1,0,0,0,809,810,5,20,0,0,810,933,5,110,0,0,811, + 812,5,45,0,0,812,813,3,116,58,0,813,814,3,148,74,0,814,933,1,0,0,0,815, + 816,5,82,0,0,816,817,5,130,0,0,817,818,3,116,58,0,818,819,5,34,0,0,819, + 822,3,116,58,0,820,821,5,33,0,0,821,823,3,116,58,0,822,820,1,0,0,0,822, + 823,1,0,0,0,823,824,1,0,0,0,824,825,5,149,0,0,825,933,1,0,0,0,826,827, + 5,86,0,0,827,933,5,110,0,0,828,829,5,91,0,0,829,830,5,130,0,0,830,831, + 7,9,0,0,831,832,3,162,81,0,832,833,5,34,0,0,833,834,3,116,58,0,834,835, + 5,149,0,0,835,933,1,0,0,0,836,837,3,156,78,0,837,839,5,130,0,0,838,840, + 3,114,57,0,839,838,1,0,0,0,839,840,1,0,0,0,840,841,1,0,0,0,841,842,5, + 149,0,0,842,851,1,0,0,0,843,845,5,130,0,0,844,846,5,24,0,0,845,844,1, + 0,0,0,845,846,1,0,0,0,846,848,1,0,0,0,847,849,3,114,57,0,848,847,1,0, + 0,0,848,849,1,0,0,0,849,850,1,0,0,0,850,852,5,149,0,0,851,843,1,0,0,0, + 851,852,1,0,0,0,852,853,1,0,0,0,853,854,5,66,0,0,854,855,5,130,0,0,855, + 856,3,98,49,0,856,857,5,149,0,0,857,933,1,0,0,0,858,859,3,156,78,0,859, + 861,5,130,0,0,860,862,3,114,57,0,861,860,1,0,0,0,861,862,1,0,0,0,862, + 863,1,0,0,0,863,864,5,149,0,0,864,873,1,0,0,0,865,867,5,130,0,0,866,868, + 5,24,0,0,867,866,1,0,0,0,867,868,1,0,0,0,868,870,1,0,0,0,869,871,3,114, + 57,0,870,869,1,0,0,0,870,871,1,0,0,0,871,872,1,0,0,0,872,874,5,149,0, + 0,873,865,1,0,0,0,873,874,1,0,0,0,874,875,1,0,0,0,875,876,5,66,0,0,876, + 877,3,156,78,0,877,933,1,0,0,0,878,884,3,156,78,0,879,881,5,130,0,0,880, + 882,3,114,57,0,881,880,1,0,0,0,881,882,1,0,0,0,882,883,1,0,0,0,883,885, + 5,149,0,0,884,879,1,0,0,0,884,885,1,0,0,0,885,886,1,0,0,0,886,888,5,130, + 0,0,887,889,5,24,0,0,888,887,1,0,0,0,888,889,1,0,0,0,889,891,1,0,0,0, + 890,892,3,114,57,0,891,890,1,0,0,0,891,892,1,0,0,0,892,893,1,0,0,0,893, + 894,5,149,0,0,894,933,1,0,0,0,895,933,3,120,60,0,896,933,3,164,82,0,897, + 933,3,146,73,0,898,899,5,118,0,0,899,933,3,116,58,20,900,901,5,58,0,0, + 901,933,3,116,58,14,902,903,3,136,68,0,903,904,5,120,0,0,904,906,1,0, + 0,0,905,902,1,0,0,0,905,906,1,0,0,0,906,907,1,0,0,0,907,933,5,112,0,0, + 908,909,5,130,0,0,909,910,3,44,22,0,910,911,5,149,0,0,911,933,1,0,0,0, + 912,913,5,130,0,0,913,914,3,116,58,0,914,915,5,149,0,0,915,933,1,0,0, + 0,916,917,5,130,0,0,917,918,3,114,57,0,918,919,5,149,0,0,919,933,1,0, + 0,0,920,922,5,129,0,0,921,923,3,114,57,0,922,921,1,0,0,0,922,923,1,0, + 0,0,923,924,1,0,0,0,924,933,5,148,0,0,925,927,5,128,0,0,926,928,3,40, + 20,0,927,926,1,0,0,0,927,928,1,0,0,0,928,929,1,0,0,0,929,933,5,147,0, + 0,930,933,3,118,59,0,931,933,3,128,64,0,932,782,1,0,0,0,932,802,1,0,0, + 0,932,809,1,0,0,0,932,811,1,0,0,0,932,815,1,0,0,0,932,826,1,0,0,0,932, + 828,1,0,0,0,932,836,1,0,0,0,932,858,1,0,0,0,932,878,1,0,0,0,932,895,1, + 0,0,0,932,896,1,0,0,0,932,897,1,0,0,0,932,898,1,0,0,0,932,900,1,0,0,0, + 932,905,1,0,0,0,932,908,1,0,0,0,932,912,1,0,0,0,932,916,1,0,0,0,932,920, + 1,0,0,0,932,925,1,0,0,0,932,930,1,0,0,0,932,931,1,0,0,0,933,1044,1,0, + 0,0,934,938,10,19,0,0,935,939,5,112,0,0,936,939,5,151,0,0,937,939,5,138, + 0,0,938,935,1,0,0,0,938,936,1,0,0,0,938,937,1,0,0,0,939,940,1,0,0,0,940, + 1043,3,116,58,20,941,945,10,18,0,0,942,946,5,139,0,0,943,946,5,118,0, + 0,944,946,5,117,0,0,945,942,1,0,0,0,945,943,1,0,0,0,945,944,1,0,0,0,946, + 947,1,0,0,0,947,1043,3,116,58,19,948,973,10,17,0,0,949,974,5,121,0,0, + 950,974,5,122,0,0,951,974,5,133,0,0,952,974,5,131,0,0,953,974,5,132,0, + 0,954,974,5,123,0,0,955,974,5,124,0,0,956,958,5,58,0,0,957,956,1,0,0, + 0,957,958,1,0,0,0,958,959,1,0,0,0,959,961,5,42,0,0,960,962,5,15,0,0,961, + 960,1,0,0,0,961,962,1,0,0,0,962,974,1,0,0,0,963,965,5,58,0,0,964,963, + 1,0,0,0,964,965,1,0,0,0,965,966,1,0,0,0,966,974,7,10,0,0,967,974,5,145, + 0,0,968,974,5,146,0,0,969,974,5,135,0,0,970,974,5,126,0,0,971,974,5,127, + 0,0,972,974,5,134,0,0,973,949,1,0,0,0,973,950,1,0,0,0,973,951,1,0,0,0, + 973,952,1,0,0,0,973,953,1,0,0,0,973,954,1,0,0,0,973,955,1,0,0,0,973,957, + 1,0,0,0,973,964,1,0,0,0,973,967,1,0,0,0,973,968,1,0,0,0,973,969,1,0,0, + 0,973,970,1,0,0,0,973,971,1,0,0,0,973,972,1,0,0,0,974,975,1,0,0,0,975, + 1043,3,116,58,18,976,977,10,15,0,0,977,978,5,137,0,0,978,1043,3,116,58, + 16,979,980,10,13,0,0,980,981,5,2,0,0,981,1043,3,116,58,14,982,983,10, + 12,0,0,983,984,5,63,0,0,984,1043,3,116,58,13,985,987,10,11,0,0,986,988, + 5,58,0,0,987,986,1,0,0,0,987,988,1,0,0,0,988,989,1,0,0,0,989,990,5,9, + 0,0,990,991,3,116,58,0,991,992,5,2,0,0,992,993,3,116,58,12,993,1043,1, + 0,0,0,994,995,10,10,0,0,995,996,5,140,0,0,996,997,3,116,58,0,997,998, + 5,115,0,0,998,999,3,116,58,10,999,1043,1,0,0,0,1000,1001,10,30,0,0,1001, + 1003,5,130,0,0,1002,1004,3,114,57,0,1003,1002,1,0,0,0,1003,1004,1,0,0, + 0,1004,1005,1,0,0,0,1005,1043,5,149,0,0,1006,1007,10,26,0,0,1007,1008, + 5,129,0,0,1008,1009,3,116,58,0,1009,1010,5,148,0,0,1010,1043,1,0,0,0, + 1011,1012,10,25,0,0,1012,1013,5,120,0,0,1013,1043,5,108,0,0,1014,1015, + 10,24,0,0,1015,1016,5,120,0,0,1016,1043,3,156,78,0,1017,1018,10,23,0, + 0,1018,1019,5,136,0,0,1019,1020,5,129,0,0,1020,1021,3,116,58,0,1021,1022, + 5,148,0,0,1022,1043,1,0,0,0,1023,1024,10,22,0,0,1024,1025,5,136,0,0,1025, + 1043,5,108,0,0,1026,1027,10,21,0,0,1027,1028,5,136,0,0,1028,1043,3,156, + 78,0,1029,1030,10,16,0,0,1030,1032,5,46,0,0,1031,1033,5,58,0,0,1032,1031, + 1,0,0,0,1032,1033,1,0,0,0,1033,1034,1,0,0,0,1034,1043,5,59,0,0,1035,1040, + 10,9,0,0,1036,1037,5,6,0,0,1037,1041,3,156,78,0,1038,1039,5,6,0,0,1039, + 1041,5,110,0,0,1040,1036,1,0,0,0,1040,1038,1,0,0,0,1041,1043,1,0,0,0, + 1042,934,1,0,0,0,1042,941,1,0,0,0,1042,948,1,0,0,0,1042,976,1,0,0,0,1042, + 979,1,0,0,0,1042,982,1,0,0,0,1042,985,1,0,0,0,1042,994,1,0,0,0,1042,1000, + 1,0,0,0,1042,1006,1,0,0,0,1042,1011,1,0,0,0,1042,1014,1,0,0,0,1042,1017, + 1,0,0,0,1042,1023,1,0,0,0,1042,1026,1,0,0,0,1042,1029,1,0,0,0,1042,1035, + 1,0,0,0,1043,1046,1,0,0,0,1044,1042,1,0,0,0,1044,1045,1,0,0,0,1045,117, + 1,0,0,0,1046,1044,1,0,0,0,1047,1048,5,130,0,0,1048,1053,3,156,78,0,1049, + 1050,5,116,0,0,1050,1052,3,156,78,0,1051,1049,1,0,0,0,1052,1055,1,0,0, + 0,1053,1051,1,0,0,0,1053,1054,1,0,0,0,1054,1057,1,0,0,0,1055,1053,1,0, + 0,0,1056,1058,5,116,0,0,1057,1056,1,0,0,0,1057,1058,1,0,0,0,1058,1059, + 1,0,0,0,1059,1060,5,149,0,0,1060,1075,1,0,0,0,1061,1066,3,156,78,0,1062, + 1063,5,116,0,0,1063,1065,3,156,78,0,1064,1062,1,0,0,0,1065,1068,1,0,0, + 0,1066,1064,1,0,0,0,1066,1067,1,0,0,0,1067,1070,1,0,0,0,1068,1066,1,0, + 0,0,1069,1071,5,116,0,0,1070,1069,1,0,0,0,1070,1071,1,0,0,0,1071,1075, + 1,0,0,0,1072,1073,5,130,0,0,1073,1075,5,149,0,0,1074,1047,1,0,0,0,1074, + 1061,1,0,0,0,1074,1072,1,0,0,0,1075,1076,1,0,0,0,1076,1079,5,111,0,0, + 1077,1080,3,116,58,0,1078,1080,3,36,18,0,1079,1077,1,0,0,0,1079,1078, + 1,0,0,0,1080,119,1,0,0,0,1081,1082,5,132,0,0,1082,1086,3,156,78,0,1083, + 1085,3,122,61,0,1084,1083,1,0,0,0,1085,1088,1,0,0,0,1086,1084,1,0,0,0, + 1086,1087,1,0,0,0,1087,1089,1,0,0,0,1088,1086,1,0,0,0,1089,1090,5,151, + 0,0,1090,1091,5,124,0,0,1091,1114,1,0,0,0,1092,1093,5,132,0,0,1093,1097, + 3,156,78,0,1094,1096,3,122,61,0,1095,1094,1,0,0,0,1096,1099,1,0,0,0,1097, + 1095,1,0,0,0,1097,1098,1,0,0,0,1098,1100,1,0,0,0,1099,1097,1,0,0,0,1100, + 1106,5,124,0,0,1101,1107,3,120,60,0,1102,1103,5,128,0,0,1103,1104,3,116, + 58,0,1104,1105,5,147,0,0,1105,1107,1,0,0,0,1106,1101,1,0,0,0,1106,1102, + 1,0,0,0,1106,1107,1,0,0,0,1107,1108,1,0,0,0,1108,1109,5,132,0,0,1109, + 1110,5,151,0,0,1110,1111,3,156,78,0,1111,1112,5,124,0,0,1112,1114,1,0, + 0,0,1113,1081,1,0,0,0,1113,1092,1,0,0,0,1114,121,1,0,0,0,1115,1116,3, + 156,78,0,1116,1117,5,122,0,0,1117,1118,3,162,81,0,1118,1127,1,0,0,0,1119, + 1120,3,156,78,0,1120,1121,5,122,0,0,1121,1122,5,128,0,0,1122,1123,3,116, + 58,0,1123,1124,5,147,0,0,1124,1127,1,0,0,0,1125,1127,3,156,78,0,1126, + 1115,1,0,0,0,1126,1119,1,0,0,0,1126,1125,1,0,0,0,1127,123,1,0,0,0,1128, + 1133,3,126,63,0,1129,1130,5,116,0,0,1130,1132,3,126,63,0,1131,1129,1, + 0,0,0,1132,1135,1,0,0,0,1133,1131,1,0,0,0,1133,1134,1,0,0,0,1134,1137, + 1,0,0,0,1135,1133,1,0,0,0,1136,1138,5,116,0,0,1137,1136,1,0,0,0,1137, + 1138,1,0,0,0,1138,125,1,0,0,0,1139,1140,3,156,78,0,1140,1141,5,6,0,0, + 1141,1142,5,130,0,0,1142,1143,3,44,22,0,1143,1144,5,149,0,0,1144,1150, + 1,0,0,0,1145,1146,3,116,58,0,1146,1147,5,6,0,0,1147,1148,3,156,78,0,1148, + 1150,1,0,0,0,1149,1139,1,0,0,0,1149,1145,1,0,0,0,1150,127,1,0,0,0,1151, + 1159,3,160,80,0,1152,1153,3,136,68,0,1153,1154,5,120,0,0,1154,1156,1, + 0,0,0,1155,1152,1,0,0,0,1155,1156,1,0,0,0,1156,1157,1,0,0,0,1157,1159, + 3,130,65,0,1158,1151,1,0,0,0,1158,1155,1,0,0,0,1159,129,1,0,0,0,1160, + 1165,3,156,78,0,1161,1162,5,120,0,0,1162,1164,3,156,78,0,1163,1161,1, + 0,0,0,1164,1167,1,0,0,0,1165,1163,1,0,0,0,1165,1166,1,0,0,0,1166,131, + 1,0,0,0,1167,1165,1,0,0,0,1168,1169,6,66,-1,0,1169,1178,3,136,68,0,1170, + 1178,3,134,67,0,1171,1172,5,130,0,0,1172,1173,3,44,22,0,1173,1174,5,149, + 0,0,1174,1178,1,0,0,0,1175,1178,3,120,60,0,1176,1178,3,160,80,0,1177, + 1168,1,0,0,0,1177,1170,1,0,0,0,1177,1171,1,0,0,0,1177,1175,1,0,0,0,1177, + 1176,1,0,0,0,1178,1187,1,0,0,0,1179,1183,10,3,0,0,1180,1184,3,154,77, + 0,1181,1182,5,6,0,0,1182,1184,3,156,78,0,1183,1180,1,0,0,0,1183,1181, + 1,0,0,0,1184,1186,1,0,0,0,1185,1179,1,0,0,0,1186,1189,1,0,0,0,1187,1185, + 1,0,0,0,1187,1188,1,0,0,0,1188,133,1,0,0,0,1189,1187,1,0,0,0,1190,1191, + 3,156,78,0,1191,1193,5,130,0,0,1192,1194,3,138,69,0,1193,1192,1,0,0,0, + 1193,1194,1,0,0,0,1194,1195,1,0,0,0,1195,1196,5,149,0,0,1196,135,1,0, + 0,0,1197,1198,3,140,70,0,1198,1199,5,120,0,0,1199,1201,1,0,0,0,1200,1197, + 1,0,0,0,1200,1201,1,0,0,0,1201,1202,1,0,0,0,1202,1203,3,156,78,0,1203, + 137,1,0,0,0,1204,1209,3,116,58,0,1205,1206,5,116,0,0,1206,1208,3,116, + 58,0,1207,1205,1,0,0,0,1208,1211,1,0,0,0,1209,1207,1,0,0,0,1209,1210, + 1,0,0,0,1210,1213,1,0,0,0,1211,1209,1,0,0,0,1212,1214,5,116,0,0,1213, + 1212,1,0,0,0,1213,1214,1,0,0,0,1214,139,1,0,0,0,1215,1216,3,156,78,0, + 1216,141,1,0,0,0,1217,1226,5,106,0,0,1218,1219,5,120,0,0,1219,1226,7, + 11,0,0,1220,1221,5,108,0,0,1221,1223,5,120,0,0,1222,1224,7,11,0,0,1223, + 1222,1,0,0,0,1223,1224,1,0,0,0,1224,1226,1,0,0,0,1225,1217,1,0,0,0,1225, + 1218,1,0,0,0,1225,1220,1,0,0,0,1226,143,1,0,0,0,1227,1229,7,12,0,0,1228, + 1227,1,0,0,0,1228,1229,1,0,0,0,1229,1236,1,0,0,0,1230,1237,3,142,71,0, + 1231,1237,5,107,0,0,1232,1237,5,108,0,0,1233,1237,5,109,0,0,1234,1237, + 5,43,0,0,1235,1237,5,57,0,0,1236,1230,1,0,0,0,1236,1231,1,0,0,0,1236, + 1232,1,0,0,0,1236,1233,1,0,0,0,1236,1234,1,0,0,0,1236,1235,1,0,0,0,1237, + 145,1,0,0,0,1238,1242,3,144,72,0,1239,1242,5,110,0,0,1240,1242,5,59,0, + 0,1241,1238,1,0,0,0,1241,1239,1,0,0,0,1241,1240,1,0,0,0,1242,147,1,0, + 0,0,1243,1244,7,13,0,0,1244,149,1,0,0,0,1245,1246,7,14,0,0,1246,151,1, + 0,0,0,1247,1248,7,15,0,0,1248,153,1,0,0,0,1249,1252,5,105,0,0,1250,1252, + 3,152,76,0,1251,1249,1,0,0,0,1251,1250,1,0,0,0,1252,155,1,0,0,0,1253, + 1257,5,105,0,0,1254,1257,3,148,74,0,1255,1257,3,150,75,0,1256,1253,1, + 0,0,0,1256,1254,1,0,0,0,1256,1255,1,0,0,0,1257,157,1,0,0,0,1258,1259, + 3,162,81,0,1259,1260,5,122,0,0,1260,1261,3,144,72,0,1261,159,1,0,0,0, + 1262,1263,5,128,0,0,1263,1264,3,130,65,0,1264,1265,5,147,0,0,1265,161, + 1,0,0,0,1266,1269,5,110,0,0,1267,1269,3,164,82,0,1268,1266,1,0,0,0,1268, + 1267,1,0,0,0,1269,163,1,0,0,0,1270,1274,5,142,0,0,1271,1273,3,166,83, + 0,1272,1271,1,0,0,0,1273,1276,1,0,0,0,1274,1272,1,0,0,0,1274,1275,1,0, + 0,0,1275,1277,1,0,0,0,1276,1274,1,0,0,0,1277,1278,5,144,0,0,1278,165, + 1,0,0,0,1279,1280,5,157,0,0,1280,1281,3,116,58,0,1281,1282,5,147,0,0, + 1282,1285,1,0,0,0,1283,1285,5,156,0,0,1284,1279,1,0,0,0,1284,1283,1,0, + 0,0,1285,167,1,0,0,0,1286,1290,5,143,0,0,1287,1289,3,170,85,0,1288,1287, + 1,0,0,0,1289,1292,1,0,0,0,1290,1288,1,0,0,0,1290,1291,1,0,0,0,1291,1293, + 1,0,0,0,1292,1290,1,0,0,0,1293,1294,5,0,0,1,1294,169,1,0,0,0,1295,1296, + 5,159,0,0,1296,1297,3,116,58,0,1297,1298,5,147,0,0,1298,1301,1,0,0,0, + 1299,1301,5,158,0,0,1300,1295,1,0,0,0,1300,1299,1,0,0,0,1301,171,1,0, + 0,0,167,175,182,191,198,202,216,220,223,227,230,237,241,250,255,264,272, + 279,283,289,294,302,309,315,327,335,349,353,358,368,377,380,384,387,391, + 394,397,400,403,407,411,414,417,420,424,427,436,442,463,480,497,503,509, + 520,522,533,536,542,550,556,558,562,567,570,573,577,581,584,586,589,593, + 597,600,602,604,609,620,626,633,638,642,646,652,654,661,669,672,675,694, + 708,724,728,739,743,754,758,765,769,776,780,785,794,798,822,839,845,848, + 851,861,867,870,873,881,884,888,891,905,922,927,932,938,945,957,961,964, + 973,987,1003,1032,1040,1042,1044,1053,1057,1066,1070,1074,1079,1086,1097, + 1106,1113,1126,1133,1137,1149,1155,1158,1165,1177,1183,1187,1193,1200, + 1209,1213,1223,1225,1228,1236,1241,1251,1256,1268,1274,1284,1290,1300 }; staticData->serializedATN = antlr4::atn::SerializedATNView(serializedATNSegment, sizeof(serializedATNSegment) / sizeof(serializedATNSegment[0])); @@ -615,7 +611,7 @@ void hogqlparserParserInitialize() { for (size_t i = 0; i < count; i++) { staticData->decisionToDFA.emplace_back(staticData->atn->getDecisionState(i), i); } - hogqlparserParserStaticData = staticData.release(); + hogqlparserParserStaticData = std::move(staticData); } } @@ -697,20 +693,20 @@ HogQLParser::ProgramContext* HogQLParser::program() { }); try { enterOuterAlt(_localctx, 1); - setState(179); + setState(175); _errHandler->sync(this); _la = _input->LA(1); while ((((_la & ~ 0x3fULL) == 0) && ((1ULL << _la) & -536887298) != 0) || ((((_la - 64) & ~ 0x3fULL) == 0) && ((1ULL << (_la - 64)) & 90493105500848127) != 0) || ((((_la - 128) & ~ 0x3fULL) == 0) && ((1ULL << (_la - 128)) & 4212759) != 0)) { - setState(176); + setState(172); declaration(); - setState(181); + setState(177); _errHandler->sync(this); _la = _input->LA(1); } - setState(182); + setState(178); match(HogQLParser::EOF); } @@ -762,12 +758,12 @@ HogQLParser::DeclarationContext* HogQLParser::declaration() { exitRule(); }); try { - setState(186); + setState(182); _errHandler->sync(this); switch (_input->LA(1)) { case HogQLParser::LET: { enterOuterAlt(_localctx, 1); - setState(184); + setState(180); varDecl(); break; } @@ -889,7 +885,7 @@ HogQLParser::DeclarationContext* HogQLParser::declaration() { case HogQLParser::QUOTE_SINGLE_TEMPLATE: case HogQLParser::SEMICOLON: { enterOuterAlt(_localctx, 2); - setState(185); + setState(181); statement(); break; } @@ -944,7 +940,7 @@ HogQLParser::ExpressionContext* HogQLParser::expression() { }); try { enterOuterAlt(_localctx, 1); - setState(188); + setState(184); columnExpr(0); } @@ -1010,20 +1006,20 @@ HogQLParser::VarDeclContext* HogQLParser::varDecl() { }); try { enterOuterAlt(_localctx, 1); - setState(190); + setState(186); match(HogQLParser::LET); - setState(191); + setState(187); identifier(); - setState(195); + setState(191); _errHandler->sync(this); _la = _input->LA(1); if (_la == HogQLParser::COLON) { - setState(192); + setState(188); match(HogQLParser::COLON); - setState(193); + setState(189); match(HogQLParser::EQ_SINGLE); - setState(194); + setState(190); expression(); } @@ -1087,28 +1083,28 @@ HogQLParser::IdentifierListContext* HogQLParser::identifierList() { try { size_t alt; enterOuterAlt(_localctx, 1); - setState(197); + setState(193); identifier(); - setState(202); + setState(198); _errHandler->sync(this); alt = getInterpreter()->adaptivePredict(_input, 3, _ctx); while (alt != 2 && alt != atn::ATN::INVALID_ALT_NUMBER) { if (alt == 1) { - setState(198); + setState(194); match(HogQLParser::COMMA); - setState(199); + setState(195); identifier(); } - setState(204); + setState(200); _errHandler->sync(this); alt = getInterpreter()->adaptivePredict(_input, 3, _ctx); } - setState(206); + setState(202); _errHandler->sync(this); _la = _input->LA(1); if (_la == HogQLParser::COMMA) { - setState(205); + setState(201); match(HogQLParser::COMMA); } @@ -1201,89 +1197,89 @@ HogQLParser::StatementContext* HogQLParser::statement() { exitRule(); }); try { - setState(220); + setState(216); _errHandler->sync(this); switch (getInterpreter()->adaptivePredict(_input, 5, _ctx)) { case 1: { enterOuterAlt(_localctx, 1); - setState(208); + setState(204); returnStmt(); break; } case 2: { enterOuterAlt(_localctx, 2); - setState(209); + setState(205); throwStmt(); break; } case 3: { enterOuterAlt(_localctx, 3); - setState(210); + setState(206); tryCatchStmt(); break; } case 4: { enterOuterAlt(_localctx, 4); - setState(211); + setState(207); ifStmt(); break; } case 5: { enterOuterAlt(_localctx, 5); - setState(212); + setState(208); whileStmt(); break; } case 6: { enterOuterAlt(_localctx, 6); - setState(213); + setState(209); forInStmt(); break; } case 7: { enterOuterAlt(_localctx, 7); - setState(214); + setState(210); forStmt(); break; } case 8: { enterOuterAlt(_localctx, 8); - setState(215); + setState(211); funcStmt(); break; } case 9: { enterOuterAlt(_localctx, 9); - setState(216); + setState(212); varAssignment(); break; } case 10: { enterOuterAlt(_localctx, 10); - setState(217); + setState(213); block(); break; } case 11: { enterOuterAlt(_localctx, 11); - setState(218); + setState(214); exprStmt(); break; } case 12: { enterOuterAlt(_localctx, 12); - setState(219); + setState(215); emptyStmt(); break; } @@ -1346,14 +1342,14 @@ HogQLParser::ReturnStmtContext* HogQLParser::returnStmt() { }); try { enterOuterAlt(_localctx, 1); - setState(222); + setState(218); match(HogQLParser::RETURN); - setState(224); + setState(220); _errHandler->sync(this); switch (getInterpreter()->adaptivePredict(_input, 6, _ctx)) { case 1: { - setState(223); + setState(219); expression(); break; } @@ -1361,12 +1357,12 @@ HogQLParser::ReturnStmtContext* HogQLParser::returnStmt() { default: break; } - setState(227); + setState(223); _errHandler->sync(this); switch (getInterpreter()->adaptivePredict(_input, 7, _ctx)) { case 1: { - setState(226); + setState(222); match(HogQLParser::SEMICOLON); break; } @@ -1429,14 +1425,14 @@ HogQLParser::ThrowStmtContext* HogQLParser::throwStmt() { }); try { enterOuterAlt(_localctx, 1); - setState(229); + setState(225); match(HogQLParser::THROW); - setState(231); + setState(227); _errHandler->sync(this); switch (getInterpreter()->adaptivePredict(_input, 8, _ctx)) { case 1: { - setState(230); + setState(226); expression(); break; } @@ -1444,12 +1440,12 @@ HogQLParser::ThrowStmtContext* HogQLParser::throwStmt() { default: break; } - setState(234); + setState(230); _errHandler->sync(this); switch (getInterpreter()->adaptivePredict(_input, 9, _ctx)) { case 1: { - setState(233); + setState(229); match(HogQLParser::SEMICOLON); break; } @@ -1529,31 +1525,31 @@ HogQLParser::CatchBlockContext* HogQLParser::catchBlock() { }); try { enterOuterAlt(_localctx, 1); - setState(236); + setState(232); match(HogQLParser::CATCH); - setState(245); + setState(241); _errHandler->sync(this); _la = _input->LA(1); if (_la == HogQLParser::LPAREN) { - setState(237); + setState(233); match(HogQLParser::LPAREN); - setState(238); + setState(234); antlrcpp::downCast(_localctx)->catchVar = identifier(); - setState(241); + setState(237); _errHandler->sync(this); _la = _input->LA(1); if (_la == HogQLParser::COLON) { - setState(239); + setState(235); match(HogQLParser::COLON); - setState(240); + setState(236); antlrcpp::downCast(_localctx)->catchType = identifier(); } - setState(243); + setState(239); match(HogQLParser::RPAREN); } - setState(247); + setState(243); antlrcpp::downCast(_localctx)->catchStmt = block(); } @@ -1623,28 +1619,28 @@ HogQLParser::TryCatchStmtContext* HogQLParser::tryCatchStmt() { }); try { enterOuterAlt(_localctx, 1); - setState(249); + setState(245); match(HogQLParser::TRY); - setState(250); + setState(246); antlrcpp::downCast(_localctx)->tryStmt = block(); - setState(254); + setState(250); _errHandler->sync(this); _la = _input->LA(1); while (_la == HogQLParser::CATCH) { - setState(251); + setState(247); catchBlock(); - setState(256); + setState(252); _errHandler->sync(this); _la = _input->LA(1); } - setState(259); + setState(255); _errHandler->sync(this); _la = _input->LA(1); if (_la == HogQLParser::FINALLY) { - setState(257); + setState(253); match(HogQLParser::FINALLY); - setState(258); + setState(254); antlrcpp::downCast(_localctx)->finallyStmt = block(); } @@ -1718,24 +1714,24 @@ HogQLParser::IfStmtContext* HogQLParser::ifStmt() { }); try { enterOuterAlt(_localctx, 1); - setState(261); + setState(257); match(HogQLParser::IF); - setState(262); + setState(258); match(HogQLParser::LPAREN); - setState(263); + setState(259); expression(); - setState(264); + setState(260); match(HogQLParser::RPAREN); - setState(265); + setState(261); statement(); - setState(268); + setState(264); _errHandler->sync(this); switch (getInterpreter()->adaptivePredict(_input, 14, _ctx)) { case 1: { - setState(266); + setState(262); match(HogQLParser::ELSE); - setState(267); + setState(263); statement(); break; } @@ -1810,22 +1806,22 @@ HogQLParser::WhileStmtContext* HogQLParser::whileStmt() { }); try { enterOuterAlt(_localctx, 1); - setState(270); + setState(266); match(HogQLParser::WHILE); - setState(271); + setState(267); match(HogQLParser::LPAREN); - setState(272); + setState(268); expression(); - setState(273); + setState(269); match(HogQLParser::RPAREN); - setState(274); + setState(270); statement(); - setState(276); + setState(272); _errHandler->sync(this); switch (getInterpreter()->adaptivePredict(_input, 15, _ctx)) { case 1: { - setState(275); + setState(271); match(HogQLParser::SEMICOLON); break; } @@ -1925,28 +1921,28 @@ HogQLParser::ForStmtContext* HogQLParser::forStmt() { }); try { enterOuterAlt(_localctx, 1); - setState(278); + setState(274); match(HogQLParser::FOR); - setState(279); + setState(275); match(HogQLParser::LPAREN); - setState(283); + setState(279); _errHandler->sync(this); switch (getInterpreter()->adaptivePredict(_input, 16, _ctx)) { case 1: { - setState(280); + setState(276); antlrcpp::downCast(_localctx)->initializerVarDeclr = varDecl(); break; } case 2: { - setState(281); + setState(277); antlrcpp::downCast(_localctx)->initializerVarAssignment = varAssignment(); break; } case 3: { - setState(282); + setState(278); antlrcpp::downCast(_localctx)->initializerExpression = expression(); break; } @@ -1954,9 +1950,9 @@ HogQLParser::ForStmtContext* HogQLParser::forStmt() { default: break; } - setState(285); + setState(281); match(HogQLParser::SEMICOLON); - setState(287); + setState(283); _errHandler->sync(this); _la = _input->LA(1); @@ -1964,29 +1960,29 @@ HogQLParser::ForStmtContext* HogQLParser::forStmt() { ((1ULL << _la) & -4503602311741442) != 0) || ((((_la - 64) & ~ 0x3fULL) == 0) && ((1ULL << (_la - 64)) & 90493036243451903) != 0) || ((((_la - 128) & ~ 0x3fULL) == 0) && ((1ULL << (_la - 128)) & 18455) != 0)) { - setState(286); + setState(282); antlrcpp::downCast(_localctx)->condition = expression(); } - setState(289); + setState(285); match(HogQLParser::SEMICOLON); - setState(293); + setState(289); _errHandler->sync(this); switch (getInterpreter()->adaptivePredict(_input, 18, _ctx)) { case 1: { - setState(290); + setState(286); antlrcpp::downCast(_localctx)->incrementVarDeclr = varDecl(); break; } case 2: { - setState(291); + setState(287); antlrcpp::downCast(_localctx)->incrementVarAssignment = varAssignment(); break; } case 3: { - setState(292); + setState(288); antlrcpp::downCast(_localctx)->incrementExpression = expression(); break; } @@ -1994,16 +1990,16 @@ HogQLParser::ForStmtContext* HogQLParser::forStmt() { default: break; } - setState(295); + setState(291); match(HogQLParser::RPAREN); - setState(296); + setState(292); statement(); - setState(298); + setState(294); _errHandler->sync(this); switch (getInterpreter()->adaptivePredict(_input, 19, _ctx)) { case 1: { - setState(297); + setState(293); match(HogQLParser::SEMICOLON); break; } @@ -2099,38 +2095,38 @@ HogQLParser::ForInStmtContext* HogQLParser::forInStmt() { }); try { enterOuterAlt(_localctx, 1); - setState(300); + setState(296); match(HogQLParser::FOR); - setState(301); + setState(297); match(HogQLParser::LPAREN); - setState(302); + setState(298); match(HogQLParser::LET); - setState(303); + setState(299); identifier(); - setState(306); + setState(302); _errHandler->sync(this); _la = _input->LA(1); if (_la == HogQLParser::COMMA) { - setState(304); + setState(300); match(HogQLParser::COMMA); - setState(305); + setState(301); identifier(); } - setState(308); + setState(304); match(HogQLParser::IN); - setState(309); + setState(305); expression(); - setState(310); + setState(306); match(HogQLParser::RPAREN); - setState(311); + setState(307); statement(); - setState(313); + setState(309); _errHandler->sync(this); switch (getInterpreter()->adaptivePredict(_input, 21, _ctx)) { case 1: { - setState(312); + setState(308); match(HogQLParser::SEMICOLON); break; } @@ -2206,25 +2202,25 @@ HogQLParser::FuncStmtContext* HogQLParser::funcStmt() { }); try { enterOuterAlt(_localctx, 1); - setState(315); + setState(311); match(HogQLParser::FN); - setState(316); + setState(312); identifier(); - setState(317); + setState(313); match(HogQLParser::LPAREN); - setState(319); + setState(315); _errHandler->sync(this); _la = _input->LA(1); if ((((_la & ~ 0x3fULL) == 0) && ((1ULL << _la) & -725088338784043010) != 0) || ((((_la - 64) & ~ 0x3fULL) == 0) && ((1ULL << (_la - 64)) & 3229277487103) != 0)) { - setState(318); + setState(314); identifierList(); } - setState(321); + setState(317); match(HogQLParser::RPAREN); - setState(322); + setState(318); block(); } @@ -2285,13 +2281,13 @@ HogQLParser::VarAssignmentContext* HogQLParser::varAssignment() { }); try { enterOuterAlt(_localctx, 1); - setState(324); + setState(320); expression(); - setState(325); + setState(321); match(HogQLParser::COLON); - setState(326); + setState(322); match(HogQLParser::EQ_SINGLE); - setState(327); + setState(323); expression(); } @@ -2344,14 +2340,14 @@ HogQLParser::ExprStmtContext* HogQLParser::exprStmt() { }); try { enterOuterAlt(_localctx, 1); - setState(329); + setState(325); expression(); - setState(331); + setState(327); _errHandler->sync(this); switch (getInterpreter()->adaptivePredict(_input, 23, _ctx)) { case 1: { - setState(330); + setState(326); match(HogQLParser::SEMICOLON); break; } @@ -2406,7 +2402,7 @@ HogQLParser::EmptyStmtContext* HogQLParser::emptyStmt() { }); try { enterOuterAlt(_localctx, 1); - setState(333); + setState(329); match(HogQLParser::SEMICOLON); } @@ -2468,22 +2464,22 @@ HogQLParser::BlockContext* HogQLParser::block() { }); try { enterOuterAlt(_localctx, 1); - setState(335); + setState(331); match(HogQLParser::LBRACE); - setState(339); + setState(335); _errHandler->sync(this); _la = _input->LA(1); while ((((_la & ~ 0x3fULL) == 0) && ((1ULL << _la) & -536887298) != 0) || ((((_la - 64) & ~ 0x3fULL) == 0) && ((1ULL << (_la - 64)) & 90493105500848127) != 0) || ((((_la - 128) & ~ 0x3fULL) == 0) && ((1ULL << (_la - 128)) & 4212759) != 0)) { - setState(336); + setState(332); declaration(); - setState(341); + setState(337); _errHandler->sync(this); _la = _input->LA(1); } - setState(342); + setState(338); match(HogQLParser::RBRACE); } @@ -2540,11 +2536,11 @@ HogQLParser::KvPairContext* HogQLParser::kvPair() { }); try { enterOuterAlt(_localctx, 1); - setState(344); + setState(340); expression(); - setState(345); + setState(341); match(HogQLParser::COLON); - setState(346); + setState(342); expression(); } @@ -2607,28 +2603,28 @@ HogQLParser::KvPairListContext* HogQLParser::kvPairList() { try { size_t alt; enterOuterAlt(_localctx, 1); - setState(348); + setState(344); kvPair(); - setState(353); + setState(349); _errHandler->sync(this); alt = getInterpreter()->adaptivePredict(_input, 25, _ctx); while (alt != 2 && alt != atn::ATN::INVALID_ALT_NUMBER) { if (alt == 1) { - setState(349); + setState(345); match(HogQLParser::COMMA); - setState(350); + setState(346); kvPair(); } - setState(355); + setState(351); _errHandler->sync(this); alt = getInterpreter()->adaptivePredict(_input, 25, _ctx); } - setState(357); + setState(353); _errHandler->sync(this); _la = _input->LA(1); if (_la == HogQLParser::COMMA) { - setState(356); + setState(352); match(HogQLParser::COMMA); } @@ -2690,23 +2686,23 @@ HogQLParser::SelectContext* HogQLParser::select() { }); try { enterOuterAlt(_localctx, 1); - setState(362); + setState(358); _errHandler->sync(this); switch (getInterpreter()->adaptivePredict(_input, 27, _ctx)) { case 1: { - setState(359); + setState(355); selectUnionStmt(); break; } case 2: { - setState(360); + setState(356); selectStmt(); break; } case 3: { - setState(361); + setState(357); hogqlxTagElement(); break; } @@ -2714,7 +2710,7 @@ HogQLParser::SelectContext* HogQLParser::select() { default: break; } - setState(364); + setState(360); match(HogQLParser::EOF); } @@ -2784,19 +2780,19 @@ HogQLParser::SelectUnionStmtContext* HogQLParser::selectUnionStmt() { }); try { enterOuterAlt(_localctx, 1); - setState(366); + setState(362); selectStmtWithParens(); - setState(372); + setState(368); _errHandler->sync(this); _la = _input->LA(1); while (_la == HogQLParser::UNION) { - setState(367); + setState(363); match(HogQLParser::UNION); - setState(368); + setState(364); match(HogQLParser::ALL); - setState(369); + setState(365); selectStmtWithParens(); - setState(374); + setState(370); _errHandler->sync(this); _la = _input->LA(1); } @@ -2862,31 +2858,31 @@ HogQLParser::SelectStmtWithParensContext* HogQLParser::selectStmtWithParens() { exitRule(); }); try { - setState(381); + setState(377); _errHandler->sync(this); switch (_input->LA(1)) { case HogQLParser::SELECT: case HogQLParser::WITH: { enterOuterAlt(_localctx, 1); - setState(375); + setState(371); selectStmt(); break; } case HogQLParser::LPAREN: { enterOuterAlt(_localctx, 2); - setState(376); + setState(372); match(HogQLParser::LPAREN); - setState(377); + setState(373); selectUnionStmt(); - setState(378); + setState(374); match(HogQLParser::RPAREN); break; } case HogQLParser::LBRACE: { enterOuterAlt(_localctx, 3); - setState(380); + setState(376); placeholder(); break; } @@ -3022,22 +3018,22 @@ HogQLParser::SelectStmtContext* HogQLParser::selectStmt() { }); try { enterOuterAlt(_localctx, 1); - setState(384); + setState(380); _errHandler->sync(this); _la = _input->LA(1); if (_la == HogQLParser::WITH) { - setState(383); + setState(379); antlrcpp::downCast(_localctx)->with = withClause(); } - setState(386); + setState(382); match(HogQLParser::SELECT); - setState(388); + setState(384); _errHandler->sync(this); switch (getInterpreter()->adaptivePredict(_input, 31, _ctx)) { case 1: { - setState(387); + setState(383); match(HogQLParser::DISTINCT); break; } @@ -3045,12 +3041,12 @@ HogQLParser::SelectStmtContext* HogQLParser::selectStmt() { default: break; } - setState(391); + setState(387); _errHandler->sync(this); switch (getInterpreter()->adaptivePredict(_input, 32, _ctx)) { case 1: { - setState(390); + setState(386); topClause(); break; } @@ -3058,57 +3054,57 @@ HogQLParser::SelectStmtContext* HogQLParser::selectStmt() { default: break; } - setState(393); + setState(389); antlrcpp::downCast(_localctx)->columns = columnExprList(); - setState(395); + setState(391); _errHandler->sync(this); _la = _input->LA(1); if (_la == HogQLParser::FROM) { - setState(394); + setState(390); antlrcpp::downCast(_localctx)->from = fromClause(); } - setState(398); + setState(394); _errHandler->sync(this); _la = _input->LA(1); if ((((_la & ~ 0x3fULL) == 0) && ((1ULL << _la) & 2269391999729696) != 0)) { - setState(397); + setState(393); arrayJoinClause(); } - setState(401); + setState(397); _errHandler->sync(this); _la = _input->LA(1); if (_la == HogQLParser::PREWHERE) { - setState(400); + setState(396); prewhereClause(); } - setState(404); + setState(400); _errHandler->sync(this); _la = _input->LA(1); if (_la == HogQLParser::WHERE) { - setState(403); + setState(399); antlrcpp::downCast(_localctx)->where = whereClause(); } - setState(407); + setState(403); _errHandler->sync(this); _la = _input->LA(1); if (_la == HogQLParser::GROUP) { - setState(406); + setState(402); groupByClause(); } - setState(411); + setState(407); _errHandler->sync(this); switch (getInterpreter()->adaptivePredict(_input, 38, _ctx)) { case 1: { - setState(409); + setState(405); match(HogQLParser::WITH); - setState(410); + setState(406); _la = _input->LA(1); if (!(_la == HogQLParser::CUBE @@ -3125,51 +3121,51 @@ HogQLParser::SelectStmtContext* HogQLParser::selectStmt() { default: break; } - setState(415); + setState(411); _errHandler->sync(this); _la = _input->LA(1); if (_la == HogQLParser::WITH) { - setState(413); + setState(409); match(HogQLParser::WITH); - setState(414); + setState(410); match(HogQLParser::TOTALS); } - setState(418); + setState(414); _errHandler->sync(this); _la = _input->LA(1); if (_la == HogQLParser::HAVING) { - setState(417); + setState(413); havingClause(); } - setState(421); + setState(417); _errHandler->sync(this); _la = _input->LA(1); if (_la == HogQLParser::WINDOW) { - setState(420); + setState(416); windowClause(); } - setState(424); + setState(420); _errHandler->sync(this); _la = _input->LA(1); if (_la == HogQLParser::ORDER) { - setState(423); + setState(419); orderByClause(); } - setState(428); + setState(424); _errHandler->sync(this); switch (_input->LA(1)) { case HogQLParser::LIMIT: { - setState(426); + setState(422); limitAndOffsetClause(); break; } case HogQLParser::OFFSET: { - setState(427); + setState(423); offsetOnlyClause(); break; } @@ -3184,12 +3180,12 @@ HogQLParser::SelectStmtContext* HogQLParser::selectStmt() { default: break; } - setState(431); + setState(427); _errHandler->sync(this); _la = _input->LA(1); if (_la == HogQLParser::SETTINGS) { - setState(430); + setState(426); settingsClause(); } @@ -3243,9 +3239,9 @@ HogQLParser::WithClauseContext* HogQLParser::withClause() { }); try { enterOuterAlt(_localctx, 1); - setState(433); + setState(429); match(HogQLParser::WITH); - setState(434); + setState(430); withExprList(); } @@ -3306,18 +3302,18 @@ HogQLParser::TopClauseContext* HogQLParser::topClause() { }); try { enterOuterAlt(_localctx, 1); - setState(436); + setState(432); match(HogQLParser::TOP); - setState(437); + setState(433); match(HogQLParser::DECIMAL_LITERAL); - setState(440); + setState(436); _errHandler->sync(this); switch (getInterpreter()->adaptivePredict(_input, 45, _ctx)) { case 1: { - setState(438); + setState(434); match(HogQLParser::WITH); - setState(439); + setState(435); match(HogQLParser::TIES); break; } @@ -3376,9 +3372,9 @@ HogQLParser::FromClauseContext* HogQLParser::fromClause() { }); try { enterOuterAlt(_localctx, 1); - setState(442); + setState(438); match(HogQLParser::FROM); - setState(443); + setState(439); joinExpr(0); } @@ -3444,14 +3440,14 @@ HogQLParser::ArrayJoinClauseContext* HogQLParser::arrayJoinClause() { }); try { enterOuterAlt(_localctx, 1); - setState(446); + setState(442); _errHandler->sync(this); _la = _input->LA(1); if (_la == HogQLParser::INNER || _la == HogQLParser::LEFT) { - setState(445); + setState(441); _la = _input->LA(1); if (!(_la == HogQLParser::INNER @@ -3463,11 +3459,11 @@ HogQLParser::ArrayJoinClauseContext* HogQLParser::arrayJoinClause() { consume(); } } - setState(448); + setState(444); match(HogQLParser::ARRAY); - setState(449); + setState(445); match(HogQLParser::JOIN); - setState(450); + setState(446); columnExprList(); } @@ -3565,35 +3561,35 @@ HogQLParser::WindowClauseContext* HogQLParser::windowClause() { }); try { enterOuterAlt(_localctx, 1); - setState(452); + setState(448); match(HogQLParser::WINDOW); - setState(453); + setState(449); identifier(); - setState(454); + setState(450); match(HogQLParser::AS); - setState(455); + setState(451); match(HogQLParser::LPAREN); - setState(456); + setState(452); windowExpr(); - setState(457); + setState(453); match(HogQLParser::RPAREN); - setState(467); + setState(463); _errHandler->sync(this); _la = _input->LA(1); while (_la == HogQLParser::COMMA) { - setState(458); + setState(454); match(HogQLParser::COMMA); - setState(459); + setState(455); identifier(); - setState(460); + setState(456); match(HogQLParser::AS); - setState(461); + setState(457); match(HogQLParser::LPAREN); - setState(462); + setState(458); windowExpr(); - setState(463); + setState(459); match(HogQLParser::RPAREN); - setState(469); + setState(465); _errHandler->sync(this); _la = _input->LA(1); } @@ -3648,9 +3644,9 @@ HogQLParser::PrewhereClauseContext* HogQLParser::prewhereClause() { }); try { enterOuterAlt(_localctx, 1); - setState(470); + setState(466); match(HogQLParser::PREWHERE); - setState(471); + setState(467); columnExpr(0); } @@ -3703,9 +3699,9 @@ HogQLParser::WhereClauseContext* HogQLParser::whereClause() { }); try { enterOuterAlt(_localctx, 1); - setState(473); + setState(469); match(HogQLParser::WHERE); - setState(474); + setState(470); columnExpr(0); } @@ -3779,15 +3775,15 @@ HogQLParser::GroupByClauseContext* HogQLParser::groupByClause() { }); try { enterOuterAlt(_localctx, 1); - setState(476); + setState(472); match(HogQLParser::GROUP); - setState(477); + setState(473); match(HogQLParser::BY); - setState(484); + setState(480); _errHandler->sync(this); switch (getInterpreter()->adaptivePredict(_input, 48, _ctx)) { case 1: { - setState(478); + setState(474); _la = _input->LA(1); if (!(_la == HogQLParser::CUBE @@ -3798,17 +3794,17 @@ HogQLParser::GroupByClauseContext* HogQLParser::groupByClause() { _errHandler->reportMatch(this); consume(); } - setState(479); + setState(475); match(HogQLParser::LPAREN); - setState(480); + setState(476); columnExprList(); - setState(481); + setState(477); match(HogQLParser::RPAREN); break; } case 2: { - setState(483); + setState(479); columnExprList(); break; } @@ -3867,9 +3863,9 @@ HogQLParser::HavingClauseContext* HogQLParser::havingClause() { }); try { enterOuterAlt(_localctx, 1); - setState(486); + setState(482); match(HogQLParser::HAVING); - setState(487); + setState(483); columnExpr(0); } @@ -3926,11 +3922,11 @@ HogQLParser::OrderByClauseContext* HogQLParser::orderByClause() { }); try { enterOuterAlt(_localctx, 1); - setState(489); + setState(485); match(HogQLParser::ORDER); - setState(490); + setState(486); match(HogQLParser::BY); - setState(491); + setState(487); orderExprList(); } @@ -3987,11 +3983,11 @@ HogQLParser::ProjectionOrderByClauseContext* HogQLParser::projectionOrderByClaus }); try { enterOuterAlt(_localctx, 1); - setState(493); + setState(489); match(HogQLParser::ORDER); - setState(494); + setState(490); match(HogQLParser::BY); - setState(495); + setState(491); columnExprList(); } @@ -4072,40 +4068,40 @@ HogQLParser::LimitAndOffsetClauseContext* HogQLParser::limitAndOffsetClause() { exitRule(); }); try { - setState(526); + setState(522); _errHandler->sync(this); switch (getInterpreter()->adaptivePredict(_input, 53, _ctx)) { case 1: { enterOuterAlt(_localctx, 1); - setState(497); + setState(493); match(HogQLParser::LIMIT); - setState(498); + setState(494); columnExpr(0); - setState(501); + setState(497); _errHandler->sync(this); _la = _input->LA(1); if (_la == HogQLParser::COMMA) { - setState(499); + setState(495); match(HogQLParser::COMMA); - setState(500); + setState(496); columnExpr(0); } - setState(507); + setState(503); _errHandler->sync(this); switch (_input->LA(1)) { case HogQLParser::WITH: { - setState(503); + setState(499); match(HogQLParser::WITH); - setState(504); + setState(500); match(HogQLParser::TIES); break; } case HogQLParser::BY: { - setState(505); + setState(501); match(HogQLParser::BY); - setState(506); + setState(502); columnExprList(); break; } @@ -4125,45 +4121,45 @@ HogQLParser::LimitAndOffsetClauseContext* HogQLParser::limitAndOffsetClause() { case 2: { enterOuterAlt(_localctx, 2); - setState(509); + setState(505); match(HogQLParser::LIMIT); - setState(510); + setState(506); columnExpr(0); - setState(513); + setState(509); _errHandler->sync(this); _la = _input->LA(1); if (_la == HogQLParser::WITH) { - setState(511); + setState(507); match(HogQLParser::WITH); - setState(512); + setState(508); match(HogQLParser::TIES); } - setState(515); + setState(511); match(HogQLParser::OFFSET); - setState(516); + setState(512); columnExpr(0); break; } case 3: { enterOuterAlt(_localctx, 3); - setState(518); + setState(514); match(HogQLParser::LIMIT); - setState(519); + setState(515); columnExpr(0); - setState(520); + setState(516); match(HogQLParser::OFFSET); - setState(521); + setState(517); columnExpr(0); - setState(524); + setState(520); _errHandler->sync(this); _la = _input->LA(1); if (_la == HogQLParser::BY) { - setState(522); + setState(518); match(HogQLParser::BY); - setState(523); + setState(519); columnExprList(); } break; @@ -4223,9 +4219,9 @@ HogQLParser::OffsetOnlyClauseContext* HogQLParser::offsetOnlyClause() { }); try { enterOuterAlt(_localctx, 1); - setState(528); + setState(524); match(HogQLParser::OFFSET); - setState(529); + setState(525); columnExpr(0); } @@ -4278,9 +4274,9 @@ HogQLParser::SettingsClauseContext* HogQLParser::settingsClause() { }); try { enterOuterAlt(_localctx, 1); - setState(531); + setState(527); match(HogQLParser::SETTINGS); - setState(532); + setState(528); settingExprList(); } @@ -4434,7 +4430,7 @@ HogQLParser::JoinExprContext* HogQLParser::joinExpr(int precedence) { try { size_t alt; enterOuterAlt(_localctx, 1); - setState(546); + setState(542); _errHandler->sync(this); switch (getInterpreter()->adaptivePredict(_input, 56, _ctx)) { case 1: { @@ -4442,14 +4438,14 @@ HogQLParser::JoinExprContext* HogQLParser::joinExpr(int precedence) { _ctx = _localctx; previousContext = _localctx; - setState(535); + setState(531); tableExpr(0); - setState(537); + setState(533); _errHandler->sync(this); switch (getInterpreter()->adaptivePredict(_input, 54, _ctx)) { case 1: { - setState(536); + setState(532); match(HogQLParser::FINAL); break; } @@ -4457,12 +4453,12 @@ HogQLParser::JoinExprContext* HogQLParser::joinExpr(int precedence) { default: break; } - setState(540); + setState(536); _errHandler->sync(this); switch (getInterpreter()->adaptivePredict(_input, 55, _ctx)) { case 1: { - setState(539); + setState(535); sampleClause(); break; } @@ -4477,11 +4473,11 @@ HogQLParser::JoinExprContext* HogQLParser::joinExpr(int precedence) { _localctx = _tracker.createInstance(_localctx); _ctx = _localctx; previousContext = _localctx; - setState(542); + setState(538); match(HogQLParser::LPAREN); - setState(543); + setState(539); joinExpr(0); - setState(544); + setState(540); match(HogQLParser::RPAREN); break; } @@ -4490,7 +4486,7 @@ HogQLParser::JoinExprContext* HogQLParser::joinExpr(int precedence) { break; } _ctx->stop = _input->LT(-1); - setState(562); + setState(558); _errHandler->sync(this); alt = getInterpreter()->adaptivePredict(_input, 59, _ctx); while (alt != 2 && alt != atn::ATN::INVALID_ALT_NUMBER) { @@ -4498,19 +4494,19 @@ HogQLParser::JoinExprContext* HogQLParser::joinExpr(int precedence) { if (!_parseListeners.empty()) triggerExitRuleEvent(); previousContext = _localctx; - setState(560); + setState(556); _errHandler->sync(this); switch (getInterpreter()->adaptivePredict(_input, 58, _ctx)) { case 1: { auto newContext = _tracker.createInstance(_tracker.createInstance(parentContext, parentState)); _localctx = newContext; pushNewRecursionContext(newContext, startState, RuleJoinExpr); - setState(548); + setState(544); if (!(precpred(_ctx, 3))) throw FailedPredicateException(this, "precpred(_ctx, 3)"); - setState(549); + setState(545); joinOpCross(); - setState(550); + setState(546); joinExpr(4); break; } @@ -4519,10 +4515,10 @@ HogQLParser::JoinExprContext* HogQLParser::joinExpr(int precedence) { auto newContext = _tracker.createInstance(_tracker.createInstance(parentContext, parentState)); _localctx = newContext; pushNewRecursionContext(newContext, startState, RuleJoinExpr); - setState(552); + setState(548); if (!(precpred(_ctx, 4))) throw FailedPredicateException(this, "precpred(_ctx, 4)"); - setState(554); + setState(550); _errHandler->sync(this); _la = _input->LA(1); @@ -4530,14 +4526,14 @@ HogQLParser::JoinExprContext* HogQLParser::joinExpr(int precedence) { ((1ULL << _la) & 2269426359468314) != 0) || _la == HogQLParser::RIGHT || _la == HogQLParser::SEMI) { - setState(553); + setState(549); joinOp(); } - setState(556); + setState(552); match(HogQLParser::JOIN); - setState(557); + setState(553); joinExpr(0); - setState(558); + setState(554); joinConstraintClause(); break; } @@ -4546,7 +4542,7 @@ HogQLParser::JoinExprContext* HogQLParser::joinExpr(int precedence) { break; } } - setState(564); + setState(560); _errHandler->sync(this); alt = getInterpreter()->adaptivePredict(_input, 59, _ctx); } @@ -4684,23 +4680,23 @@ HogQLParser::JoinOpContext* HogQLParser::joinOp() { exitRule(); }); try { - setState(608); + setState(604); _errHandler->sync(this); switch (getInterpreter()->adaptivePredict(_input, 73, _ctx)) { case 1: { _localctx = _tracker.createInstance(_localctx); enterOuterAlt(_localctx, 1); - setState(574); + setState(570); _errHandler->sync(this); switch (getInterpreter()->adaptivePredict(_input, 62, _ctx)) { case 1: { - setState(566); + setState(562); _errHandler->sync(this); _la = _input->LA(1); if ((((_la & ~ 0x3fULL) == 0) && ((1ULL << _la) & 274) != 0)) { - setState(565); + setState(561); _la = _input->LA(1); if (!((((_la & ~ 0x3fULL) == 0) && ((1ULL << _la) & 274) != 0))) { @@ -4711,21 +4707,21 @@ HogQLParser::JoinOpContext* HogQLParser::joinOp() { consume(); } } - setState(568); + setState(564); match(HogQLParser::INNER); break; } case 2: { - setState(569); + setState(565); match(HogQLParser::INNER); - setState(571); + setState(567); _errHandler->sync(this); _la = _input->LA(1); if ((((_la & ~ 0x3fULL) == 0) && ((1ULL << _la) & 274) != 0)) { - setState(570); + setState(566); _la = _input->LA(1); if (!((((_la & ~ 0x3fULL) == 0) && ((1ULL << _la) & 274) != 0))) { @@ -4740,7 +4736,7 @@ HogQLParser::JoinOpContext* HogQLParser::joinOp() { } case 3: { - setState(573); + setState(569); _la = _input->LA(1); if (!((((_la & ~ 0x3fULL) == 0) && ((1ULL << _la) & 274) != 0))) { @@ -4762,17 +4758,17 @@ HogQLParser::JoinOpContext* HogQLParser::joinOp() { case 2: { _localctx = _tracker.createInstance(_localctx); enterOuterAlt(_localctx, 2); - setState(590); + setState(586); _errHandler->sync(this); switch (getInterpreter()->adaptivePredict(_input, 67, _ctx)) { case 1: { - setState(577); + setState(573); _errHandler->sync(this); _la = _input->LA(1); if ((((_la & ~ 0x3fULL) == 0) && ((1ULL << _la) & 282) != 0) || _la == HogQLParser::SEMI) { - setState(576); + setState(572); _la = _input->LA(1); if (!((((_la & ~ 0x3fULL) == 0) && ((1ULL << _la) & 282) != 0) || _la == HogQLParser::SEMI)) { @@ -4783,7 +4779,7 @@ HogQLParser::JoinOpContext* HogQLParser::joinOp() { consume(); } } - setState(579); + setState(575); _la = _input->LA(1); if (!(_la == HogQLParser::LEFT @@ -4794,19 +4790,19 @@ HogQLParser::JoinOpContext* HogQLParser::joinOp() { _errHandler->reportMatch(this); consume(); } - setState(581); + setState(577); _errHandler->sync(this); _la = _input->LA(1); if (_la == HogQLParser::OUTER) { - setState(580); + setState(576); match(HogQLParser::OUTER); } break; } case 2: { - setState(583); + setState(579); _la = _input->LA(1); if (!(_la == HogQLParser::LEFT @@ -4817,21 +4813,21 @@ HogQLParser::JoinOpContext* HogQLParser::joinOp() { _errHandler->reportMatch(this); consume(); } - setState(585); + setState(581); _errHandler->sync(this); _la = _input->LA(1); if (_la == HogQLParser::OUTER) { - setState(584); + setState(580); match(HogQLParser::OUTER); } - setState(588); + setState(584); _errHandler->sync(this); _la = _input->LA(1); if ((((_la & ~ 0x3fULL) == 0) && ((1ULL << _la) & 282) != 0) || _la == HogQLParser::SEMI) { - setState(587); + setState(583); _la = _input->LA(1); if (!((((_la & ~ 0x3fULL) == 0) && ((1ULL << _la) & 282) != 0) || _la == HogQLParser::SEMI)) { @@ -4854,18 +4850,18 @@ HogQLParser::JoinOpContext* HogQLParser::joinOp() { case 3: { _localctx = _tracker.createInstance(_localctx); enterOuterAlt(_localctx, 3); - setState(606); + setState(602); _errHandler->sync(this); switch (getInterpreter()->adaptivePredict(_input, 72, _ctx)) { case 1: { - setState(593); + setState(589); _errHandler->sync(this); _la = _input->LA(1); if (_la == HogQLParser::ALL || _la == HogQLParser::ANY) { - setState(592); + setState(588); _la = _input->LA(1); if (!(_la == HogQLParser::ALL @@ -4877,38 +4873,38 @@ HogQLParser::JoinOpContext* HogQLParser::joinOp() { consume(); } } - setState(595); + setState(591); match(HogQLParser::FULL); - setState(597); + setState(593); _errHandler->sync(this); _la = _input->LA(1); if (_la == HogQLParser::OUTER) { - setState(596); + setState(592); match(HogQLParser::OUTER); } break; } case 2: { - setState(599); + setState(595); match(HogQLParser::FULL); - setState(601); + setState(597); _errHandler->sync(this); _la = _input->LA(1); if (_la == HogQLParser::OUTER) { - setState(600); + setState(596); match(HogQLParser::OUTER); } - setState(604); + setState(600); _errHandler->sync(this); _la = _input->LA(1); if (_la == HogQLParser::ALL || _la == HogQLParser::ANY) { - setState(603); + setState(599); _la = _input->LA(1); if (!(_la == HogQLParser::ALL @@ -4986,21 +4982,21 @@ HogQLParser::JoinOpCrossContext* HogQLParser::joinOpCross() { exitRule(); }); try { - setState(613); + setState(609); _errHandler->sync(this); switch (_input->LA(1)) { case HogQLParser::CROSS: { enterOuterAlt(_localctx, 1); - setState(610); + setState(606); match(HogQLParser::CROSS); - setState(611); + setState(607); match(HogQLParser::JOIN); break; } case HogQLParser::COMMA: { enterOuterAlt(_localctx, 2); - setState(612); + setState(608); match(HogQLParser::COMMA); break; } @@ -5070,36 +5066,36 @@ HogQLParser::JoinConstraintClauseContext* HogQLParser::joinConstraintClause() { exitRule(); }); try { - setState(624); + setState(620); _errHandler->sync(this); switch (getInterpreter()->adaptivePredict(_input, 75, _ctx)) { case 1: { enterOuterAlt(_localctx, 1); - setState(615); + setState(611); match(HogQLParser::ON); - setState(616); + setState(612); columnExprList(); break; } case 2: { enterOuterAlt(_localctx, 2); - setState(617); + setState(613); match(HogQLParser::USING); - setState(618); + setState(614); match(HogQLParser::LPAREN); - setState(619); + setState(615); columnExprList(); - setState(620); + setState(616); match(HogQLParser::RPAREN); break; } case 3: { enterOuterAlt(_localctx, 3); - setState(622); + setState(618); match(HogQLParser::USING); - setState(623); + setState(619); columnExprList(); break; } @@ -5166,18 +5162,18 @@ HogQLParser::SampleClauseContext* HogQLParser::sampleClause() { }); try { enterOuterAlt(_localctx, 1); - setState(626); + setState(622); match(HogQLParser::SAMPLE); - setState(627); + setState(623); ratioExpr(); - setState(630); + setState(626); _errHandler->sync(this); switch (getInterpreter()->adaptivePredict(_input, 76, _ctx)) { case 1: { - setState(628); + setState(624); match(HogQLParser::OFFSET); - setState(629); + setState(625); ratioExpr(); break; } @@ -5245,17 +5241,17 @@ HogQLParser::OrderExprListContext* HogQLParser::orderExprList() { }); try { enterOuterAlt(_localctx, 1); - setState(632); + setState(628); orderExpr(); - setState(637); + setState(633); _errHandler->sync(this); _la = _input->LA(1); while (_la == HogQLParser::COMMA) { - setState(633); + setState(629); match(HogQLParser::COMMA); - setState(634); + setState(630); orderExpr(); - setState(639); + setState(635); _errHandler->sync(this); _la = _input->LA(1); } @@ -5339,15 +5335,15 @@ HogQLParser::OrderExprContext* HogQLParser::orderExpr() { }); try { enterOuterAlt(_localctx, 1); - setState(640); + setState(636); columnExpr(0); - setState(642); + setState(638); _errHandler->sync(this); _la = _input->LA(1); if ((((_la & ~ 0x3fULL) == 0) && ((1ULL << _la) & 12583040) != 0)) { - setState(641); + setState(637); _la = _input->LA(1); if (!((((_la & ~ 0x3fULL) == 0) && ((1ULL << _la) & 12583040) != 0))) { @@ -5358,14 +5354,14 @@ HogQLParser::OrderExprContext* HogQLParser::orderExpr() { consume(); } } - setState(646); + setState(642); _errHandler->sync(this); _la = _input->LA(1); if (_la == HogQLParser::NULLS) { - setState(644); + setState(640); match(HogQLParser::NULLS); - setState(645); + setState(641); _la = _input->LA(1); if (!(_la == HogQLParser::FIRST @@ -5377,14 +5373,14 @@ HogQLParser::OrderExprContext* HogQLParser::orderExpr() { consume(); } } - setState(650); + setState(646); _errHandler->sync(this); _la = _input->LA(1); if (_la == HogQLParser::COLLATE) { - setState(648); + setState(644); match(HogQLParser::COLLATE); - setState(649); + setState(645); match(HogQLParser::STRING_LITERAL); } @@ -5445,12 +5441,12 @@ HogQLParser::RatioExprContext* HogQLParser::ratioExpr() { exitRule(); }); try { - setState(658); + setState(654); _errHandler->sync(this); switch (_input->LA(1)) { case HogQLParser::LBRACE: { enterOuterAlt(_localctx, 1); - setState(652); + setState(648); placeholder(); break; } @@ -5465,16 +5461,16 @@ HogQLParser::RatioExprContext* HogQLParser::ratioExpr() { case HogQLParser::DOT: case HogQLParser::PLUS: { enterOuterAlt(_localctx, 2); - setState(653); + setState(649); numberLiteral(); - setState(656); + setState(652); _errHandler->sync(this); switch (getInterpreter()->adaptivePredict(_input, 81, _ctx)) { case 1: { - setState(654); + setState(650); match(HogQLParser::SLASH); - setState(655); + setState(651); numberLiteral(); break; } @@ -5548,17 +5544,17 @@ HogQLParser::SettingExprListContext* HogQLParser::settingExprList() { }); try { enterOuterAlt(_localctx, 1); - setState(660); + setState(656); settingExpr(); - setState(665); + setState(661); _errHandler->sync(this); _la = _input->LA(1); while (_la == HogQLParser::COMMA) { - setState(661); + setState(657); match(HogQLParser::COMMA); - setState(662); + setState(658); settingExpr(); - setState(667); + setState(663); _errHandler->sync(this); _la = _input->LA(1); } @@ -5617,11 +5613,11 @@ HogQLParser::SettingExprContext* HogQLParser::settingExpr() { }); try { enterOuterAlt(_localctx, 1); - setState(668); + setState(664); identifier(); - setState(669); + setState(665); match(HogQLParser::EQ_SINGLE); - setState(670); + setState(666); literal(); } @@ -5679,30 +5675,30 @@ HogQLParser::WindowExprContext* HogQLParser::windowExpr() { }); try { enterOuterAlt(_localctx, 1); - setState(673); + setState(669); _errHandler->sync(this); _la = _input->LA(1); if (_la == HogQLParser::PARTITION) { - setState(672); + setState(668); winPartitionByClause(); } - setState(676); + setState(672); _errHandler->sync(this); _la = _input->LA(1); if (_la == HogQLParser::ORDER) { - setState(675); + setState(671); winOrderByClause(); } - setState(679); + setState(675); _errHandler->sync(this); _la = _input->LA(1); if (_la == HogQLParser::RANGE || _la == HogQLParser::ROWS) { - setState(678); + setState(674); winFrameClause(); } @@ -5760,11 +5756,11 @@ HogQLParser::WinPartitionByClauseContext* HogQLParser::winPartitionByClause() { }); try { enterOuterAlt(_localctx, 1); - setState(681); + setState(677); match(HogQLParser::PARTITION); - setState(682); + setState(678); match(HogQLParser::BY); - setState(683); + setState(679); columnExprList(); } @@ -5821,11 +5817,11 @@ HogQLParser::WinOrderByClauseContext* HogQLParser::winOrderByClause() { }); try { enterOuterAlt(_localctx, 1); - setState(685); + setState(681); match(HogQLParser::ORDER); - setState(686); + setState(682); match(HogQLParser::BY); - setState(687); + setState(683); orderExprList(); } @@ -5883,7 +5879,7 @@ HogQLParser::WinFrameClauseContext* HogQLParser::winFrameClause() { }); try { enterOuterAlt(_localctx, 1); - setState(689); + setState(685); _la = _input->LA(1); if (!(_la == HogQLParser::RANGE @@ -5894,7 +5890,7 @@ HogQLParser::WinFrameClauseContext* HogQLParser::winFrameClause() { _errHandler->reportMatch(this); consume(); } - setState(690); + setState(686); winFrameExtend(); } @@ -5976,7 +5972,7 @@ HogQLParser::WinFrameExtendContext* HogQLParser::winFrameExtend() { exitRule(); }); try { - setState(698); + setState(694); _errHandler->sync(this); switch (_input->LA(1)) { case HogQLParser::CURRENT: @@ -5992,7 +5988,7 @@ HogQLParser::WinFrameExtendContext* HogQLParser::winFrameExtend() { case HogQLParser::PLUS: { _localctx = _tracker.createInstance(_localctx); enterOuterAlt(_localctx, 1); - setState(692); + setState(688); winFrameBound(); break; } @@ -6000,13 +5996,13 @@ HogQLParser::WinFrameExtendContext* HogQLParser::winFrameExtend() { case HogQLParser::BETWEEN: { _localctx = _tracker.createInstance(_localctx); enterOuterAlt(_localctx, 2); - setState(693); + setState(689); match(HogQLParser::BETWEEN); - setState(694); + setState(690); winFrameBound(); - setState(695); + setState(691); match(HogQLParser::AND); - setState(696); + setState(692); winFrameBound(); break; } @@ -6081,45 +6077,45 @@ HogQLParser::WinFrameBoundContext* HogQLParser::winFrameBound() { }); try { enterOuterAlt(_localctx, 1); - setState(712); + setState(708); _errHandler->sync(this); switch (getInterpreter()->adaptivePredict(_input, 88, _ctx)) { case 1: { - setState(700); + setState(696); match(HogQLParser::CURRENT); - setState(701); + setState(697); match(HogQLParser::ROW); break; } case 2: { - setState(702); + setState(698); match(HogQLParser::UNBOUNDED); - setState(703); + setState(699); match(HogQLParser::PRECEDING); break; } case 3: { - setState(704); + setState(700); match(HogQLParser::UNBOUNDED); - setState(705); + setState(701); match(HogQLParser::FOLLOWING); break; } case 4: { - setState(706); + setState(702); numberLiteral(); - setState(707); + setState(703); match(HogQLParser::PRECEDING); break; } case 5: { - setState(709); + setState(705); numberLiteral(); - setState(710); + setState(706); match(HogQLParser::FOLLOWING); break; } @@ -6178,9 +6174,9 @@ HogQLParser::ExprContext* HogQLParser::expr() { }); try { enterOuterAlt(_localctx, 1); - setState(714); + setState(710); columnExpr(0); - setState(715); + setState(711); match(HogQLParser::EOF); } @@ -6385,13 +6381,13 @@ HogQLParser::ColumnTypeExprContext* HogQLParser::columnTypeExpr() { }); try { size_t alt; - setState(773); + setState(769); _errHandler->sync(this); switch (getInterpreter()->adaptivePredict(_input, 96, _ctx)) { case 1: { _localctx = _tracker.createInstance(_localctx); enterOuterAlt(_localctx, 1); - setState(717); + setState(713); identifier(); break; } @@ -6399,39 +6395,39 @@ HogQLParser::ColumnTypeExprContext* HogQLParser::columnTypeExpr() { case 2: { _localctx = _tracker.createInstance(_localctx); enterOuterAlt(_localctx, 2); - setState(718); + setState(714); identifier(); - setState(719); + setState(715); match(HogQLParser::LPAREN); - setState(720); + setState(716); identifier(); - setState(721); + setState(717); columnTypeExpr(); - setState(728); + setState(724); _errHandler->sync(this); alt = getInterpreter()->adaptivePredict(_input, 89, _ctx); while (alt != 2 && alt != atn::ATN::INVALID_ALT_NUMBER) { if (alt == 1) { - setState(722); + setState(718); match(HogQLParser::COMMA); - setState(723); + setState(719); identifier(); - setState(724); + setState(720); columnTypeExpr(); } - setState(730); + setState(726); _errHandler->sync(this); alt = getInterpreter()->adaptivePredict(_input, 89, _ctx); } - setState(732); + setState(728); _errHandler->sync(this); _la = _input->LA(1); if (_la == HogQLParser::COMMA) { - setState(731); + setState(727); match(HogQLParser::COMMA); } - setState(734); + setState(730); match(HogQLParser::RPAREN); break; } @@ -6439,35 +6435,35 @@ HogQLParser::ColumnTypeExprContext* HogQLParser::columnTypeExpr() { case 3: { _localctx = _tracker.createInstance(_localctx); enterOuterAlt(_localctx, 3); - setState(736); + setState(732); identifier(); - setState(737); + setState(733); match(HogQLParser::LPAREN); - setState(738); + setState(734); enumValue(); - setState(743); + setState(739); _errHandler->sync(this); alt = getInterpreter()->adaptivePredict(_input, 91, _ctx); while (alt != 2 && alt != atn::ATN::INVALID_ALT_NUMBER) { if (alt == 1) { - setState(739); + setState(735); match(HogQLParser::COMMA); - setState(740); + setState(736); enumValue(); } - setState(745); + setState(741); _errHandler->sync(this); alt = getInterpreter()->adaptivePredict(_input, 91, _ctx); } - setState(747); + setState(743); _errHandler->sync(this); _la = _input->LA(1); if (_la == HogQLParser::COMMA) { - setState(746); + setState(742); match(HogQLParser::COMMA); } - setState(749); + setState(745); match(HogQLParser::RPAREN); break; } @@ -6475,35 +6471,35 @@ HogQLParser::ColumnTypeExprContext* HogQLParser::columnTypeExpr() { case 4: { _localctx = _tracker.createInstance(_localctx); enterOuterAlt(_localctx, 4); - setState(751); + setState(747); identifier(); - setState(752); + setState(748); match(HogQLParser::LPAREN); - setState(753); + setState(749); columnTypeExpr(); - setState(758); + setState(754); _errHandler->sync(this); alt = getInterpreter()->adaptivePredict(_input, 93, _ctx); while (alt != 2 && alt != atn::ATN::INVALID_ALT_NUMBER) { if (alt == 1) { - setState(754); + setState(750); match(HogQLParser::COMMA); - setState(755); + setState(751); columnTypeExpr(); } - setState(760); + setState(756); _errHandler->sync(this); alt = getInterpreter()->adaptivePredict(_input, 93, _ctx); } - setState(762); + setState(758); _errHandler->sync(this); _la = _input->LA(1); if (_la == HogQLParser::COMMA) { - setState(761); + setState(757); match(HogQLParser::COMMA); } - setState(764); + setState(760); match(HogQLParser::RPAREN); break; } @@ -6511,11 +6507,11 @@ HogQLParser::ColumnTypeExprContext* HogQLParser::columnTypeExpr() { case 5: { _localctx = _tracker.createInstance(_localctx); enterOuterAlt(_localctx, 5); - setState(766); + setState(762); identifier(); - setState(767); + setState(763); match(HogQLParser::LPAREN); - setState(769); + setState(765); _errHandler->sync(this); _la = _input->LA(1); @@ -6523,10 +6519,10 @@ HogQLParser::ColumnTypeExprContext* HogQLParser::columnTypeExpr() { ((1ULL << _la) & -4503602311741442) != 0) || ((((_la - 64) & ~ 0x3fULL) == 0) && ((1ULL << (_la - 64)) & 90493036243451903) != 0) || ((((_la - 128) & ~ 0x3fULL) == 0) && ((1ULL << (_la - 128)) & 18455) != 0)) { - setState(768); + setState(764); columnExprList(); } - setState(771); + setState(767); match(HogQLParser::RPAREN); break; } @@ -6594,28 +6590,28 @@ HogQLParser::ColumnExprListContext* HogQLParser::columnExprList() { try { size_t alt; enterOuterAlt(_localctx, 1); - setState(775); + setState(771); columnExpr(0); - setState(780); + setState(776); _errHandler->sync(this); alt = getInterpreter()->adaptivePredict(_input, 97, _ctx); while (alt != 2 && alt != atn::ATN::INVALID_ALT_NUMBER) { if (alt == 1) { - setState(776); + setState(772); match(HogQLParser::COMMA); - setState(777); + setState(773); columnExpr(0); } - setState(782); + setState(778); _errHandler->sync(this); alt = getInterpreter()->adaptivePredict(_input, 97, _ctx); } - setState(784); + setState(780); _errHandler->sync(this); switch (getInterpreter()->adaptivePredict(_input, 98, _ctx)) { case 1: { - setState(783); + setState(779); match(HogQLParser::COMMA); break; } @@ -7159,16 +7155,16 @@ tree::TerminalNode* HogQLParser::ColumnExprWinFunctionTargetContext::RPAREN(size return getToken(HogQLParser::RPAREN, i); } -HogQLParser::ColumnExprListContext* HogQLParser::ColumnExprWinFunctionTargetContext::columnExprList() { - return getRuleContext(0); +std::vector HogQLParser::ColumnExprWinFunctionTargetContext::columnExprList() { + return getRuleContexts(); } -tree::TerminalNode* HogQLParser::ColumnExprWinFunctionTargetContext::DISTINCT() { - return getToken(HogQLParser::DISTINCT, 0); +HogQLParser::ColumnExprListContext* HogQLParser::ColumnExprWinFunctionTargetContext::columnExprList(size_t i) { + return getRuleContext(i); } -HogQLParser::ColumnArgListContext* HogQLParser::ColumnExprWinFunctionTargetContext::columnArgList() { - return getRuleContext(0); +tree::TerminalNode* HogQLParser::ColumnExprWinFunctionTargetContext::DISTINCT() { + return getToken(HogQLParser::DISTINCT, 0); } HogQLParser::ColumnExprWinFunctionTargetContext::ColumnExprWinFunctionTargetContext(ColumnExprContext *ctx) { copyFrom(ctx); } @@ -7303,6 +7299,33 @@ std::any HogQLParser::ColumnExprTupleContext::accept(tree::ParseTreeVisitor *vis else return visitor->visitChildren(this); } +//----------------- ColumnExprCallContext ------------------------------------------------------------------ + +HogQLParser::ColumnExprContext* HogQLParser::ColumnExprCallContext::columnExpr() { + return getRuleContext(0); +} + +tree::TerminalNode* HogQLParser::ColumnExprCallContext::LPAREN() { + return getToken(HogQLParser::LPAREN, 0); +} + +tree::TerminalNode* HogQLParser::ColumnExprCallContext::RPAREN() { + return getToken(HogQLParser::RPAREN, 0); +} + +HogQLParser::ColumnExprListContext* HogQLParser::ColumnExprCallContext::columnExprList() { + return getRuleContext(0); +} + +HogQLParser::ColumnExprCallContext::ColumnExprCallContext(ColumnExprContext *ctx) { copyFrom(ctx); } + + +std::any HogQLParser::ColumnExprCallContext::accept(tree::ParseTreeVisitor *visitor) { + if (auto parserVisitor = dynamic_cast(visitor)) + return parserVisitor->visitColumnExprCall(this); + else + return visitor->visitChildren(this); +} //----------------- ColumnExprArrayAccessContext ------------------------------------------------------------------ std::vector HogQLParser::ColumnExprArrayAccessContext::columnExpr() { @@ -7641,16 +7664,16 @@ tree::TerminalNode* HogQLParser::ColumnExprWinFunctionContext::RPAREN(size_t i) return getToken(HogQLParser::RPAREN, i); } -HogQLParser::ColumnExprListContext* HogQLParser::ColumnExprWinFunctionContext::columnExprList() { - return getRuleContext(0); +std::vector HogQLParser::ColumnExprWinFunctionContext::columnExprList() { + return getRuleContexts(); } -tree::TerminalNode* HogQLParser::ColumnExprWinFunctionContext::DISTINCT() { - return getToken(HogQLParser::DISTINCT, 0); +HogQLParser::ColumnExprListContext* HogQLParser::ColumnExprWinFunctionContext::columnExprList(size_t i) { + return getRuleContext(i); } -HogQLParser::ColumnArgListContext* HogQLParser::ColumnExprWinFunctionContext::columnArgList() { - return getRuleContext(0); +tree::TerminalNode* HogQLParser::ColumnExprWinFunctionContext::DISTINCT() { + return getToken(HogQLParser::DISTINCT, 0); } HogQLParser::ColumnExprWinFunctionContext::ColumnExprWinFunctionContext(ColumnExprContext *ctx) { copyFrom(ctx); } @@ -7662,6 +7685,21 @@ std::any HogQLParser::ColumnExprWinFunctionContext::accept(tree::ParseTreeVisito else return visitor->visitChildren(this); } +//----------------- ColumnExprLambdaContext ------------------------------------------------------------------ + +HogQLParser::ColumnLambdaExprContext* HogQLParser::ColumnExprLambdaContext::columnLambdaExpr() { + return getRuleContext(0); +} + +HogQLParser::ColumnExprLambdaContext::ColumnExprLambdaContext(ColumnExprContext *ctx) { copyFrom(ctx); } + + +std::any HogQLParser::ColumnExprLambdaContext::accept(tree::ParseTreeVisitor *visitor) { + if (auto parserVisitor = dynamic_cast(visitor)) + return parserVisitor->visitColumnExprLambda(this); + else + return visitor->visitChildren(this); +} //----------------- ColumnExprIdentifierContext ------------------------------------------------------------------ HogQLParser::ColumnIdentifierContext* HogQLParser::ColumnExprIdentifierContext::columnIdentifier() { @@ -7703,12 +7741,12 @@ tree::TerminalNode* HogQLParser::ColumnExprFunctionContext::DISTINCT() { return getToken(HogQLParser::DISTINCT, 0); } -HogQLParser::ColumnArgListContext* HogQLParser::ColumnExprFunctionContext::columnArgList() { - return getRuleContext(0); +std::vector HogQLParser::ColumnExprFunctionContext::columnExprList() { + return getRuleContexts(); } -HogQLParser::ColumnExprListContext* HogQLParser::ColumnExprFunctionContext::columnExprList() { - return getRuleContext(0); +HogQLParser::ColumnExprListContext* HogQLParser::ColumnExprFunctionContext::columnExprList(size_t i) { + return getRuleContext(i); } HogQLParser::ColumnExprFunctionContext::ColumnExprFunctionContext(ColumnExprContext *ctx) { copyFrom(ctx); } @@ -7769,7 +7807,7 @@ HogQLParser::ColumnExprContext* HogQLParser::columnExpr(int precedence) { try { size_t alt; enterOuterAlt(_localctx, 1); - setState(935); + setState(932); _errHandler->sync(this); switch (getInterpreter()->adaptivePredict(_input, 118, _ctx)) { case 1: { @@ -7777,14 +7815,14 @@ HogQLParser::ColumnExprContext* HogQLParser::columnExpr(int precedence) { _ctx = _localctx; previousContext = _localctx; - setState(787); + setState(783); match(HogQLParser::CASE); - setState(789); + setState(785); _errHandler->sync(this); switch (getInterpreter()->adaptivePredict(_input, 99, _ctx)) { case 1: { - setState(788); + setState(784); antlrcpp::downCast(_localctx)->caseExpr = columnExpr(0); break; } @@ -7792,33 +7830,33 @@ HogQLParser::ColumnExprContext* HogQLParser::columnExpr(int precedence) { default: break; } - setState(796); + setState(792); _errHandler->sync(this); _la = _input->LA(1); do { - setState(791); + setState(787); match(HogQLParser::WHEN); - setState(792); + setState(788); antlrcpp::downCast(_localctx)->whenExpr = columnExpr(0); - setState(793); + setState(789); match(HogQLParser::THEN); - setState(794); + setState(790); antlrcpp::downCast(_localctx)->thenExpr = columnExpr(0); - setState(798); + setState(794); _errHandler->sync(this); _la = _input->LA(1); } while (_la == HogQLParser::WHEN); - setState(802); + setState(798); _errHandler->sync(this); _la = _input->LA(1); if (_la == HogQLParser::ELSE) { - setState(800); + setState(796); match(HogQLParser::ELSE); - setState(801); + setState(797); antlrcpp::downCast(_localctx)->elseExpr = columnExpr(0); } - setState(804); + setState(800); match(HogQLParser::END); break; } @@ -7827,17 +7865,17 @@ HogQLParser::ColumnExprContext* HogQLParser::columnExpr(int precedence) { _localctx = _tracker.createInstance(_localctx); _ctx = _localctx; previousContext = _localctx; - setState(806); + setState(802); match(HogQLParser::CAST); - setState(807); + setState(803); match(HogQLParser::LPAREN); - setState(808); + setState(804); columnExpr(0); - setState(809); + setState(805); match(HogQLParser::AS); - setState(810); + setState(806); columnTypeExpr(); - setState(811); + setState(807); match(HogQLParser::RPAREN); break; } @@ -7846,9 +7884,9 @@ HogQLParser::ColumnExprContext* HogQLParser::columnExpr(int precedence) { _localctx = _tracker.createInstance(_localctx); _ctx = _localctx; previousContext = _localctx; - setState(813); + setState(809); match(HogQLParser::DATE); - setState(814); + setState(810); match(HogQLParser::STRING_LITERAL); break; } @@ -7857,11 +7895,11 @@ HogQLParser::ColumnExprContext* HogQLParser::columnExpr(int precedence) { _localctx = _tracker.createInstance(_localctx); _ctx = _localctx; previousContext = _localctx; - setState(815); + setState(811); match(HogQLParser::INTERVAL); - setState(816); + setState(812); columnExpr(0); - setState(817); + setState(813); interval(); break; } @@ -7870,27 +7908,27 @@ HogQLParser::ColumnExprContext* HogQLParser::columnExpr(int precedence) { _localctx = _tracker.createInstance(_localctx); _ctx = _localctx; previousContext = _localctx; - setState(819); + setState(815); match(HogQLParser::SUBSTRING); - setState(820); + setState(816); match(HogQLParser::LPAREN); - setState(821); + setState(817); columnExpr(0); - setState(822); + setState(818); match(HogQLParser::FROM); - setState(823); + setState(819); columnExpr(0); - setState(826); + setState(822); _errHandler->sync(this); _la = _input->LA(1); if (_la == HogQLParser::FOR) { - setState(824); + setState(820); match(HogQLParser::FOR); - setState(825); + setState(821); columnExpr(0); } - setState(828); + setState(824); match(HogQLParser::RPAREN); break; } @@ -7899,9 +7937,9 @@ HogQLParser::ColumnExprContext* HogQLParser::columnExpr(int precedence) { _localctx = _tracker.createInstance(_localctx); _ctx = _localctx; previousContext = _localctx; - setState(830); + setState(826); match(HogQLParser::TIMESTAMP); - setState(831); + setState(827); match(HogQLParser::STRING_LITERAL); break; } @@ -7910,11 +7948,11 @@ HogQLParser::ColumnExprContext* HogQLParser::columnExpr(int precedence) { _localctx = _tracker.createInstance(_localctx); _ctx = _localctx; previousContext = _localctx; - setState(832); + setState(828); match(HogQLParser::TRIM); - setState(833); + setState(829); match(HogQLParser::LPAREN); - setState(834); + setState(830); _la = _input->LA(1); if (!(_la == HogQLParser::BOTH @@ -7925,13 +7963,13 @@ HogQLParser::ColumnExprContext* HogQLParser::columnExpr(int precedence) { _errHandler->reportMatch(this); consume(); } - setState(835); + setState(831); string(); - setState(836); + setState(832); match(HogQLParser::FROM); - setState(837); + setState(833); columnExpr(0); - setState(838); + setState(834); match(HogQLParser::RPAREN); break; } @@ -7940,12 +7978,12 @@ HogQLParser::ColumnExprContext* HogQLParser::columnExpr(int precedence) { _localctx = _tracker.createInstance(_localctx); _ctx = _localctx; previousContext = _localctx; - setState(840); + setState(836); identifier(); - setState(841); + setState(837); match(HogQLParser::LPAREN); - setState(843); + setState(839); _errHandler->sync(this); _la = _input->LA(1); @@ -7953,24 +7991,24 @@ HogQLParser::ColumnExprContext* HogQLParser::columnExpr(int precedence) { ((1ULL << _la) & -4503602311741442) != 0) || ((((_la - 64) & ~ 0x3fULL) == 0) && ((1ULL << (_la - 64)) & 90493036243451903) != 0) || ((((_la - 128) & ~ 0x3fULL) == 0) && ((1ULL << (_la - 128)) & 18455) != 0)) { - setState(842); - columnExprList(); + setState(838); + antlrcpp::downCast(_localctx)->columnExprs = columnExprList(); } - setState(845); + setState(841); match(HogQLParser::RPAREN); - setState(855); + setState(851); _errHandler->sync(this); _la = _input->LA(1); if (_la == HogQLParser::LPAREN) { - setState(847); + setState(843); match(HogQLParser::LPAREN); - setState(849); + setState(845); _errHandler->sync(this); switch (getInterpreter()->adaptivePredict(_input, 104, _ctx)) { case 1: { - setState(848); + setState(844); match(HogQLParser::DISTINCT); break; } @@ -7978,7 +8016,7 @@ HogQLParser::ColumnExprContext* HogQLParser::columnExpr(int precedence) { default: break; } - setState(852); + setState(848); _errHandler->sync(this); _la = _input->LA(1); @@ -7986,19 +8024,19 @@ HogQLParser::ColumnExprContext* HogQLParser::columnExpr(int precedence) { ((1ULL << _la) & -4503602311741442) != 0) || ((((_la - 64) & ~ 0x3fULL) == 0) && ((1ULL << (_la - 64)) & 90493036243451903) != 0) || ((((_la - 128) & ~ 0x3fULL) == 0) && ((1ULL << (_la - 128)) & 18455) != 0)) { - setState(851); - columnArgList(); + setState(847); + antlrcpp::downCast(_localctx)->columnArgList = columnExprList(); } - setState(854); + setState(850); match(HogQLParser::RPAREN); } - setState(857); + setState(853); match(HogQLParser::OVER); - setState(858); + setState(854); match(HogQLParser::LPAREN); - setState(859); + setState(855); windowExpr(); - setState(860); + setState(856); match(HogQLParser::RPAREN); break; } @@ -8007,12 +8045,12 @@ HogQLParser::ColumnExprContext* HogQLParser::columnExpr(int precedence) { _localctx = _tracker.createInstance(_localctx); _ctx = _localctx; previousContext = _localctx; - setState(862); + setState(858); identifier(); - setState(863); + setState(859); match(HogQLParser::LPAREN); - setState(865); + setState(861); _errHandler->sync(this); _la = _input->LA(1); @@ -8020,24 +8058,24 @@ HogQLParser::ColumnExprContext* HogQLParser::columnExpr(int precedence) { ((1ULL << _la) & -4503602311741442) != 0) || ((((_la - 64) & ~ 0x3fULL) == 0) && ((1ULL << (_la - 64)) & 90493036243451903) != 0) || ((((_la - 128) & ~ 0x3fULL) == 0) && ((1ULL << (_la - 128)) & 18455) != 0)) { - setState(864); - columnExprList(); + setState(860); + antlrcpp::downCast(_localctx)->columnExprs = columnExprList(); } - setState(867); + setState(863); match(HogQLParser::RPAREN); - setState(877); + setState(873); _errHandler->sync(this); _la = _input->LA(1); if (_la == HogQLParser::LPAREN) { - setState(869); + setState(865); match(HogQLParser::LPAREN); - setState(871); + setState(867); _errHandler->sync(this); switch (getInterpreter()->adaptivePredict(_input, 108, _ctx)) { case 1: { - setState(870); + setState(866); match(HogQLParser::DISTINCT); break; } @@ -8045,7 +8083,7 @@ HogQLParser::ColumnExprContext* HogQLParser::columnExpr(int precedence) { default: break; } - setState(874); + setState(870); _errHandler->sync(this); _la = _input->LA(1); @@ -8053,15 +8091,15 @@ HogQLParser::ColumnExprContext* HogQLParser::columnExpr(int precedence) { ((1ULL << _la) & -4503602311741442) != 0) || ((((_la - 64) & ~ 0x3fULL) == 0) && ((1ULL << (_la - 64)) & 90493036243451903) != 0) || ((((_la - 128) & ~ 0x3fULL) == 0) && ((1ULL << (_la - 128)) & 18455) != 0)) { - setState(873); - columnArgList(); + setState(869); + antlrcpp::downCast(_localctx)->columnArgList = columnExprList(); } - setState(876); + setState(872); match(HogQLParser::RPAREN); } - setState(879); + setState(875); match(HogQLParser::OVER); - setState(880); + setState(876); identifier(); break; } @@ -8070,16 +8108,16 @@ HogQLParser::ColumnExprContext* HogQLParser::columnExpr(int precedence) { _localctx = _tracker.createInstance(_localctx); _ctx = _localctx; previousContext = _localctx; - setState(882); + setState(878); identifier(); - setState(888); + setState(884); _errHandler->sync(this); switch (getInterpreter()->adaptivePredict(_input, 112, _ctx)) { case 1: { - setState(883); + setState(879); match(HogQLParser::LPAREN); - setState(885); + setState(881); _errHandler->sync(this); _la = _input->LA(1); @@ -8087,10 +8125,10 @@ HogQLParser::ColumnExprContext* HogQLParser::columnExpr(int precedence) { ((1ULL << _la) & -4503602311741442) != 0) || ((((_la - 64) & ~ 0x3fULL) == 0) && ((1ULL << (_la - 64)) & 90493036243451903) != 0) || ((((_la - 128) & ~ 0x3fULL) == 0) && ((1ULL << (_la - 128)) & 18455) != 0)) { - setState(884); - columnExprList(); + setState(880); + antlrcpp::downCast(_localctx)->columnExprs = columnExprList(); } - setState(887); + setState(883); match(HogQLParser::RPAREN); break; } @@ -8098,14 +8136,14 @@ HogQLParser::ColumnExprContext* HogQLParser::columnExpr(int precedence) { default: break; } - setState(890); + setState(886); match(HogQLParser::LPAREN); - setState(892); + setState(888); _errHandler->sync(this); switch (getInterpreter()->adaptivePredict(_input, 113, _ctx)) { case 1: { - setState(891); + setState(887); match(HogQLParser::DISTINCT); break; } @@ -8113,7 +8151,7 @@ HogQLParser::ColumnExprContext* HogQLParser::columnExpr(int precedence) { default: break; } - setState(895); + setState(891); _errHandler->sync(this); _la = _input->LA(1); @@ -8121,10 +8159,10 @@ HogQLParser::ColumnExprContext* HogQLParser::columnExpr(int precedence) { ((1ULL << _la) & -4503602311741442) != 0) || ((((_la - 64) & ~ 0x3fULL) == 0) && ((1ULL << (_la - 64)) & 90493036243451903) != 0) || ((((_la - 128) & ~ 0x3fULL) == 0) && ((1ULL << (_la - 128)) & 18455) != 0)) { - setState(894); - columnArgList(); + setState(890); + antlrcpp::downCast(_localctx)->columnArgList = columnExprList(); } - setState(897); + setState(893); match(HogQLParser::RPAREN); break; } @@ -8133,7 +8171,7 @@ HogQLParser::ColumnExprContext* HogQLParser::columnExpr(int precedence) { _localctx = _tracker.createInstance(_localctx); _ctx = _localctx; previousContext = _localctx; - setState(899); + setState(895); hogqlxTagElement(); break; } @@ -8142,7 +8180,7 @@ HogQLParser::ColumnExprContext* HogQLParser::columnExpr(int precedence) { _localctx = _tracker.createInstance(_localctx); _ctx = _localctx; previousContext = _localctx; - setState(900); + setState(896); templateString(); break; } @@ -8151,7 +8189,7 @@ HogQLParser::ColumnExprContext* HogQLParser::columnExpr(int precedence) { _localctx = _tracker.createInstance(_localctx); _ctx = _localctx; previousContext = _localctx; - setState(901); + setState(897); literal(); break; } @@ -8160,10 +8198,10 @@ HogQLParser::ColumnExprContext* HogQLParser::columnExpr(int precedence) { _localctx = _tracker.createInstance(_localctx); _ctx = _localctx; previousContext = _localctx; - setState(902); + setState(898); match(HogQLParser::DASH); - setState(903); - columnExpr(19); + setState(899); + columnExpr(20); break; } @@ -8171,10 +8209,10 @@ HogQLParser::ColumnExprContext* HogQLParser::columnExpr(int precedence) { _localctx = _tracker.createInstance(_localctx); _ctx = _localctx; previousContext = _localctx; - setState(904); + setState(900); match(HogQLParser::NOT); - setState(905); - columnExpr(13); + setState(901); + columnExpr(14); break; } @@ -8182,19 +8220,19 @@ HogQLParser::ColumnExprContext* HogQLParser::columnExpr(int precedence) { _localctx = _tracker.createInstance(_localctx); _ctx = _localctx; previousContext = _localctx; - setState(909); + setState(905); _errHandler->sync(this); _la = _input->LA(1); if ((((_la & ~ 0x3fULL) == 0) && ((1ULL << _la) & -725088338784043010) != 0) || ((((_la - 64) & ~ 0x3fULL) == 0) && ((1ULL << (_la - 64)) & 3229277487103) != 0)) { - setState(906); + setState(902); tableIdentifier(); - setState(907); + setState(903); match(HogQLParser::DOT); } - setState(911); + setState(907); match(HogQLParser::ASTERISK); break; } @@ -8203,11 +8241,11 @@ HogQLParser::ColumnExprContext* HogQLParser::columnExpr(int precedence) { _localctx = _tracker.createInstance(_localctx); _ctx = _localctx; previousContext = _localctx; - setState(912); + setState(908); match(HogQLParser::LPAREN); - setState(913); + setState(909); selectUnionStmt(); - setState(914); + setState(910); match(HogQLParser::RPAREN); break; } @@ -8216,11 +8254,11 @@ HogQLParser::ColumnExprContext* HogQLParser::columnExpr(int precedence) { _localctx = _tracker.createInstance(_localctx); _ctx = _localctx; previousContext = _localctx; - setState(916); + setState(912); match(HogQLParser::LPAREN); - setState(917); + setState(913); columnExpr(0); - setState(918); + setState(914); match(HogQLParser::RPAREN); break; } @@ -8229,11 +8267,11 @@ HogQLParser::ColumnExprContext* HogQLParser::columnExpr(int precedence) { _localctx = _tracker.createInstance(_localctx); _ctx = _localctx; previousContext = _localctx; - setState(920); + setState(916); match(HogQLParser::LPAREN); - setState(921); + setState(917); columnExprList(); - setState(922); + setState(918); match(HogQLParser::RPAREN); break; } @@ -8242,9 +8280,9 @@ HogQLParser::ColumnExprContext* HogQLParser::columnExpr(int precedence) { _localctx = _tracker.createInstance(_localctx); _ctx = _localctx; previousContext = _localctx; - setState(924); + setState(920); match(HogQLParser::LBRACKET); - setState(926); + setState(922); _errHandler->sync(this); _la = _input->LA(1); @@ -8252,10 +8290,10 @@ HogQLParser::ColumnExprContext* HogQLParser::columnExpr(int precedence) { ((1ULL << _la) & -4503602311741442) != 0) || ((((_la - 64) & ~ 0x3fULL) == 0) && ((1ULL << (_la - 64)) & 90493036243451903) != 0) || ((((_la - 128) & ~ 0x3fULL) == 0) && ((1ULL << (_la - 128)) & 18455) != 0)) { - setState(925); + setState(921); columnExprList(); } - setState(928); + setState(924); match(HogQLParser::RBRACKET); break; } @@ -8264,9 +8302,9 @@ HogQLParser::ColumnExprContext* HogQLParser::columnExpr(int precedence) { _localctx = _tracker.createInstance(_localctx); _ctx = _localctx; previousContext = _localctx; - setState(929); + setState(925); match(HogQLParser::LBRACE); - setState(931); + setState(927); _errHandler->sync(this); _la = _input->LA(1); @@ -8274,19 +8312,28 @@ HogQLParser::ColumnExprContext* HogQLParser::columnExpr(int precedence) { ((1ULL << _la) & -4503602311741442) != 0) || ((((_la - 64) & ~ 0x3fULL) == 0) && ((1ULL << (_la - 64)) & 90493036243451903) != 0) || ((((_la - 128) & ~ 0x3fULL) == 0) && ((1ULL << (_la - 128)) & 18455) != 0)) { - setState(930); + setState(926); kvPairList(); } - setState(933); + setState(929); match(HogQLParser::RBRACE); break; } case 22: { + _localctx = _tracker.createInstance(_localctx); + _ctx = _localctx; + previousContext = _localctx; + setState(930); + columnLambdaExpr(); + break; + } + + case 23: { _localctx = _tracker.createInstance(_localctx); _ctx = _localctx; previousContext = _localctx; - setState(934); + setState(931); columnIdentifier(); break; } @@ -8295,42 +8342,42 @@ HogQLParser::ColumnExprContext* HogQLParser::columnExpr(int precedence) { break; } _ctx->stop = _input->LT(-1); - setState(1041); + setState(1044); _errHandler->sync(this); - alt = getInterpreter()->adaptivePredict(_input, 129, _ctx); + alt = getInterpreter()->adaptivePredict(_input, 130, _ctx); while (alt != 2 && alt != atn::ATN::INVALID_ALT_NUMBER) { if (alt == 1) { if (!_parseListeners.empty()) triggerExitRuleEvent(); previousContext = _localctx; - setState(1039); + setState(1042); _errHandler->sync(this); - switch (getInterpreter()->adaptivePredict(_input, 128, _ctx)) { + switch (getInterpreter()->adaptivePredict(_input, 129, _ctx)) { case 1: { auto newContext = _tracker.createInstance(_tracker.createInstance(parentContext, parentState)); _localctx = newContext; newContext->left = previousContext; pushNewRecursionContext(newContext, startState, RuleColumnExpr); - setState(937); + setState(934); - if (!(precpred(_ctx, 18))) throw FailedPredicateException(this, "precpred(_ctx, 18)"); - setState(941); + if (!(precpred(_ctx, 19))) throw FailedPredicateException(this, "precpred(_ctx, 19)"); + setState(938); _errHandler->sync(this); switch (_input->LA(1)) { case HogQLParser::ASTERISK: { - setState(938); + setState(935); antlrcpp::downCast(_localctx)->operator_ = match(HogQLParser::ASTERISK); break; } case HogQLParser::SLASH: { - setState(939); + setState(936); antlrcpp::downCast(_localctx)->operator_ = match(HogQLParser::SLASH); break; } case HogQLParser::PERCENT: { - setState(940); + setState(937); antlrcpp::downCast(_localctx)->operator_ = match(HogQLParser::PERCENT); break; } @@ -8338,8 +8385,8 @@ HogQLParser::ColumnExprContext* HogQLParser::columnExpr(int precedence) { default: throw NoViableAltException(this); } - setState(943); - antlrcpp::downCast(_localctx)->right = columnExpr(19); + setState(940); + antlrcpp::downCast(_localctx)->right = columnExpr(20); break; } @@ -8348,26 +8395,26 @@ HogQLParser::ColumnExprContext* HogQLParser::columnExpr(int precedence) { _localctx = newContext; newContext->left = previousContext; pushNewRecursionContext(newContext, startState, RuleColumnExpr); - setState(944); + setState(941); - if (!(precpred(_ctx, 17))) throw FailedPredicateException(this, "precpred(_ctx, 17)"); - setState(948); + if (!(precpred(_ctx, 18))) throw FailedPredicateException(this, "precpred(_ctx, 18)"); + setState(945); _errHandler->sync(this); switch (_input->LA(1)) { case HogQLParser::PLUS: { - setState(945); + setState(942); antlrcpp::downCast(_localctx)->operator_ = match(HogQLParser::PLUS); break; } case HogQLParser::DASH: { - setState(946); + setState(943); antlrcpp::downCast(_localctx)->operator_ = match(HogQLParser::DASH); break; } case HogQLParser::CONCAT: { - setState(947); + setState(944); antlrcpp::downCast(_localctx)->operator_ = match(HogQLParser::CONCAT); break; } @@ -8375,8 +8422,8 @@ HogQLParser::ColumnExprContext* HogQLParser::columnExpr(int precedence) { default: throw NoViableAltException(this); } - setState(950); - antlrcpp::downCast(_localctx)->right = columnExpr(18); + setState(947); + antlrcpp::downCast(_localctx)->right = columnExpr(19); break; } @@ -8385,71 +8432,71 @@ HogQLParser::ColumnExprContext* HogQLParser::columnExpr(int precedence) { _localctx = newContext; newContext->left = previousContext; pushNewRecursionContext(newContext, startState, RuleColumnExpr); - setState(951); + setState(948); - if (!(precpred(_ctx, 16))) throw FailedPredicateException(this, "precpred(_ctx, 16)"); - setState(976); + if (!(precpred(_ctx, 17))) throw FailedPredicateException(this, "precpred(_ctx, 17)"); + setState(973); _errHandler->sync(this); switch (getInterpreter()->adaptivePredict(_input, 124, _ctx)) { case 1: { - setState(952); + setState(949); antlrcpp::downCast(_localctx)->operator_ = match(HogQLParser::EQ_DOUBLE); break; } case 2: { - setState(953); + setState(950); antlrcpp::downCast(_localctx)->operator_ = match(HogQLParser::EQ_SINGLE); break; } case 3: { - setState(954); + setState(951); antlrcpp::downCast(_localctx)->operator_ = match(HogQLParser::NOT_EQ); break; } case 4: { - setState(955); + setState(952); antlrcpp::downCast(_localctx)->operator_ = match(HogQLParser::LT_EQ); break; } case 5: { - setState(956); + setState(953); antlrcpp::downCast(_localctx)->operator_ = match(HogQLParser::LT); break; } case 6: { - setState(957); + setState(954); antlrcpp::downCast(_localctx)->operator_ = match(HogQLParser::GT_EQ); break; } case 7: { - setState(958); + setState(955); antlrcpp::downCast(_localctx)->operator_ = match(HogQLParser::GT); break; } case 8: { - setState(960); + setState(957); _errHandler->sync(this); _la = _input->LA(1); if (_la == HogQLParser::NOT) { - setState(959); + setState(956); antlrcpp::downCast(_localctx)->operator_ = match(HogQLParser::NOT); } - setState(962); + setState(959); match(HogQLParser::IN); - setState(964); + setState(961); _errHandler->sync(this); switch (getInterpreter()->adaptivePredict(_input, 122, _ctx)) { case 1: { - setState(963); + setState(960); match(HogQLParser::COHORT); break; } @@ -8461,15 +8508,15 @@ HogQLParser::ColumnExprContext* HogQLParser::columnExpr(int precedence) { } case 9: { - setState(967); + setState(964); _errHandler->sync(this); _la = _input->LA(1); if (_la == HogQLParser::NOT) { - setState(966); + setState(963); antlrcpp::downCast(_localctx)->operator_ = match(HogQLParser::NOT); } - setState(969); + setState(966); _la = _input->LA(1); if (!(_la == HogQLParser::ILIKE @@ -8484,37 +8531,37 @@ HogQLParser::ColumnExprContext* HogQLParser::columnExpr(int precedence) { } case 10: { - setState(970); + setState(967); antlrcpp::downCast(_localctx)->operator_ = match(HogQLParser::REGEX_SINGLE); break; } case 11: { - setState(971); + setState(968); antlrcpp::downCast(_localctx)->operator_ = match(HogQLParser::REGEX_DOUBLE); break; } case 12: { - setState(972); + setState(969); antlrcpp::downCast(_localctx)->operator_ = match(HogQLParser::NOT_REGEX); break; } case 13: { - setState(973); + setState(970); antlrcpp::downCast(_localctx)->operator_ = match(HogQLParser::IREGEX_SINGLE); break; } case 14: { - setState(974); + setState(971); antlrcpp::downCast(_localctx)->operator_ = match(HogQLParser::IREGEX_DOUBLE); break; } case 15: { - setState(975); + setState(972); antlrcpp::downCast(_localctx)->operator_ = match(HogQLParser::NOT_IREGEX); break; } @@ -8522,8 +8569,8 @@ HogQLParser::ColumnExprContext* HogQLParser::columnExpr(int precedence) { default: break; } - setState(978); - antlrcpp::downCast(_localctx)->right = columnExpr(17); + setState(975); + antlrcpp::downCast(_localctx)->right = columnExpr(18); break; } @@ -8531,13 +8578,13 @@ HogQLParser::ColumnExprContext* HogQLParser::columnExpr(int precedence) { auto newContext = _tracker.createInstance(_tracker.createInstance(parentContext, parentState)); _localctx = newContext; pushNewRecursionContext(newContext, startState, RuleColumnExpr); - setState(979); + setState(976); - if (!(precpred(_ctx, 14))) throw FailedPredicateException(this, "precpred(_ctx, 14)"); - setState(980); + if (!(precpred(_ctx, 15))) throw FailedPredicateException(this, "precpred(_ctx, 15)"); + setState(977); match(HogQLParser::NULLISH); - setState(981); - columnExpr(15); + setState(978); + columnExpr(16); break; } @@ -8545,13 +8592,13 @@ HogQLParser::ColumnExprContext* HogQLParser::columnExpr(int precedence) { auto newContext = _tracker.createInstance(_tracker.createInstance(parentContext, parentState)); _localctx = newContext; pushNewRecursionContext(newContext, startState, RuleColumnExpr); - setState(982); + setState(979); - if (!(precpred(_ctx, 12))) throw FailedPredicateException(this, "precpred(_ctx, 12)"); - setState(983); + if (!(precpred(_ctx, 13))) throw FailedPredicateException(this, "precpred(_ctx, 13)"); + setState(980); match(HogQLParser::AND); - setState(984); - columnExpr(13); + setState(981); + columnExpr(14); break; } @@ -8559,13 +8606,13 @@ HogQLParser::ColumnExprContext* HogQLParser::columnExpr(int precedence) { auto newContext = _tracker.createInstance(_tracker.createInstance(parentContext, parentState)); _localctx = newContext; pushNewRecursionContext(newContext, startState, RuleColumnExpr); - setState(985); + setState(982); - if (!(precpred(_ctx, 11))) throw FailedPredicateException(this, "precpred(_ctx, 11)"); - setState(986); + if (!(precpred(_ctx, 12))) throw FailedPredicateException(this, "precpred(_ctx, 12)"); + setState(983); match(HogQLParser::OR); - setState(987); - columnExpr(12); + setState(984); + columnExpr(13); break; } @@ -8573,25 +8620,25 @@ HogQLParser::ColumnExprContext* HogQLParser::columnExpr(int precedence) { auto newContext = _tracker.createInstance(_tracker.createInstance(parentContext, parentState)); _localctx = newContext; pushNewRecursionContext(newContext, startState, RuleColumnExpr); - setState(988); + setState(985); - if (!(precpred(_ctx, 10))) throw FailedPredicateException(this, "precpred(_ctx, 10)"); - setState(990); + if (!(precpred(_ctx, 11))) throw FailedPredicateException(this, "precpred(_ctx, 11)"); + setState(987); _errHandler->sync(this); _la = _input->LA(1); if (_la == HogQLParser::NOT) { - setState(989); + setState(986); match(HogQLParser::NOT); } - setState(992); + setState(989); match(HogQLParser::BETWEEN); - setState(993); + setState(990); columnExpr(0); - setState(994); + setState(991); match(HogQLParser::AND); - setState(995); - columnExpr(11); + setState(992); + columnExpr(12); break; } @@ -8599,333 +8646,203 @@ HogQLParser::ColumnExprContext* HogQLParser::columnExpr(int precedence) { auto newContext = _tracker.createInstance(_tracker.createInstance(parentContext, parentState)); _localctx = newContext; pushNewRecursionContext(newContext, startState, RuleColumnExpr); - setState(997); + setState(994); - if (!(precpred(_ctx, 9))) throw FailedPredicateException(this, "precpred(_ctx, 9)"); - setState(998); + if (!(precpred(_ctx, 10))) throw FailedPredicateException(this, "precpred(_ctx, 10)"); + setState(995); match(HogQLParser::QUERY); - setState(999); + setState(996); columnExpr(0); - setState(1000); + setState(997); match(HogQLParser::COLON); - setState(1001); - columnExpr(9); + setState(998); + columnExpr(10); break; } case 9: { - auto newContext = _tracker.createInstance(_tracker.createInstance(parentContext, parentState)); + auto newContext = _tracker.createInstance(_tracker.createInstance(parentContext, parentState)); _localctx = newContext; pushNewRecursionContext(newContext, startState, RuleColumnExpr); + setState(1000); + + if (!(precpred(_ctx, 30))) throw FailedPredicateException(this, "precpred(_ctx, 30)"); + setState(1001); + match(HogQLParser::LPAREN); setState(1003); + _errHandler->sync(this); - if (!(precpred(_ctx, 25))) throw FailedPredicateException(this, "precpred(_ctx, 25)"); - setState(1004); - match(HogQLParser::LBRACKET); + _la = _input->LA(1); + if ((((_la & ~ 0x3fULL) == 0) && + ((1ULL << _la) & -4503602311741442) != 0) || ((((_la - 64) & ~ 0x3fULL) == 0) && + ((1ULL << (_la - 64)) & 90493036243451903) != 0) || ((((_la - 128) & ~ 0x3fULL) == 0) && + ((1ULL << (_la - 128)) & 18455) != 0)) { + setState(1002); + columnExprList(); + } setState(1005); - columnExpr(0); - setState(1006); - match(HogQLParser::RBRACKET); + match(HogQLParser::RPAREN); break; } case 10: { - auto newContext = _tracker.createInstance(_tracker.createInstance(parentContext, parentState)); + auto newContext = _tracker.createInstance(_tracker.createInstance(parentContext, parentState)); _localctx = newContext; pushNewRecursionContext(newContext, startState, RuleColumnExpr); - setState(1008); + setState(1006); - if (!(precpred(_ctx, 24))) throw FailedPredicateException(this, "precpred(_ctx, 24)"); + if (!(precpred(_ctx, 26))) throw FailedPredicateException(this, "precpred(_ctx, 26)"); + setState(1007); + match(HogQLParser::LBRACKET); + setState(1008); + columnExpr(0); setState(1009); - match(HogQLParser::DOT); - setState(1010); - match(HogQLParser::DECIMAL_LITERAL); + match(HogQLParser::RBRACKET); break; } case 11: { - auto newContext = _tracker.createInstance(_tracker.createInstance(parentContext, parentState)); + auto newContext = _tracker.createInstance(_tracker.createInstance(parentContext, parentState)); _localctx = newContext; pushNewRecursionContext(newContext, startState, RuleColumnExpr); setState(1011); - if (!(precpred(_ctx, 23))) throw FailedPredicateException(this, "precpred(_ctx, 23)"); + if (!(precpred(_ctx, 25))) throw FailedPredicateException(this, "precpred(_ctx, 25)"); setState(1012); match(HogQLParser::DOT); setState(1013); - identifier(); + match(HogQLParser::DECIMAL_LITERAL); break; } case 12: { - auto newContext = _tracker.createInstance(_tracker.createInstance(parentContext, parentState)); + auto newContext = _tracker.createInstance(_tracker.createInstance(parentContext, parentState)); _localctx = newContext; pushNewRecursionContext(newContext, startState, RuleColumnExpr); setState(1014); - if (!(precpred(_ctx, 22))) throw FailedPredicateException(this, "precpred(_ctx, 22)"); + if (!(precpred(_ctx, 24))) throw FailedPredicateException(this, "precpred(_ctx, 24)"); setState(1015); - match(HogQLParser::NULL_PROPERTY); + match(HogQLParser::DOT); setState(1016); - match(HogQLParser::LBRACKET); - setState(1017); - columnExpr(0); - setState(1018); - match(HogQLParser::RBRACKET); + identifier(); break; } case 13: { - auto newContext = _tracker.createInstance(_tracker.createInstance(parentContext, parentState)); + auto newContext = _tracker.createInstance(_tracker.createInstance(parentContext, parentState)); _localctx = newContext; pushNewRecursionContext(newContext, startState, RuleColumnExpr); - setState(1020); + setState(1017); - if (!(precpred(_ctx, 21))) throw FailedPredicateException(this, "precpred(_ctx, 21)"); - setState(1021); + if (!(precpred(_ctx, 23))) throw FailedPredicateException(this, "precpred(_ctx, 23)"); + setState(1018); match(HogQLParser::NULL_PROPERTY); - setState(1022); - match(HogQLParser::DECIMAL_LITERAL); + setState(1019); + match(HogQLParser::LBRACKET); + setState(1020); + columnExpr(0); + setState(1021); + match(HogQLParser::RBRACKET); break; } case 14: { - auto newContext = _tracker.createInstance(_tracker.createInstance(parentContext, parentState)); + auto newContext = _tracker.createInstance(_tracker.createInstance(parentContext, parentState)); _localctx = newContext; pushNewRecursionContext(newContext, startState, RuleColumnExpr); setState(1023); - if (!(precpred(_ctx, 20))) throw FailedPredicateException(this, "precpred(_ctx, 20)"); + if (!(precpred(_ctx, 22))) throw FailedPredicateException(this, "precpred(_ctx, 22)"); setState(1024); match(HogQLParser::NULL_PROPERTY); setState(1025); - identifier(); + match(HogQLParser::DECIMAL_LITERAL); break; } case 15: { - auto newContext = _tracker.createInstance(_tracker.createInstance(parentContext, parentState)); + auto newContext = _tracker.createInstance(_tracker.createInstance(parentContext, parentState)); _localctx = newContext; pushNewRecursionContext(newContext, startState, RuleColumnExpr); setState(1026); - if (!(precpred(_ctx, 15))) throw FailedPredicateException(this, "precpred(_ctx, 15)"); + if (!(precpred(_ctx, 21))) throw FailedPredicateException(this, "precpred(_ctx, 21)"); setState(1027); - match(HogQLParser::IS); + match(HogQLParser::NULL_PROPERTY); + setState(1028); + identifier(); + break; + } + + case 16: { + auto newContext = _tracker.createInstance(_tracker.createInstance(parentContext, parentState)); + _localctx = newContext; + pushNewRecursionContext(newContext, startState, RuleColumnExpr); setState(1029); + + if (!(precpred(_ctx, 16))) throw FailedPredicateException(this, "precpred(_ctx, 16)"); + setState(1030); + match(HogQLParser::IS); + setState(1032); _errHandler->sync(this); _la = _input->LA(1); if (_la == HogQLParser::NOT) { - setState(1028); + setState(1031); match(HogQLParser::NOT); } - setState(1031); + setState(1034); match(HogQLParser::NULL_SQL); break; } - case 16: { + case 17: { auto newContext = _tracker.createInstance(_tracker.createInstance(parentContext, parentState)); _localctx = newContext; pushNewRecursionContext(newContext, startState, RuleColumnExpr); - setState(1032); + setState(1035); - if (!(precpred(_ctx, 8))) throw FailedPredicateException(this, "precpred(_ctx, 8)"); - setState(1037); + if (!(precpred(_ctx, 9))) throw FailedPredicateException(this, "precpred(_ctx, 9)"); + setState(1040); _errHandler->sync(this); - switch (getInterpreter()->adaptivePredict(_input, 127, _ctx)) { + switch (getInterpreter()->adaptivePredict(_input, 128, _ctx)) { case 1: { - setState(1033); - match(HogQLParser::AS); - setState(1034); - identifier(); - break; - } - - case 2: { - setState(1035); - match(HogQLParser::AS); setState(1036); - match(HogQLParser::STRING_LITERAL); - break; - } - - default: - break; - } - break; - } - - default: - break; - } - } - setState(1043); - _errHandler->sync(this); - alt = getInterpreter()->adaptivePredict(_input, 129, _ctx); - } - } - catch (RecognitionException &e) { - _errHandler->reportError(this, e); - _localctx->exception = std::current_exception(); - _errHandler->recover(this, _localctx->exception); - } - return _localctx; -} - -//----------------- ColumnArgListContext ------------------------------------------------------------------ - -HogQLParser::ColumnArgListContext::ColumnArgListContext(ParserRuleContext *parent, size_t invokingState) - : ParserRuleContext(parent, invokingState) { -} - -std::vector HogQLParser::ColumnArgListContext::columnArgExpr() { - return getRuleContexts(); -} - -HogQLParser::ColumnArgExprContext* HogQLParser::ColumnArgListContext::columnArgExpr(size_t i) { - return getRuleContext(i); -} - -std::vector HogQLParser::ColumnArgListContext::COMMA() { - return getTokens(HogQLParser::COMMA); -} - -tree::TerminalNode* HogQLParser::ColumnArgListContext::COMMA(size_t i) { - return getToken(HogQLParser::COMMA, i); -} - - -size_t HogQLParser::ColumnArgListContext::getRuleIndex() const { - return HogQLParser::RuleColumnArgList; -} - - -std::any HogQLParser::ColumnArgListContext::accept(tree::ParseTreeVisitor *visitor) { - if (auto parserVisitor = dynamic_cast(visitor)) - return parserVisitor->visitColumnArgList(this); - else - return visitor->visitChildren(this); -} - -HogQLParser::ColumnArgListContext* HogQLParser::columnArgList() { - ColumnArgListContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 118, HogQLParser::RuleColumnArgList); - size_t _la = 0; - -#if __cplusplus > 201703L - auto onExit = finally([=, this] { -#else - auto onExit = finally([=] { -#endif - exitRule(); - }); - try { - size_t alt; - enterOuterAlt(_localctx, 1); - setState(1044); - columnArgExpr(); - setState(1049); - _errHandler->sync(this); - alt = getInterpreter()->adaptivePredict(_input, 130, _ctx); - while (alt != 2 && alt != atn::ATN::INVALID_ALT_NUMBER) { - if (alt == 1) { - setState(1045); - match(HogQLParser::COMMA); - setState(1046); - columnArgExpr(); - } - setState(1051); - _errHandler->sync(this); - alt = getInterpreter()->adaptivePredict(_input, 130, _ctx); - } - setState(1053); - _errHandler->sync(this); - - _la = _input->LA(1); - if (_la == HogQLParser::COMMA) { - setState(1052); - match(HogQLParser::COMMA); - } - - } - catch (RecognitionException &e) { - _errHandler->reportError(this, e); - _localctx->exception = std::current_exception(); - _errHandler->recover(this, _localctx->exception); - } - - return _localctx; -} - -//----------------- ColumnArgExprContext ------------------------------------------------------------------ - -HogQLParser::ColumnArgExprContext::ColumnArgExprContext(ParserRuleContext *parent, size_t invokingState) - : ParserRuleContext(parent, invokingState) { -} - -HogQLParser::ColumnLambdaExprContext* HogQLParser::ColumnArgExprContext::columnLambdaExpr() { - return getRuleContext(0); -} - -HogQLParser::ColumnExprContext* HogQLParser::ColumnArgExprContext::columnExpr() { - return getRuleContext(0); -} - - -size_t HogQLParser::ColumnArgExprContext::getRuleIndex() const { - return HogQLParser::RuleColumnArgExpr; -} - - -std::any HogQLParser::ColumnArgExprContext::accept(tree::ParseTreeVisitor *visitor) { - if (auto parserVisitor = dynamic_cast(visitor)) - return parserVisitor->visitColumnArgExpr(this); - else - return visitor->visitChildren(this); -} - -HogQLParser::ColumnArgExprContext* HogQLParser::columnArgExpr() { - ColumnArgExprContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 120, HogQLParser::RuleColumnArgExpr); - -#if __cplusplus > 201703L - auto onExit = finally([=, this] { -#else - auto onExit = finally([=] { -#endif - exitRule(); - }); - try { - setState(1057); - _errHandler->sync(this); - switch (getInterpreter()->adaptivePredict(_input, 132, _ctx)) { - case 1: { - enterOuterAlt(_localctx, 1); - setState(1055); - columnLambdaExpr(); - break; - } + match(HogQLParser::AS); + setState(1037); + identifier(); + break; + } - case 2: { - enterOuterAlt(_localctx, 2); - setState(1056); - columnExpr(0); - break; - } + case 2: { + setState(1038); + match(HogQLParser::AS); + setState(1039); + match(HogQLParser::STRING_LITERAL); + break; + } - default: - break; + default: + break; + } + break; + } + + default: + break; + } + } + setState(1046); + _errHandler->sync(this); + alt = getInterpreter()->adaptivePredict(_input, 130, _ctx); } - } catch (RecognitionException &e) { _errHandler->reportError(this, e); _localctx->exception = std::current_exception(); _errHandler->recover(this, _localctx->exception); } - return _localctx; } @@ -8939,10 +8856,6 @@ tree::TerminalNode* HogQLParser::ColumnLambdaExprContext::ARROW() { return getToken(HogQLParser::ARROW, 0); } -HogQLParser::ColumnExprContext* HogQLParser::ColumnLambdaExprContext::columnExpr() { - return getRuleContext(0); -} - tree::TerminalNode* HogQLParser::ColumnLambdaExprContext::LPAREN() { return getToken(HogQLParser::LPAREN, 0); } @@ -8959,6 +8872,14 @@ tree::TerminalNode* HogQLParser::ColumnLambdaExprContext::RPAREN() { return getToken(HogQLParser::RPAREN, 0); } +HogQLParser::ColumnExprContext* HogQLParser::ColumnLambdaExprContext::columnExpr() { + return getRuleContext(0); +} + +HogQLParser::BlockContext* HogQLParser::ColumnLambdaExprContext::block() { + return getRuleContext(0); +} + std::vector HogQLParser::ColumnLambdaExprContext::COMMA() { return getTokens(HogQLParser::COMMA); } @@ -8982,7 +8903,7 @@ std::any HogQLParser::ColumnLambdaExprContext::accept(tree::ParseTreeVisitor *vi HogQLParser::ColumnLambdaExprContext* HogQLParser::columnLambdaExpr() { ColumnLambdaExprContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 122, HogQLParser::RuleColumnLambdaExpr); + enterRule(_localctx, 118, HogQLParser::RuleColumnLambdaExpr); size_t _la = 0; #if __cplusplus > 201703L @@ -8995,169 +8916,100 @@ HogQLParser::ColumnLambdaExprContext* HogQLParser::columnLambdaExpr() { try { size_t alt; enterOuterAlt(_localctx, 1); - setState(1084); + setState(1074); _errHandler->sync(this); - switch (_input->LA(1)) { - case HogQLParser::LPAREN: { - setState(1059); - match(HogQLParser::LPAREN); - setState(1060); - identifier(); - setState(1065); - _errHandler->sync(this); - alt = getInterpreter()->adaptivePredict(_input, 133, _ctx); - while (alt != 2 && alt != atn::ATN::INVALID_ALT_NUMBER) { - if (alt == 1) { - setState(1061); - match(HogQLParser::COMMA); - setState(1062); - identifier(); - } - setState(1067); - _errHandler->sync(this); - alt = getInterpreter()->adaptivePredict(_input, 133, _ctx); + switch (getInterpreter()->adaptivePredict(_input, 135, _ctx)) { + case 1: { + setState(1047); + match(HogQLParser::LPAREN); + setState(1048); + identifier(); + setState(1053); + _errHandler->sync(this); + alt = getInterpreter()->adaptivePredict(_input, 131, _ctx); + while (alt != 2 && alt != atn::ATN::INVALID_ALT_NUMBER) { + if (alt == 1) { + setState(1049); + match(HogQLParser::COMMA); + setState(1050); + identifier(); } - setState(1069); + setState(1055); _errHandler->sync(this); + alt = getInterpreter()->adaptivePredict(_input, 131, _ctx); + } + setState(1057); + _errHandler->sync(this); - _la = _input->LA(1); - if (_la == HogQLParser::COMMA) { - setState(1068); - match(HogQLParser::COMMA); - } - setState(1071); - match(HogQLParser::RPAREN); - break; + _la = _input->LA(1); + if (_la == HogQLParser::COMMA) { + setState(1056); + match(HogQLParser::COMMA); } + setState(1059); + match(HogQLParser::RPAREN); + break; + } - case HogQLParser::ALL: - case HogQLParser::AND: - case HogQLParser::ANTI: - case HogQLParser::ANY: - case HogQLParser::ARRAY: - case HogQLParser::AS: - case HogQLParser::ASCENDING: - case HogQLParser::ASOF: - case HogQLParser::BETWEEN: - case HogQLParser::BOTH: - case HogQLParser::BY: - case HogQLParser::CASE: - case HogQLParser::CAST: - case HogQLParser::COHORT: - case HogQLParser::COLLATE: - case HogQLParser::CROSS: - case HogQLParser::CUBE: - case HogQLParser::CURRENT: - case HogQLParser::DATE: - case HogQLParser::DAY: - case HogQLParser::DESC: - case HogQLParser::DESCENDING: - case HogQLParser::DISTINCT: - case HogQLParser::ELSE: - case HogQLParser::END: - case HogQLParser::EXTRACT: - case HogQLParser::FINAL: - case HogQLParser::FIRST: - case HogQLParser::FOLLOWING: - case HogQLParser::FOR: - case HogQLParser::FROM: - case HogQLParser::FULL: - case HogQLParser::GROUP: - case HogQLParser::HAVING: - case HogQLParser::HOUR: - case HogQLParser::ID: - case HogQLParser::IF: - case HogQLParser::ILIKE: - case HogQLParser::IN: - case HogQLParser::INNER: - case HogQLParser::INTERVAL: - case HogQLParser::IS: - case HogQLParser::JOIN: - case HogQLParser::KEY: - case HogQLParser::LAST: - case HogQLParser::LEADING: - case HogQLParser::LEFT: - case HogQLParser::LIKE: - case HogQLParser::LIMIT: - case HogQLParser::MINUTE: - case HogQLParser::MONTH: - case HogQLParser::NOT: - case HogQLParser::NULLS: - case HogQLParser::OFFSET: - case HogQLParser::ON: - case HogQLParser::OR: - case HogQLParser::ORDER: - case HogQLParser::OUTER: - case HogQLParser::OVER: - case HogQLParser::PARTITION: - case HogQLParser::PRECEDING: - case HogQLParser::PREWHERE: - case HogQLParser::QUARTER: - case HogQLParser::RANGE: - case HogQLParser::RETURN: - case HogQLParser::RIGHT: - case HogQLParser::ROLLUP: - case HogQLParser::ROW: - case HogQLParser::ROWS: - case HogQLParser::SAMPLE: - case HogQLParser::SECOND: - case HogQLParser::SELECT: - case HogQLParser::SEMI: - case HogQLParser::SETTINGS: - case HogQLParser::SUBSTRING: - case HogQLParser::THEN: - case HogQLParser::TIES: - case HogQLParser::TIMESTAMP: - case HogQLParser::TO: - case HogQLParser::TOP: - case HogQLParser::TOTALS: - case HogQLParser::TRAILING: - case HogQLParser::TRIM: - case HogQLParser::TRUNCATE: - case HogQLParser::UNBOUNDED: - case HogQLParser::UNION: - case HogQLParser::USING: - case HogQLParser::WEEK: - case HogQLParser::WHEN: - case HogQLParser::WHERE: - case HogQLParser::WINDOW: - case HogQLParser::WITH: - case HogQLParser::YEAR: - case HogQLParser::IDENTIFIER: { - setState(1073); - identifier(); - setState(1078); - _errHandler->sync(this); - alt = getInterpreter()->adaptivePredict(_input, 135, _ctx); - while (alt != 2 && alt != atn::ATN::INVALID_ALT_NUMBER) { - if (alt == 1) { - setState(1074); - match(HogQLParser::COMMA); - setState(1075); - identifier(); - } - setState(1080); - _errHandler->sync(this); - alt = getInterpreter()->adaptivePredict(_input, 135, _ctx); + case 2: { + setState(1061); + identifier(); + setState(1066); + _errHandler->sync(this); + alt = getInterpreter()->adaptivePredict(_input, 133, _ctx); + while (alt != 2 && alt != atn::ATN::INVALID_ALT_NUMBER) { + if (alt == 1) { + setState(1062); + match(HogQLParser::COMMA); + setState(1063); + identifier(); } - setState(1082); + setState(1068); _errHandler->sync(this); + alt = getInterpreter()->adaptivePredict(_input, 133, _ctx); + } + setState(1070); + _errHandler->sync(this); - _la = _input->LA(1); - if (_la == HogQLParser::COMMA) { - setState(1081); - match(HogQLParser::COMMA); - } - break; + _la = _input->LA(1); + if (_la == HogQLParser::COMMA) { + setState(1069); + match(HogQLParser::COMMA); } + break; + } + + case 3: { + setState(1072); + match(HogQLParser::LPAREN); + setState(1073); + match(HogQLParser::RPAREN); + break; + } default: - throw NoViableAltException(this); + break; } - setState(1086); + setState(1076); match(HogQLParser::ARROW); - setState(1087); - columnExpr(0); + setState(1079); + _errHandler->sync(this); + switch (getInterpreter()->adaptivePredict(_input, 136, _ctx)) { + case 1: { + setState(1077); + columnExpr(0); + break; + } + + case 2: { + setState(1078); + block(); + break; + } + + default: + break; + } } catch (RecognitionException &e) { @@ -9284,7 +9136,7 @@ std::any HogQLParser::HogqlxTagElementNestedContext::accept(tree::ParseTreeVisit } HogQLParser::HogqlxTagElementContext* HogQLParser::hogqlxTagElement() { HogqlxTagElementContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 124, HogQLParser::RuleHogqlxTagElement); + enterRule(_localctx, 120, HogQLParser::RuleHogqlxTagElement); size_t _la = 0; #if __cplusplus > 201703L @@ -9295,31 +9147,31 @@ HogQLParser::HogqlxTagElementContext* HogQLParser::hogqlxTagElement() { exitRule(); }); try { - setState(1121); + setState(1113); _errHandler->sync(this); - switch (getInterpreter()->adaptivePredict(_input, 141, _ctx)) { + switch (getInterpreter()->adaptivePredict(_input, 140, _ctx)) { case 1: { _localctx = _tracker.createInstance(_localctx); enterOuterAlt(_localctx, 1); - setState(1089); + setState(1081); match(HogQLParser::LT); - setState(1090); + setState(1082); identifier(); - setState(1094); + setState(1086); _errHandler->sync(this); _la = _input->LA(1); while ((((_la & ~ 0x3fULL) == 0) && ((1ULL << _la) & -725088338784043010) != 0) || ((((_la - 64) & ~ 0x3fULL) == 0) && ((1ULL << (_la - 64)) & 3229277487103) != 0)) { - setState(1091); + setState(1083); hogqlxTagAttribute(); - setState(1096); + setState(1088); _errHandler->sync(this); _la = _input->LA(1); } - setState(1097); + setState(1089); match(HogQLParser::SLASH); - setState(1098); + setState(1090); match(HogQLParser::GT); break; } @@ -9327,40 +9179,40 @@ HogQLParser::HogqlxTagElementContext* HogQLParser::hogqlxTagElement() { case 2: { _localctx = _tracker.createInstance(_localctx); enterOuterAlt(_localctx, 2); - setState(1100); + setState(1092); match(HogQLParser::LT); - setState(1101); + setState(1093); identifier(); - setState(1105); + setState(1097); _errHandler->sync(this); _la = _input->LA(1); while ((((_la & ~ 0x3fULL) == 0) && ((1ULL << _la) & -725088338784043010) != 0) || ((((_la - 64) & ~ 0x3fULL) == 0) && ((1ULL << (_la - 64)) & 3229277487103) != 0)) { - setState(1102); + setState(1094); hogqlxTagAttribute(); - setState(1107); + setState(1099); _errHandler->sync(this); _la = _input->LA(1); } - setState(1108); + setState(1100); match(HogQLParser::GT); - setState(1114); + setState(1106); _errHandler->sync(this); - switch (getInterpreter()->adaptivePredict(_input, 140, _ctx)) { + switch (getInterpreter()->adaptivePredict(_input, 139, _ctx)) { case 1: { - setState(1109); + setState(1101); hogqlxTagElement(); break; } case 2: { - setState(1110); + setState(1102); match(HogQLParser::LBRACE); - setState(1111); + setState(1103); columnExpr(0); - setState(1112); + setState(1104); match(HogQLParser::RBRACE); break; } @@ -9368,13 +9220,13 @@ HogQLParser::HogqlxTagElementContext* HogQLParser::hogqlxTagElement() { default: break; } - setState(1116); + setState(1108); match(HogQLParser::LT); - setState(1117); + setState(1109); match(HogQLParser::SLASH); - setState(1118); + setState(1110); identifier(); - setState(1119); + setState(1111); match(HogQLParser::GT); break; } @@ -9438,7 +9290,7 @@ std::any HogQLParser::HogqlxTagAttributeContext::accept(tree::ParseTreeVisitor * HogQLParser::HogqlxTagAttributeContext* HogQLParser::hogqlxTagAttribute() { HogqlxTagAttributeContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 126, HogQLParser::RuleHogqlxTagAttribute); + enterRule(_localctx, 122, HogQLParser::RuleHogqlxTagAttribute); #if __cplusplus > 201703L auto onExit = finally([=, this] { @@ -9448,38 +9300,38 @@ HogQLParser::HogqlxTagAttributeContext* HogQLParser::hogqlxTagAttribute() { exitRule(); }); try { - setState(1134); + setState(1126); _errHandler->sync(this); - switch (getInterpreter()->adaptivePredict(_input, 142, _ctx)) { + switch (getInterpreter()->adaptivePredict(_input, 141, _ctx)) { case 1: { enterOuterAlt(_localctx, 1); - setState(1123); + setState(1115); identifier(); - setState(1124); + setState(1116); match(HogQLParser::EQ_SINGLE); - setState(1125); + setState(1117); string(); break; } case 2: { enterOuterAlt(_localctx, 2); - setState(1127); + setState(1119); identifier(); - setState(1128); + setState(1120); match(HogQLParser::EQ_SINGLE); - setState(1129); + setState(1121); match(HogQLParser::LBRACE); - setState(1130); + setState(1122); columnExpr(0); - setState(1131); + setState(1123); match(HogQLParser::RBRACE); break; } case 3: { enterOuterAlt(_localctx, 3); - setState(1133); + setState(1125); identifier(); break; } @@ -9535,7 +9387,7 @@ std::any HogQLParser::WithExprListContext::accept(tree::ParseTreeVisitor *visito HogQLParser::WithExprListContext* HogQLParser::withExprList() { WithExprListContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 128, HogQLParser::RuleWithExprList); + enterRule(_localctx, 124, HogQLParser::RuleWithExprList); size_t _la = 0; #if __cplusplus > 201703L @@ -9548,28 +9400,28 @@ HogQLParser::WithExprListContext* HogQLParser::withExprList() { try { size_t alt; enterOuterAlt(_localctx, 1); - setState(1136); + setState(1128); withExpr(); - setState(1141); + setState(1133); _errHandler->sync(this); - alt = getInterpreter()->adaptivePredict(_input, 143, _ctx); + alt = getInterpreter()->adaptivePredict(_input, 142, _ctx); while (alt != 2 && alt != atn::ATN::INVALID_ALT_NUMBER) { if (alt == 1) { - setState(1137); + setState(1129); match(HogQLParser::COMMA); - setState(1138); + setState(1130); withExpr(); } - setState(1143); + setState(1135); _errHandler->sync(this); - alt = getInterpreter()->adaptivePredict(_input, 143, _ctx); + alt = getInterpreter()->adaptivePredict(_input, 142, _ctx); } - setState(1145); + setState(1137); _errHandler->sync(this); _la = _input->LA(1); if (_la == HogQLParser::COMMA) { - setState(1144); + setState(1136); match(HogQLParser::COMMA); } @@ -9654,7 +9506,7 @@ std::any HogQLParser::WithExprSubqueryContext::accept(tree::ParseTreeVisitor *vi } HogQLParser::WithExprContext* HogQLParser::withExpr() { WithExprContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 130, HogQLParser::RuleWithExpr); + enterRule(_localctx, 126, HogQLParser::RuleWithExpr); #if __cplusplus > 201703L auto onExit = finally([=, this] { @@ -9664,21 +9516,21 @@ HogQLParser::WithExprContext* HogQLParser::withExpr() { exitRule(); }); try { - setState(1157); + setState(1149); _errHandler->sync(this); - switch (getInterpreter()->adaptivePredict(_input, 145, _ctx)) { + switch (getInterpreter()->adaptivePredict(_input, 144, _ctx)) { case 1: { _localctx = _tracker.createInstance(_localctx); enterOuterAlt(_localctx, 1); - setState(1147); + setState(1139); identifier(); - setState(1148); + setState(1140); match(HogQLParser::AS); - setState(1149); + setState(1141); match(HogQLParser::LPAREN); - setState(1150); + setState(1142); selectUnionStmt(); - setState(1151); + setState(1143); match(HogQLParser::RPAREN); break; } @@ -9686,11 +9538,11 @@ HogQLParser::WithExprContext* HogQLParser::withExpr() { case 2: { _localctx = _tracker.createInstance(_localctx); enterOuterAlt(_localctx, 2); - setState(1153); + setState(1145); columnExpr(0); - setState(1154); + setState(1146); match(HogQLParser::AS); - setState(1155); + setState(1147); identifier(); break; } @@ -9746,7 +9598,7 @@ std::any HogQLParser::ColumnIdentifierContext::accept(tree::ParseTreeVisitor *vi HogQLParser::ColumnIdentifierContext* HogQLParser::columnIdentifier() { ColumnIdentifierContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 132, HogQLParser::RuleColumnIdentifier); + enterRule(_localctx, 128, HogQLParser::RuleColumnIdentifier); #if __cplusplus > 201703L auto onExit = finally([=, this] { @@ -9756,12 +9608,12 @@ HogQLParser::ColumnIdentifierContext* HogQLParser::columnIdentifier() { exitRule(); }); try { - setState(1166); + setState(1158); _errHandler->sync(this); switch (_input->LA(1)) { case HogQLParser::LBRACE: { enterOuterAlt(_localctx, 1); - setState(1159); + setState(1151); placeholder(); break; } @@ -9861,14 +9713,14 @@ HogQLParser::ColumnIdentifierContext* HogQLParser::columnIdentifier() { case HogQLParser::YEAR: case HogQLParser::IDENTIFIER: { enterOuterAlt(_localctx, 2); - setState(1163); + setState(1155); _errHandler->sync(this); - switch (getInterpreter()->adaptivePredict(_input, 146, _ctx)) { + switch (getInterpreter()->adaptivePredict(_input, 145, _ctx)) { case 1: { - setState(1160); + setState(1152); tableIdentifier(); - setState(1161); + setState(1153); match(HogQLParser::DOT); break; } @@ -9876,7 +9728,7 @@ HogQLParser::ColumnIdentifierContext* HogQLParser::columnIdentifier() { default: break; } - setState(1165); + setState(1157); nestedIdentifier(); break; } @@ -9932,7 +9784,7 @@ std::any HogQLParser::NestedIdentifierContext::accept(tree::ParseTreeVisitor *vi HogQLParser::NestedIdentifierContext* HogQLParser::nestedIdentifier() { NestedIdentifierContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 134, HogQLParser::RuleNestedIdentifier); + enterRule(_localctx, 130, HogQLParser::RuleNestedIdentifier); #if __cplusplus > 201703L auto onExit = finally([=, this] { @@ -9944,21 +9796,21 @@ HogQLParser::NestedIdentifierContext* HogQLParser::nestedIdentifier() { try { size_t alt; enterOuterAlt(_localctx, 1); - setState(1168); + setState(1160); identifier(); - setState(1173); + setState(1165); _errHandler->sync(this); - alt = getInterpreter()->adaptivePredict(_input, 148, _ctx); + alt = getInterpreter()->adaptivePredict(_input, 147, _ctx); while (alt != 2 && alt != atn::ATN::INVALID_ALT_NUMBER) { if (alt == 1) { - setState(1169); + setState(1161); match(HogQLParser::DOT); - setState(1170); + setState(1162); identifier(); } - setState(1175); + setState(1167); _errHandler->sync(this); - alt = getInterpreter()->adaptivePredict(_input, 148, _ctx); + alt = getInterpreter()->adaptivePredict(_input, 147, _ctx); } } @@ -10107,8 +9959,8 @@ HogQLParser::TableExprContext* HogQLParser::tableExpr(int precedence) { HogQLParser::TableExprContext *_localctx = _tracker.createInstance(_ctx, parentState); HogQLParser::TableExprContext *previousContext = _localctx; (void)previousContext; // Silence compiler, in case the context is not used by generated code. - size_t startState = 136; - enterRecursionRule(_localctx, 136, HogQLParser::RuleTableExpr, precedence); + size_t startState = 132; + enterRecursionRule(_localctx, 132, HogQLParser::RuleTableExpr, precedence); @@ -10122,15 +9974,15 @@ HogQLParser::TableExprContext* HogQLParser::tableExpr(int precedence) { try { size_t alt; enterOuterAlt(_localctx, 1); - setState(1185); + setState(1177); _errHandler->sync(this); - switch (getInterpreter()->adaptivePredict(_input, 149, _ctx)) { + switch (getInterpreter()->adaptivePredict(_input, 148, _ctx)) { case 1: { _localctx = _tracker.createInstance(_localctx); _ctx = _localctx; previousContext = _localctx; - setState(1177); + setState(1169); tableIdentifier(); break; } @@ -10139,7 +9991,7 @@ HogQLParser::TableExprContext* HogQLParser::tableExpr(int precedence) { _localctx = _tracker.createInstance(_localctx); _ctx = _localctx; previousContext = _localctx; - setState(1178); + setState(1170); tableFunctionExpr(); break; } @@ -10148,11 +10000,11 @@ HogQLParser::TableExprContext* HogQLParser::tableExpr(int precedence) { _localctx = _tracker.createInstance(_localctx); _ctx = _localctx; previousContext = _localctx; - setState(1179); + setState(1171); match(HogQLParser::LPAREN); - setState(1180); + setState(1172); selectUnionStmt(); - setState(1181); + setState(1173); match(HogQLParser::RPAREN); break; } @@ -10161,7 +10013,7 @@ HogQLParser::TableExprContext* HogQLParser::tableExpr(int precedence) { _localctx = _tracker.createInstance(_localctx); _ctx = _localctx; previousContext = _localctx; - setState(1183); + setState(1175); hogqlxTagElement(); break; } @@ -10170,7 +10022,7 @@ HogQLParser::TableExprContext* HogQLParser::tableExpr(int precedence) { _localctx = _tracker.createInstance(_localctx); _ctx = _localctx; previousContext = _localctx; - setState(1184); + setState(1176); placeholder(); break; } @@ -10179,9 +10031,9 @@ HogQLParser::TableExprContext* HogQLParser::tableExpr(int precedence) { break; } _ctx->stop = _input->LT(-1); - setState(1195); + setState(1187); _errHandler->sync(this); - alt = getInterpreter()->adaptivePredict(_input, 151, _ctx); + alt = getInterpreter()->adaptivePredict(_input, 150, _ctx); while (alt != 2 && alt != atn::ATN::INVALID_ALT_NUMBER) { if (alt == 1) { if (!_parseListeners.empty()) @@ -10190,10 +10042,10 @@ HogQLParser::TableExprContext* HogQLParser::tableExpr(int precedence) { auto newContext = _tracker.createInstance(_tracker.createInstance(parentContext, parentState)); _localctx = newContext; pushNewRecursionContext(newContext, startState, RuleTableExpr); - setState(1187); + setState(1179); if (!(precpred(_ctx, 3))) throw FailedPredicateException(this, "precpred(_ctx, 3)"); - setState(1191); + setState(1183); _errHandler->sync(this); switch (_input->LA(1)) { case HogQLParser::DATE: @@ -10201,15 +10053,15 @@ HogQLParser::TableExprContext* HogQLParser::tableExpr(int precedence) { case HogQLParser::ID: case HogQLParser::KEY: case HogQLParser::IDENTIFIER: { - setState(1188); + setState(1180); alias(); break; } case HogQLParser::AS: { - setState(1189); + setState(1181); match(HogQLParser::AS); - setState(1190); + setState(1182); identifier(); break; } @@ -10218,9 +10070,9 @@ HogQLParser::TableExprContext* HogQLParser::tableExpr(int precedence) { throw NoViableAltException(this); } } - setState(1197); + setState(1189); _errHandler->sync(this); - alt = getInterpreter()->adaptivePredict(_input, 151, _ctx); + alt = getInterpreter()->adaptivePredict(_input, 150, _ctx); } } catch (RecognitionException &e) { @@ -10268,7 +10120,7 @@ std::any HogQLParser::TableFunctionExprContext::accept(tree::ParseTreeVisitor *v HogQLParser::TableFunctionExprContext* HogQLParser::tableFunctionExpr() { TableFunctionExprContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 138, HogQLParser::RuleTableFunctionExpr); + enterRule(_localctx, 134, HogQLParser::RuleTableFunctionExpr); size_t _la = 0; #if __cplusplus > 201703L @@ -10280,11 +10132,11 @@ HogQLParser::TableFunctionExprContext* HogQLParser::tableFunctionExpr() { }); try { enterOuterAlt(_localctx, 1); - setState(1198); + setState(1190); identifier(); - setState(1199); + setState(1191); match(HogQLParser::LPAREN); - setState(1201); + setState(1193); _errHandler->sync(this); _la = _input->LA(1); @@ -10292,10 +10144,10 @@ HogQLParser::TableFunctionExprContext* HogQLParser::tableFunctionExpr() { ((1ULL << _la) & -4503602311741442) != 0) || ((((_la - 64) & ~ 0x3fULL) == 0) && ((1ULL << (_la - 64)) & 90493036243451903) != 0) || ((((_la - 128) & ~ 0x3fULL) == 0) && ((1ULL << (_la - 128)) & 18455) != 0)) { - setState(1200); + setState(1192); tableArgList(); } - setState(1203); + setState(1195); match(HogQLParser::RPAREN); } @@ -10341,7 +10193,7 @@ std::any HogQLParser::TableIdentifierContext::accept(tree::ParseTreeVisitor *vis HogQLParser::TableIdentifierContext* HogQLParser::tableIdentifier() { TableIdentifierContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 140, HogQLParser::RuleTableIdentifier); + enterRule(_localctx, 136, HogQLParser::RuleTableIdentifier); #if __cplusplus > 201703L auto onExit = finally([=, this] { @@ -10352,14 +10204,14 @@ HogQLParser::TableIdentifierContext* HogQLParser::tableIdentifier() { }); try { enterOuterAlt(_localctx, 1); - setState(1208); + setState(1200); _errHandler->sync(this); - switch (getInterpreter()->adaptivePredict(_input, 153, _ctx)) { + switch (getInterpreter()->adaptivePredict(_input, 152, _ctx)) { case 1: { - setState(1205); + setState(1197); databaseIdentifier(); - setState(1206); + setState(1198); match(HogQLParser::DOT); break; } @@ -10367,7 +10219,7 @@ HogQLParser::TableIdentifierContext* HogQLParser::tableIdentifier() { default: break; } - setState(1210); + setState(1202); identifier(); } @@ -10417,7 +10269,7 @@ std::any HogQLParser::TableArgListContext::accept(tree::ParseTreeVisitor *visito HogQLParser::TableArgListContext* HogQLParser::tableArgList() { TableArgListContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 142, HogQLParser::RuleTableArgList); + enterRule(_localctx, 138, HogQLParser::RuleTableArgList); size_t _la = 0; #if __cplusplus > 201703L @@ -10430,28 +10282,28 @@ HogQLParser::TableArgListContext* HogQLParser::tableArgList() { try { size_t alt; enterOuterAlt(_localctx, 1); - setState(1212); + setState(1204); columnExpr(0); - setState(1217); + setState(1209); _errHandler->sync(this); - alt = getInterpreter()->adaptivePredict(_input, 154, _ctx); + alt = getInterpreter()->adaptivePredict(_input, 153, _ctx); while (alt != 2 && alt != atn::ATN::INVALID_ALT_NUMBER) { if (alt == 1) { - setState(1213); + setState(1205); match(HogQLParser::COMMA); - setState(1214); + setState(1206); columnExpr(0); } - setState(1219); + setState(1211); _errHandler->sync(this); - alt = getInterpreter()->adaptivePredict(_input, 154, _ctx); + alt = getInterpreter()->adaptivePredict(_input, 153, _ctx); } - setState(1221); + setState(1213); _errHandler->sync(this); _la = _input->LA(1); if (_la == HogQLParser::COMMA) { - setState(1220); + setState(1212); match(HogQLParser::COMMA); } @@ -10490,7 +10342,7 @@ std::any HogQLParser::DatabaseIdentifierContext::accept(tree::ParseTreeVisitor * HogQLParser::DatabaseIdentifierContext* HogQLParser::databaseIdentifier() { DatabaseIdentifierContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 144, HogQLParser::RuleDatabaseIdentifier); + enterRule(_localctx, 140, HogQLParser::RuleDatabaseIdentifier); #if __cplusplus > 201703L auto onExit = finally([=, this] { @@ -10501,7 +10353,7 @@ HogQLParser::DatabaseIdentifierContext* HogQLParser::databaseIdentifier() { }); try { enterOuterAlt(_localctx, 1); - setState(1223); + setState(1215); identifier(); } @@ -10555,7 +10407,7 @@ std::any HogQLParser::FloatingLiteralContext::accept(tree::ParseTreeVisitor *vis HogQLParser::FloatingLiteralContext* HogQLParser::floatingLiteral() { FloatingLiteralContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 146, HogQLParser::RuleFloatingLiteral); + enterRule(_localctx, 142, HogQLParser::RuleFloatingLiteral); size_t _la = 0; #if __cplusplus > 201703L @@ -10566,21 +10418,21 @@ HogQLParser::FloatingLiteralContext* HogQLParser::floatingLiteral() { exitRule(); }); try { - setState(1233); + setState(1225); _errHandler->sync(this); switch (_input->LA(1)) { case HogQLParser::FLOATING_LITERAL: { enterOuterAlt(_localctx, 1); - setState(1225); + setState(1217); match(HogQLParser::FLOATING_LITERAL); break; } case HogQLParser::DOT: { enterOuterAlt(_localctx, 2); - setState(1226); + setState(1218); match(HogQLParser::DOT); - setState(1227); + setState(1219); _la = _input->LA(1); if (!(_la == HogQLParser::OCTAL_LITERAL @@ -10596,16 +10448,16 @@ HogQLParser::FloatingLiteralContext* HogQLParser::floatingLiteral() { case HogQLParser::DECIMAL_LITERAL: { enterOuterAlt(_localctx, 3); - setState(1228); + setState(1220); match(HogQLParser::DECIMAL_LITERAL); - setState(1229); + setState(1221); match(HogQLParser::DOT); - setState(1231); + setState(1223); _errHandler->sync(this); - switch (getInterpreter()->adaptivePredict(_input, 156, _ctx)) { + switch (getInterpreter()->adaptivePredict(_input, 155, _ctx)) { case 1: { - setState(1230); + setState(1222); _la = _input->LA(1); if (!(_la == HogQLParser::OCTAL_LITERAL @@ -10692,7 +10544,7 @@ std::any HogQLParser::NumberLiteralContext::accept(tree::ParseTreeVisitor *visit HogQLParser::NumberLiteralContext* HogQLParser::numberLiteral() { NumberLiteralContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 148, HogQLParser::RuleNumberLiteral); + enterRule(_localctx, 144, HogQLParser::RuleNumberLiteral); size_t _la = 0; #if __cplusplus > 201703L @@ -10704,14 +10556,14 @@ HogQLParser::NumberLiteralContext* HogQLParser::numberLiteral() { }); try { enterOuterAlt(_localctx, 1); - setState(1236); + setState(1228); _errHandler->sync(this); _la = _input->LA(1); if (_la == HogQLParser::DASH || _la == HogQLParser::PLUS) { - setState(1235); + setState(1227); _la = _input->LA(1); if (!(_la == HogQLParser::DASH @@ -10723,41 +10575,41 @@ HogQLParser::NumberLiteralContext* HogQLParser::numberLiteral() { consume(); } } - setState(1244); + setState(1236); _errHandler->sync(this); - switch (getInterpreter()->adaptivePredict(_input, 159, _ctx)) { + switch (getInterpreter()->adaptivePredict(_input, 158, _ctx)) { case 1: { - setState(1238); + setState(1230); floatingLiteral(); break; } case 2: { - setState(1239); + setState(1231); match(HogQLParser::OCTAL_LITERAL); break; } case 3: { - setState(1240); + setState(1232); match(HogQLParser::DECIMAL_LITERAL); break; } case 4: { - setState(1241); + setState(1233); match(HogQLParser::HEXADECIMAL_LITERAL); break; } case 5: { - setState(1242); + setState(1234); match(HogQLParser::INF); break; } case 6: { - setState(1243); + setState(1235); match(HogQLParser::NAN_SQL); break; } @@ -10809,7 +10661,7 @@ std::any HogQLParser::LiteralContext::accept(tree::ParseTreeVisitor *visitor) { HogQLParser::LiteralContext* HogQLParser::literal() { LiteralContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 150, HogQLParser::RuleLiteral); + enterRule(_localctx, 146, HogQLParser::RuleLiteral); #if __cplusplus > 201703L auto onExit = finally([=, this] { @@ -10819,7 +10671,7 @@ HogQLParser::LiteralContext* HogQLParser::literal() { exitRule(); }); try { - setState(1249); + setState(1241); _errHandler->sync(this); switch (_input->LA(1)) { case HogQLParser::INF: @@ -10832,21 +10684,21 @@ HogQLParser::LiteralContext* HogQLParser::literal() { case HogQLParser::DOT: case HogQLParser::PLUS: { enterOuterAlt(_localctx, 1); - setState(1246); + setState(1238); numberLiteral(); break; } case HogQLParser::STRING_LITERAL: { enterOuterAlt(_localctx, 2); - setState(1247); + setState(1239); match(HogQLParser::STRING_LITERAL); break; } case HogQLParser::NULL_SQL: { enterOuterAlt(_localctx, 3); - setState(1248); + setState(1240); match(HogQLParser::NULL_SQL); break; } @@ -10918,7 +10770,7 @@ std::any HogQLParser::IntervalContext::accept(tree::ParseTreeVisitor *visitor) { HogQLParser::IntervalContext* HogQLParser::interval() { IntervalContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 152, HogQLParser::RuleInterval); + enterRule(_localctx, 148, HogQLParser::RuleInterval); size_t _la = 0; #if __cplusplus > 201703L @@ -10930,7 +10782,7 @@ HogQLParser::IntervalContext* HogQLParser::interval() { }); try { enterOuterAlt(_localctx, 1); - setState(1251); + setState(1243); _la = _input->LA(1); if (!((((_la & ~ 0x3fULL) == 0) && ((1ULL << _la) & 108086665936896000) != 0) || ((((_la - 70) & ~ 0x3fULL) == 0) && @@ -11313,7 +11165,7 @@ std::any HogQLParser::KeywordContext::accept(tree::ParseTreeVisitor *visitor) { HogQLParser::KeywordContext* HogQLParser::keyword() { KeywordContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 154, HogQLParser::RuleKeyword); + enterRule(_localctx, 150, HogQLParser::RuleKeyword); size_t _la = 0; #if __cplusplus > 201703L @@ -11325,7 +11177,7 @@ HogQLParser::KeywordContext* HogQLParser::keyword() { }); try { enterOuterAlt(_localctx, 1); - setState(1253); + setState(1245); _la = _input->LA(1); if (!((((_la & ~ 0x3fULL) == 0) && ((1ULL << _la) & -833175004720939010) != 0) || ((((_la - 64) & ~ 0x3fULL) == 0) && @@ -11384,7 +11236,7 @@ std::any HogQLParser::KeywordForAliasContext::accept(tree::ParseTreeVisitor *vis HogQLParser::KeywordForAliasContext* HogQLParser::keywordForAlias() { KeywordForAliasContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 156, HogQLParser::RuleKeywordForAlias); + enterRule(_localctx, 152, HogQLParser::RuleKeywordForAlias); size_t _la = 0; #if __cplusplus > 201703L @@ -11396,7 +11248,7 @@ HogQLParser::KeywordForAliasContext* HogQLParser::keywordForAlias() { }); try { enterOuterAlt(_localctx, 1); - setState(1255); + setState(1247); _la = _input->LA(1); if (!((((_la & ~ 0x3fULL) == 0) && ((1ULL << _la) & 282025807314944) != 0))) { @@ -11446,7 +11298,7 @@ std::any HogQLParser::AliasContext::accept(tree::ParseTreeVisitor *visitor) { HogQLParser::AliasContext* HogQLParser::alias() { AliasContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 158, HogQLParser::RuleAlias); + enterRule(_localctx, 154, HogQLParser::RuleAlias); #if __cplusplus > 201703L auto onExit = finally([=, this] { @@ -11456,12 +11308,12 @@ HogQLParser::AliasContext* HogQLParser::alias() { exitRule(); }); try { - setState(1259); + setState(1251); _errHandler->sync(this); switch (_input->LA(1)) { case HogQLParser::IDENTIFIER: { enterOuterAlt(_localctx, 1); - setState(1257); + setState(1249); match(HogQLParser::IDENTIFIER); break; } @@ -11471,7 +11323,7 @@ HogQLParser::AliasContext* HogQLParser::alias() { case HogQLParser::ID: case HogQLParser::KEY: { enterOuterAlt(_localctx, 2); - setState(1258); + setState(1250); keywordForAlias(); break; } @@ -11523,7 +11375,7 @@ std::any HogQLParser::IdentifierContext::accept(tree::ParseTreeVisitor *visitor) HogQLParser::IdentifierContext* HogQLParser::identifier() { IdentifierContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 160, HogQLParser::RuleIdentifier); + enterRule(_localctx, 156, HogQLParser::RuleIdentifier); #if __cplusplus > 201703L auto onExit = finally([=, this] { @@ -11533,12 +11385,12 @@ HogQLParser::IdentifierContext* HogQLParser::identifier() { exitRule(); }); try { - setState(1264); + setState(1256); _errHandler->sync(this); switch (_input->LA(1)) { case HogQLParser::IDENTIFIER: { enterOuterAlt(_localctx, 1); - setState(1261); + setState(1253); match(HogQLParser::IDENTIFIER); break; } @@ -11552,7 +11404,7 @@ HogQLParser::IdentifierContext* HogQLParser::identifier() { case HogQLParser::WEEK: case HogQLParser::YEAR: { enterOuterAlt(_localctx, 2); - setState(1262); + setState(1254); interval(); break; } @@ -11643,7 +11495,7 @@ HogQLParser::IdentifierContext* HogQLParser::identifier() { case HogQLParser::WINDOW: case HogQLParser::WITH: { enterOuterAlt(_localctx, 3); - setState(1263); + setState(1255); keyword(); break; } @@ -11695,7 +11547,7 @@ std::any HogQLParser::EnumValueContext::accept(tree::ParseTreeVisitor *visitor) HogQLParser::EnumValueContext* HogQLParser::enumValue() { EnumValueContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 162, HogQLParser::RuleEnumValue); + enterRule(_localctx, 158, HogQLParser::RuleEnumValue); #if __cplusplus > 201703L auto onExit = finally([=, this] { @@ -11706,11 +11558,11 @@ HogQLParser::EnumValueContext* HogQLParser::enumValue() { }); try { enterOuterAlt(_localctx, 1); - setState(1266); + setState(1258); string(); - setState(1267); + setState(1259); match(HogQLParser::EQ_SINGLE); - setState(1268); + setState(1260); numberLiteral(); } @@ -11756,7 +11608,7 @@ std::any HogQLParser::PlaceholderContext::accept(tree::ParseTreeVisitor *visitor HogQLParser::PlaceholderContext* HogQLParser::placeholder() { PlaceholderContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 164, HogQLParser::RulePlaceholder); + enterRule(_localctx, 160, HogQLParser::RulePlaceholder); #if __cplusplus > 201703L auto onExit = finally([=, this] { @@ -11767,11 +11619,11 @@ HogQLParser::PlaceholderContext* HogQLParser::placeholder() { }); try { enterOuterAlt(_localctx, 1); - setState(1270); + setState(1262); match(HogQLParser::LBRACE); - setState(1271); + setState(1263); nestedIdentifier(); - setState(1272); + setState(1264); match(HogQLParser::RBRACE); } @@ -11813,7 +11665,7 @@ std::any HogQLParser::StringContext::accept(tree::ParseTreeVisitor *visitor) { HogQLParser::StringContext* HogQLParser::string() { StringContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 166, HogQLParser::RuleString); + enterRule(_localctx, 162, HogQLParser::RuleString); #if __cplusplus > 201703L auto onExit = finally([=, this] { @@ -11823,19 +11675,19 @@ HogQLParser::StringContext* HogQLParser::string() { exitRule(); }); try { - setState(1276); + setState(1268); _errHandler->sync(this); switch (_input->LA(1)) { case HogQLParser::STRING_LITERAL: { enterOuterAlt(_localctx, 1); - setState(1274); + setState(1266); match(HogQLParser::STRING_LITERAL); break; } case HogQLParser::QUOTE_SINGLE_TEMPLATE: { enterOuterAlt(_localctx, 2); - setState(1275); + setState(1267); templateString(); break; } @@ -11891,7 +11743,7 @@ std::any HogQLParser::TemplateStringContext::accept(tree::ParseTreeVisitor *visi HogQLParser::TemplateStringContext* HogQLParser::templateString() { TemplateStringContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 168, HogQLParser::RuleTemplateString); + enterRule(_localctx, 164, HogQLParser::RuleTemplateString); size_t _la = 0; #if __cplusplus > 201703L @@ -11903,21 +11755,21 @@ HogQLParser::TemplateStringContext* HogQLParser::templateString() { }); try { enterOuterAlt(_localctx, 1); - setState(1278); + setState(1270); match(HogQLParser::QUOTE_SINGLE_TEMPLATE); - setState(1282); + setState(1274); _errHandler->sync(this); _la = _input->LA(1); while (_la == HogQLParser::STRING_TEXT || _la == HogQLParser::STRING_ESCAPE_TRIGGER) { - setState(1279); + setState(1271); stringContents(); - setState(1284); + setState(1276); _errHandler->sync(this); _la = _input->LA(1); } - setState(1285); + setState(1277); match(HogQLParser::QUOTE_SINGLE); } @@ -11967,7 +11819,7 @@ std::any HogQLParser::StringContentsContext::accept(tree::ParseTreeVisitor *visi HogQLParser::StringContentsContext* HogQLParser::stringContents() { StringContentsContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 170, HogQLParser::RuleStringContents); + enterRule(_localctx, 166, HogQLParser::RuleStringContents); #if __cplusplus > 201703L auto onExit = finally([=, this] { @@ -11977,23 +11829,23 @@ HogQLParser::StringContentsContext* HogQLParser::stringContents() { exitRule(); }); try { - setState(1292); + setState(1284); _errHandler->sync(this); switch (_input->LA(1)) { case HogQLParser::STRING_ESCAPE_TRIGGER: { enterOuterAlt(_localctx, 1); - setState(1287); + setState(1279); match(HogQLParser::STRING_ESCAPE_TRIGGER); - setState(1288); + setState(1280); columnExpr(0); - setState(1289); + setState(1281); match(HogQLParser::RBRACE); break; } case HogQLParser::STRING_TEXT: { enterOuterAlt(_localctx, 2); - setState(1291); + setState(1283); match(HogQLParser::STRING_TEXT); break; } @@ -12049,7 +11901,7 @@ std::any HogQLParser::FullTemplateStringContext::accept(tree::ParseTreeVisitor * HogQLParser::FullTemplateStringContext* HogQLParser::fullTemplateString() { FullTemplateStringContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 172, HogQLParser::RuleFullTemplateString); + enterRule(_localctx, 168, HogQLParser::RuleFullTemplateString); size_t _la = 0; #if __cplusplus > 201703L @@ -12061,21 +11913,21 @@ HogQLParser::FullTemplateStringContext* HogQLParser::fullTemplateString() { }); try { enterOuterAlt(_localctx, 1); - setState(1294); + setState(1286); match(HogQLParser::QUOTE_SINGLE_TEMPLATE_FULL); - setState(1298); + setState(1290); _errHandler->sync(this); _la = _input->LA(1); while (_la == HogQLParser::FULL_STRING_TEXT || _la == HogQLParser::FULL_STRING_ESCAPE_TRIGGER) { - setState(1295); + setState(1287); stringContentsFull(); - setState(1300); + setState(1292); _errHandler->sync(this); _la = _input->LA(1); } - setState(1301); + setState(1293); match(HogQLParser::EOF); } @@ -12125,7 +11977,7 @@ std::any HogQLParser::StringContentsFullContext::accept(tree::ParseTreeVisitor * HogQLParser::StringContentsFullContext* HogQLParser::stringContentsFull() { StringContentsFullContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 174, HogQLParser::RuleStringContentsFull); + enterRule(_localctx, 170, HogQLParser::RuleStringContentsFull); #if __cplusplus > 201703L auto onExit = finally([=, this] { @@ -12135,23 +11987,23 @@ HogQLParser::StringContentsFullContext* HogQLParser::stringContentsFull() { exitRule(); }); try { - setState(1308); + setState(1300); _errHandler->sync(this); switch (_input->LA(1)) { case HogQLParser::FULL_STRING_ESCAPE_TRIGGER: { enterOuterAlt(_localctx, 1); - setState(1303); + setState(1295); match(HogQLParser::FULL_STRING_ESCAPE_TRIGGER); - setState(1304); + setState(1296); columnExpr(0); - setState(1305); + setState(1297); match(HogQLParser::RBRACE); break; } case HogQLParser::FULL_STRING_TEXT: { enterOuterAlt(_localctx, 2); - setState(1307); + setState(1299); match(HogQLParser::FULL_STRING_TEXT); break; } @@ -12174,7 +12026,7 @@ bool HogQLParser::sempred(RuleContext *context, size_t ruleIndex, size_t predica switch (ruleIndex) { case 39: return joinExprSempred(antlrcpp::downCast(context), predicateIndex); case 58: return columnExprSempred(antlrcpp::downCast(context), predicateIndex); - case 68: return tableExprSempred(antlrcpp::downCast(context), predicateIndex); + case 66: return tableExprSempred(antlrcpp::downCast(context), predicateIndex); default: break; @@ -12195,22 +12047,23 @@ bool HogQLParser::joinExprSempred(JoinExprContext *_localctx, size_t predicateIn bool HogQLParser::columnExprSempred(ColumnExprContext *_localctx, size_t predicateIndex) { switch (predicateIndex) { - case 2: return precpred(_ctx, 18); - case 3: return precpred(_ctx, 17); - case 4: return precpred(_ctx, 16); - case 5: return precpred(_ctx, 14); - case 6: return precpred(_ctx, 12); - case 7: return precpred(_ctx, 11); - case 8: return precpred(_ctx, 10); - case 9: return precpred(_ctx, 9); - case 10: return precpred(_ctx, 25); - case 11: return precpred(_ctx, 24); - case 12: return precpred(_ctx, 23); - case 13: return precpred(_ctx, 22); - case 14: return precpred(_ctx, 21); - case 15: return precpred(_ctx, 20); - case 16: return precpred(_ctx, 15); - case 17: return precpred(_ctx, 8); + case 2: return precpred(_ctx, 19); + case 3: return precpred(_ctx, 18); + case 4: return precpred(_ctx, 17); + case 5: return precpred(_ctx, 15); + case 6: return precpred(_ctx, 13); + case 7: return precpred(_ctx, 12); + case 8: return precpred(_ctx, 11); + case 9: return precpred(_ctx, 10); + case 10: return precpred(_ctx, 30); + case 11: return precpred(_ctx, 26); + case 12: return precpred(_ctx, 25); + case 13: return precpred(_ctx, 24); + case 14: return precpred(_ctx, 23); + case 15: return precpred(_ctx, 22); + case 16: return precpred(_ctx, 21); + case 17: return precpred(_ctx, 16); + case 18: return precpred(_ctx, 9); default: break; @@ -12220,7 +12073,7 @@ bool HogQLParser::columnExprSempred(ColumnExprContext *_localctx, size_t predica bool HogQLParser::tableExprSempred(TableExprContext *_localctx, size_t predicateIndex) { switch (predicateIndex) { - case 18: return precpred(_ctx, 3); + case 19: return precpred(_ctx, 3); default: break; diff --git a/hogql_parser/HogQLParser.h b/hogql_parser/HogQLParser.h index acabb96a0baa5..a96c1ee007954 100644 --- a/hogql_parser/HogQLParser.h +++ b/hogql_parser/HogQLParser.h @@ -1,5 +1,5 @@ -// Generated from HogQLParser.g4 by ANTLR 4.13.1 +// Generated from HogQLParser.g4 by ANTLR 4.13.2 #pragma once @@ -61,16 +61,15 @@ class HogQLParser : public antlr4::Parser { RuleSettingExprList = 47, RuleSettingExpr = 48, RuleWindowExpr = 49, RuleWinPartitionByClause = 50, RuleWinOrderByClause = 51, RuleWinFrameClause = 52, RuleWinFrameExtend = 53, RuleWinFrameBound = 54, RuleExpr = 55, RuleColumnTypeExpr = 56, - RuleColumnExprList = 57, RuleColumnExpr = 58, RuleColumnArgList = 59, - RuleColumnArgExpr = 60, RuleColumnLambdaExpr = 61, RuleHogqlxTagElement = 62, - RuleHogqlxTagAttribute = 63, RuleWithExprList = 64, RuleWithExpr = 65, - RuleColumnIdentifier = 66, RuleNestedIdentifier = 67, RuleTableExpr = 68, - RuleTableFunctionExpr = 69, RuleTableIdentifier = 70, RuleTableArgList = 71, - RuleDatabaseIdentifier = 72, RuleFloatingLiteral = 73, RuleNumberLiteral = 74, - RuleLiteral = 75, RuleInterval = 76, RuleKeyword = 77, RuleKeywordForAlias = 78, - RuleAlias = 79, RuleIdentifier = 80, RuleEnumValue = 81, RulePlaceholder = 82, - RuleString = 83, RuleTemplateString = 84, RuleStringContents = 85, RuleFullTemplateString = 86, - RuleStringContentsFull = 87 + RuleColumnExprList = 57, RuleColumnExpr = 58, RuleColumnLambdaExpr = 59, + RuleHogqlxTagElement = 60, RuleHogqlxTagAttribute = 61, RuleWithExprList = 62, + RuleWithExpr = 63, RuleColumnIdentifier = 64, RuleNestedIdentifier = 65, + RuleTableExpr = 66, RuleTableFunctionExpr = 67, RuleTableIdentifier = 68, + RuleTableArgList = 69, RuleDatabaseIdentifier = 70, RuleFloatingLiteral = 71, + RuleNumberLiteral = 72, RuleLiteral = 73, RuleInterval = 74, RuleKeyword = 75, + RuleKeywordForAlias = 76, RuleAlias = 77, RuleIdentifier = 78, RuleEnumValue = 79, + RulePlaceholder = 80, RuleString = 81, RuleTemplateString = 82, RuleStringContents = 83, + RuleFullTemplateString = 84, RuleStringContentsFull = 85 }; explicit HogQLParser(antlr4::TokenStream *input); @@ -149,8 +148,6 @@ class HogQLParser : public antlr4::Parser { class ColumnTypeExprContext; class ColumnExprListContext; class ColumnExprContext; - class ColumnArgListContext; - class ColumnArgExprContext; class ColumnLambdaExprContext; class HogqlxTagElementContext; class HogqlxTagAttributeContext; @@ -1567,6 +1564,8 @@ class HogQLParser : public antlr4::Parser { public: ColumnExprWinFunctionTargetContext(ColumnExprContext *ctx); + HogQLParser::ColumnExprListContext *columnExprs = nullptr; + HogQLParser::ColumnExprListContext *columnArgList = nullptr; std::vector identifier(); IdentifierContext* identifier(size_t i); antlr4::tree::TerminalNode *OVER(); @@ -1574,9 +1573,9 @@ class HogQLParser : public antlr4::Parser { antlr4::tree::TerminalNode* LPAREN(size_t i); std::vector RPAREN(); antlr4::tree::TerminalNode* RPAREN(size_t i); - ColumnExprListContext *columnExprList(); + std::vector columnExprList(); + ColumnExprListContext* columnExprList(size_t i); antlr4::tree::TerminalNode *DISTINCT(); - ColumnArgListContext *columnArgList(); virtual std::any accept(antlr4::tree::ParseTreeVisitor *visitor) override; }; @@ -1638,6 +1637,18 @@ class HogQLParser : public antlr4::Parser { virtual std::any accept(antlr4::tree::ParseTreeVisitor *visitor) override; }; + class ColumnExprCallContext : public ColumnExprContext { + public: + ColumnExprCallContext(ColumnExprContext *ctx); + + ColumnExprContext *columnExpr(); + antlr4::tree::TerminalNode *LPAREN(); + antlr4::tree::TerminalNode *RPAREN(); + ColumnExprListContext *columnExprList(); + + virtual std::any accept(antlr4::tree::ParseTreeVisitor *visitor) override; + }; + class ColumnExprArrayAccessContext : public ColumnExprContext { public: ColumnExprArrayAccessContext(ColumnExprContext *ctx); @@ -1786,6 +1797,8 @@ class HogQLParser : public antlr4::Parser { public: ColumnExprWinFunctionContext(ColumnExprContext *ctx); + HogQLParser::ColumnExprListContext *columnExprs = nullptr; + HogQLParser::ColumnExprListContext *columnArgList = nullptr; IdentifierContext *identifier(); antlr4::tree::TerminalNode *OVER(); std::vector LPAREN(); @@ -1793,9 +1806,18 @@ class HogQLParser : public antlr4::Parser { WindowExprContext *windowExpr(); std::vector RPAREN(); antlr4::tree::TerminalNode* RPAREN(size_t i); - ColumnExprListContext *columnExprList(); + std::vector columnExprList(); + ColumnExprListContext* columnExprList(size_t i); antlr4::tree::TerminalNode *DISTINCT(); - ColumnArgListContext *columnArgList(); + + virtual std::any accept(antlr4::tree::ParseTreeVisitor *visitor) override; + }; + + class ColumnExprLambdaContext : public ColumnExprContext { + public: + ColumnExprLambdaContext(ColumnExprContext *ctx); + + ColumnLambdaExprContext *columnLambdaExpr(); virtual std::any accept(antlr4::tree::ParseTreeVisitor *visitor) override; }; @@ -1813,14 +1835,16 @@ class HogQLParser : public antlr4::Parser { public: ColumnExprFunctionContext(ColumnExprContext *ctx); + HogQLParser::ColumnExprListContext *columnExprs = nullptr; + HogQLParser::ColumnExprListContext *columnArgList = nullptr; IdentifierContext *identifier(); std::vector LPAREN(); antlr4::tree::TerminalNode* LPAREN(size_t i); std::vector RPAREN(); antlr4::tree::TerminalNode* RPAREN(size_t i); antlr4::tree::TerminalNode *DISTINCT(); - ColumnArgListContext *columnArgList(); - ColumnExprListContext *columnExprList(); + std::vector columnExprList(); + ColumnExprListContext* columnExprList(size_t i); virtual std::any accept(antlr4::tree::ParseTreeVisitor *visitor) override; }; @@ -1838,46 +1862,17 @@ class HogQLParser : public antlr4::Parser { ColumnExprContext* columnExpr(); ColumnExprContext* columnExpr(int precedence); - class ColumnArgListContext : public antlr4::ParserRuleContext { - public: - ColumnArgListContext(antlr4::ParserRuleContext *parent, size_t invokingState); - virtual size_t getRuleIndex() const override; - std::vector columnArgExpr(); - ColumnArgExprContext* columnArgExpr(size_t i); - std::vector COMMA(); - antlr4::tree::TerminalNode* COMMA(size_t i); - - - virtual std::any accept(antlr4::tree::ParseTreeVisitor *visitor) override; - - }; - - ColumnArgListContext* columnArgList(); - - class ColumnArgExprContext : public antlr4::ParserRuleContext { - public: - ColumnArgExprContext(antlr4::ParserRuleContext *parent, size_t invokingState); - virtual size_t getRuleIndex() const override; - ColumnLambdaExprContext *columnLambdaExpr(); - ColumnExprContext *columnExpr(); - - - virtual std::any accept(antlr4::tree::ParseTreeVisitor *visitor) override; - - }; - - ColumnArgExprContext* columnArgExpr(); - class ColumnLambdaExprContext : public antlr4::ParserRuleContext { public: ColumnLambdaExprContext(antlr4::ParserRuleContext *parent, size_t invokingState); virtual size_t getRuleIndex() const override; antlr4::tree::TerminalNode *ARROW(); - ColumnExprContext *columnExpr(); antlr4::tree::TerminalNode *LPAREN(); std::vector identifier(); IdentifierContext* identifier(size_t i); antlr4::tree::TerminalNode *RPAREN(); + ColumnExprContext *columnExpr(); + BlockContext *block(); std::vector COMMA(); antlr4::tree::TerminalNode* COMMA(size_t i); diff --git a/hogql_parser/HogQLParser.interp b/hogql_parser/HogQLParser.interp index 183059ec0fd79..b965cfbb577c7 100644 --- a/hogql_parser/HogQLParser.interp +++ b/hogql_parser/HogQLParser.interp @@ -382,8 +382,6 @@ expr columnTypeExpr columnExprList columnExpr -columnArgList -columnArgExpr columnLambdaExpr hogqlxTagElement hogqlxTagAttribute @@ -414,4 +412,4 @@ stringContentsFull atn: -[4, 1, 159, 1311, 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, 1, 0, 5, 0, 178, 8, 0, 10, 0, 12, 0, 181, 9, 0, 1, 0, 1, 0, 1, 1, 1, 1, 3, 1, 187, 8, 1, 1, 2, 1, 2, 1, 3, 1, 3, 1, 3, 1, 3, 1, 3, 3, 3, 196, 8, 3, 1, 4, 1, 4, 1, 4, 5, 4, 201, 8, 4, 10, 4, 12, 4, 204, 9, 4, 1, 4, 3, 4, 207, 8, 4, 1, 5, 1, 5, 1, 5, 1, 5, 1, 5, 1, 5, 1, 5, 1, 5, 1, 5, 1, 5, 1, 5, 1, 5, 3, 5, 221, 8, 5, 1, 6, 1, 6, 3, 6, 225, 8, 6, 1, 6, 3, 6, 228, 8, 6, 1, 7, 1, 7, 3, 7, 232, 8, 7, 1, 7, 3, 7, 235, 8, 7, 1, 8, 1, 8, 1, 8, 1, 8, 1, 8, 3, 8, 242, 8, 8, 1, 8, 1, 8, 3, 8, 246, 8, 8, 1, 8, 1, 8, 1, 9, 1, 9, 1, 9, 5, 9, 253, 8, 9, 10, 9, 12, 9, 256, 9, 9, 1, 9, 1, 9, 3, 9, 260, 8, 9, 1, 10, 1, 10, 1, 10, 1, 10, 1, 10, 1, 10, 1, 10, 3, 10, 269, 8, 10, 1, 11, 1, 11, 1, 11, 1, 11, 1, 11, 1, 11, 3, 11, 277, 8, 11, 1, 12, 1, 12, 1, 12, 1, 12, 1, 12, 3, 12, 284, 8, 12, 1, 12, 1, 12, 3, 12, 288, 8, 12, 1, 12, 1, 12, 1, 12, 1, 12, 3, 12, 294, 8, 12, 1, 12, 1, 12, 1, 12, 3, 12, 299, 8, 12, 1, 13, 1, 13, 1, 13, 1, 13, 1, 13, 1, 13, 3, 13, 307, 8, 13, 1, 13, 1, 13, 1, 13, 1, 13, 1, 13, 3, 13, 314, 8, 13, 1, 14, 1, 14, 1, 14, 1, 14, 3, 14, 320, 8, 14, 1, 14, 1, 14, 1, 14, 1, 15, 1, 15, 1, 15, 1, 15, 1, 15, 1, 16, 1, 16, 3, 16, 332, 8, 16, 1, 17, 1, 17, 1, 18, 1, 18, 5, 18, 338, 8, 18, 10, 18, 12, 18, 341, 9, 18, 1, 18, 1, 18, 1, 19, 1, 19, 1, 19, 1, 19, 1, 20, 1, 20, 1, 20, 5, 20, 352, 8, 20, 10, 20, 12, 20, 355, 9, 20, 1, 20, 3, 20, 358, 8, 20, 1, 21, 1, 21, 1, 21, 3, 21, 363, 8, 21, 1, 21, 1, 21, 1, 22, 1, 22, 1, 22, 1, 22, 5, 22, 371, 8, 22, 10, 22, 12, 22, 374, 9, 22, 1, 23, 1, 23, 1, 23, 1, 23, 1, 23, 1, 23, 3, 23, 382, 8, 23, 1, 24, 3, 24, 385, 8, 24, 1, 24, 1, 24, 3, 24, 389, 8, 24, 1, 24, 3, 24, 392, 8, 24, 1, 24, 1, 24, 3, 24, 396, 8, 24, 1, 24, 3, 24, 399, 8, 24, 1, 24, 3, 24, 402, 8, 24, 1, 24, 3, 24, 405, 8, 24, 1, 24, 3, 24, 408, 8, 24, 1, 24, 1, 24, 3, 24, 412, 8, 24, 1, 24, 1, 24, 3, 24, 416, 8, 24, 1, 24, 3, 24, 419, 8, 24, 1, 24, 3, 24, 422, 8, 24, 1, 24, 3, 24, 425, 8, 24, 1, 24, 1, 24, 3, 24, 429, 8, 24, 1, 24, 3, 24, 432, 8, 24, 1, 25, 1, 25, 1, 25, 1, 26, 1, 26, 1, 26, 1, 26, 3, 26, 441, 8, 26, 1, 27, 1, 27, 1, 27, 1, 28, 3, 28, 447, 8, 28, 1, 28, 1, 28, 1, 28, 1, 28, 1, 29, 1, 29, 1, 29, 1, 29, 1, 29, 1, 29, 1, 29, 1, 29, 1, 29, 1, 29, 1, 29, 1, 29, 1, 29, 5, 29, 466, 8, 29, 10, 29, 12, 29, 469, 9, 29, 1, 30, 1, 30, 1, 30, 1, 31, 1, 31, 1, 31, 1, 32, 1, 32, 1, 32, 1, 32, 1, 32, 1, 32, 1, 32, 1, 32, 3, 32, 485, 8, 32, 1, 33, 1, 33, 1, 33, 1, 34, 1, 34, 1, 34, 1, 34, 1, 35, 1, 35, 1, 35, 1, 35, 1, 36, 1, 36, 1, 36, 1, 36, 3, 36, 502, 8, 36, 1, 36, 1, 36, 1, 36, 1, 36, 3, 36, 508, 8, 36, 1, 36, 1, 36, 1, 36, 1, 36, 3, 36, 514, 8, 36, 1, 36, 1, 36, 1, 36, 1, 36, 1, 36, 1, 36, 1, 36, 1, 36, 1, 36, 3, 36, 525, 8, 36, 3, 36, 527, 8, 36, 1, 37, 1, 37, 1, 37, 1, 38, 1, 38, 1, 38, 1, 39, 1, 39, 1, 39, 3, 39, 538, 8, 39, 1, 39, 3, 39, 541, 8, 39, 1, 39, 1, 39, 1, 39, 1, 39, 3, 39, 547, 8, 39, 1, 39, 1, 39, 1, 39, 1, 39, 1, 39, 1, 39, 3, 39, 555, 8, 39, 1, 39, 1, 39, 1, 39, 1, 39, 5, 39, 561, 8, 39, 10, 39, 12, 39, 564, 9, 39, 1, 40, 3, 40, 567, 8, 40, 1, 40, 1, 40, 1, 40, 3, 40, 572, 8, 40, 1, 40, 3, 40, 575, 8, 40, 1, 40, 3, 40, 578, 8, 40, 1, 40, 1, 40, 3, 40, 582, 8, 40, 1, 40, 1, 40, 3, 40, 586, 8, 40, 1, 40, 3, 40, 589, 8, 40, 3, 40, 591, 8, 40, 1, 40, 3, 40, 594, 8, 40, 1, 40, 1, 40, 3, 40, 598, 8, 40, 1, 40, 1, 40, 3, 40, 602, 8, 40, 1, 40, 3, 40, 605, 8, 40, 3, 40, 607, 8, 40, 3, 40, 609, 8, 40, 1, 41, 1, 41, 1, 41, 3, 41, 614, 8, 41, 1, 42, 1, 42, 1, 42, 1, 42, 1, 42, 1, 42, 1, 42, 1, 42, 1, 42, 3, 42, 625, 8, 42, 1, 43, 1, 43, 1, 43, 1, 43, 3, 43, 631, 8, 43, 1, 44, 1, 44, 1, 44, 5, 44, 636, 8, 44, 10, 44, 12, 44, 639, 9, 44, 1, 45, 1, 45, 3, 45, 643, 8, 45, 1, 45, 1, 45, 3, 45, 647, 8, 45, 1, 45, 1, 45, 3, 45, 651, 8, 45, 1, 46, 1, 46, 1, 46, 1, 46, 3, 46, 657, 8, 46, 3, 46, 659, 8, 46, 1, 47, 1, 47, 1, 47, 5, 47, 664, 8, 47, 10, 47, 12, 47, 667, 9, 47, 1, 48, 1, 48, 1, 48, 1, 48, 1, 49, 3, 49, 674, 8, 49, 1, 49, 3, 49, 677, 8, 49, 1, 49, 3, 49, 680, 8, 49, 1, 50, 1, 50, 1, 50, 1, 50, 1, 51, 1, 51, 1, 51, 1, 51, 1, 52, 1, 52, 1, 52, 1, 53, 1, 53, 1, 53, 1, 53, 1, 53, 1, 53, 3, 53, 699, 8, 53, 1, 54, 1, 54, 1, 54, 1, 54, 1, 54, 1, 54, 1, 54, 1, 54, 1, 54, 1, 54, 1, 54, 1, 54, 3, 54, 713, 8, 54, 1, 55, 1, 55, 1, 55, 1, 56, 1, 56, 1, 56, 1, 56, 1, 56, 1, 56, 1, 56, 1, 56, 1, 56, 5, 56, 727, 8, 56, 10, 56, 12, 56, 730, 9, 56, 1, 56, 3, 56, 733, 8, 56, 1, 56, 1, 56, 1, 56, 1, 56, 1, 56, 1, 56, 1, 56, 5, 56, 742, 8, 56, 10, 56, 12, 56, 745, 9, 56, 1, 56, 3, 56, 748, 8, 56, 1, 56, 1, 56, 1, 56, 1, 56, 1, 56, 1, 56, 1, 56, 5, 56, 757, 8, 56, 10, 56, 12, 56, 760, 9, 56, 1, 56, 3, 56, 763, 8, 56, 1, 56, 1, 56, 1, 56, 1, 56, 1, 56, 3, 56, 770, 8, 56, 1, 56, 1, 56, 3, 56, 774, 8, 56, 1, 57, 1, 57, 1, 57, 5, 57, 779, 8, 57, 10, 57, 12, 57, 782, 9, 57, 1, 57, 3, 57, 785, 8, 57, 1, 58, 1, 58, 1, 58, 3, 58, 790, 8, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 4, 58, 797, 8, 58, 11, 58, 12, 58, 798, 1, 58, 1, 58, 3, 58, 803, 8, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 3, 58, 827, 8, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 3, 58, 844, 8, 58, 1, 58, 1, 58, 1, 58, 1, 58, 3, 58, 850, 8, 58, 1, 58, 3, 58, 853, 8, 58, 1, 58, 3, 58, 856, 8, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 3, 58, 866, 8, 58, 1, 58, 1, 58, 1, 58, 1, 58, 3, 58, 872, 8, 58, 1, 58, 3, 58, 875, 8, 58, 1, 58, 3, 58, 878, 8, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 3, 58, 886, 8, 58, 1, 58, 3, 58, 889, 8, 58, 1, 58, 1, 58, 3, 58, 893, 8, 58, 1, 58, 3, 58, 896, 8, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 3, 58, 910, 8, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 3, 58, 927, 8, 58, 1, 58, 1, 58, 1, 58, 3, 58, 932, 8, 58, 1, 58, 1, 58, 3, 58, 936, 8, 58, 1, 58, 1, 58, 1, 58, 1, 58, 3, 58, 942, 8, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 3, 58, 949, 8, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 3, 58, 961, 8, 58, 1, 58, 1, 58, 3, 58, 965, 8, 58, 1, 58, 3, 58, 968, 8, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 3, 58, 977, 8, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 3, 58, 991, 8, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 3, 58, 1030, 8, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 3, 58, 1038, 8, 58, 5, 58, 1040, 8, 58, 10, 58, 12, 58, 1043, 9, 58, 1, 59, 1, 59, 1, 59, 5, 59, 1048, 8, 59, 10, 59, 12, 59, 1051, 9, 59, 1, 59, 3, 59, 1054, 8, 59, 1, 60, 1, 60, 3, 60, 1058, 8, 60, 1, 61, 1, 61, 1, 61, 1, 61, 5, 61, 1064, 8, 61, 10, 61, 12, 61, 1067, 9, 61, 1, 61, 3, 61, 1070, 8, 61, 1, 61, 1, 61, 1, 61, 1, 61, 1, 61, 5, 61, 1077, 8, 61, 10, 61, 12, 61, 1080, 9, 61, 1, 61, 3, 61, 1083, 8, 61, 3, 61, 1085, 8, 61, 1, 61, 1, 61, 1, 61, 1, 62, 1, 62, 1, 62, 5, 62, 1093, 8, 62, 10, 62, 12, 62, 1096, 9, 62, 1, 62, 1, 62, 1, 62, 1, 62, 1, 62, 1, 62, 5, 62, 1104, 8, 62, 10, 62, 12, 62, 1107, 9, 62, 1, 62, 1, 62, 1, 62, 1, 62, 1, 62, 1, 62, 3, 62, 1115, 8, 62, 1, 62, 1, 62, 1, 62, 1, 62, 1, 62, 3, 62, 1122, 8, 62, 1, 63, 1, 63, 1, 63, 1, 63, 1, 63, 1, 63, 1, 63, 1, 63, 1, 63, 1, 63, 1, 63, 3, 63, 1135, 8, 63, 1, 64, 1, 64, 1, 64, 5, 64, 1140, 8, 64, 10, 64, 12, 64, 1143, 9, 64, 1, 64, 3, 64, 1146, 8, 64, 1, 65, 1, 65, 1, 65, 1, 65, 1, 65, 1, 65, 1, 65, 1, 65, 1, 65, 1, 65, 3, 65, 1158, 8, 65, 1, 66, 1, 66, 1, 66, 1, 66, 3, 66, 1164, 8, 66, 1, 66, 3, 66, 1167, 8, 66, 1, 67, 1, 67, 1, 67, 5, 67, 1172, 8, 67, 10, 67, 12, 67, 1175, 9, 67, 1, 68, 1, 68, 1, 68, 1, 68, 1, 68, 1, 68, 1, 68, 1, 68, 1, 68, 3, 68, 1186, 8, 68, 1, 68, 1, 68, 1, 68, 1, 68, 3, 68, 1192, 8, 68, 5, 68, 1194, 8, 68, 10, 68, 12, 68, 1197, 9, 68, 1, 69, 1, 69, 1, 69, 3, 69, 1202, 8, 69, 1, 69, 1, 69, 1, 70, 1, 70, 1, 70, 3, 70, 1209, 8, 70, 1, 70, 1, 70, 1, 71, 1, 71, 1, 71, 5, 71, 1216, 8, 71, 10, 71, 12, 71, 1219, 9, 71, 1, 71, 3, 71, 1222, 8, 71, 1, 72, 1, 72, 1, 73, 1, 73, 1, 73, 1, 73, 1, 73, 1, 73, 3, 73, 1232, 8, 73, 3, 73, 1234, 8, 73, 1, 74, 3, 74, 1237, 8, 74, 1, 74, 1, 74, 1, 74, 1, 74, 1, 74, 1, 74, 3, 74, 1245, 8, 74, 1, 75, 1, 75, 1, 75, 3, 75, 1250, 8, 75, 1, 76, 1, 76, 1, 77, 1, 77, 1, 78, 1, 78, 1, 79, 1, 79, 3, 79, 1260, 8, 79, 1, 80, 1, 80, 1, 80, 3, 80, 1265, 8, 80, 1, 81, 1, 81, 1, 81, 1, 81, 1, 82, 1, 82, 1, 82, 1, 82, 1, 83, 1, 83, 3, 83, 1277, 8, 83, 1, 84, 1, 84, 5, 84, 1281, 8, 84, 10, 84, 12, 84, 1284, 9, 84, 1, 84, 1, 84, 1, 85, 1, 85, 1, 85, 1, 85, 1, 85, 3, 85, 1293, 8, 85, 1, 86, 1, 86, 5, 86, 1297, 8, 86, 10, 86, 12, 86, 1300, 9, 86, 1, 86, 1, 86, 1, 87, 1, 87, 1, 87, 1, 87, 1, 87, 3, 87, 1309, 8, 87, 1, 87, 0, 3, 78, 116, 136, 88, 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, 0, 16, 2, 0, 18, 18, 74, 74, 2, 0, 44, 44, 51, 51, 3, 0, 1, 1, 4, 4, 8, 8, 4, 0, 1, 1, 3, 4, 8, 8, 80, 80, 2, 0, 51, 51, 73, 73, 2, 0, 1, 1, 4, 4, 2, 0, 7, 7, 22, 23, 2, 0, 30, 30, 49, 49, 2, 0, 71, 71, 76, 76, 3, 0, 10, 10, 50, 50, 90, 90, 2, 0, 41, 41, 53, 53, 1, 0, 107, 108, 2, 0, 118, 118, 139, 139, 7, 0, 21, 21, 38, 38, 55, 56, 70, 70, 78, 78, 97, 97, 103, 103, 16, 0, 1, 13, 15, 20, 22, 28, 30, 30, 32, 37, 39, 42, 44, 51, 53, 54, 58, 58, 60, 69, 71, 77, 79, 83, 85, 92, 94, 96, 98, 99, 101, 102, 4, 0, 20, 20, 30, 30, 39, 39, 48, 48, 1479, 0, 179, 1, 0, 0, 0, 2, 186, 1, 0, 0, 0, 4, 188, 1, 0, 0, 0, 6, 190, 1, 0, 0, 0, 8, 197, 1, 0, 0, 0, 10, 220, 1, 0, 0, 0, 12, 222, 1, 0, 0, 0, 14, 229, 1, 0, 0, 0, 16, 236, 1, 0, 0, 0, 18, 249, 1, 0, 0, 0, 20, 261, 1, 0, 0, 0, 22, 270, 1, 0, 0, 0, 24, 278, 1, 0, 0, 0, 26, 300, 1, 0, 0, 0, 28, 315, 1, 0, 0, 0, 30, 324, 1, 0, 0, 0, 32, 329, 1, 0, 0, 0, 34, 333, 1, 0, 0, 0, 36, 335, 1, 0, 0, 0, 38, 344, 1, 0, 0, 0, 40, 348, 1, 0, 0, 0, 42, 362, 1, 0, 0, 0, 44, 366, 1, 0, 0, 0, 46, 381, 1, 0, 0, 0, 48, 384, 1, 0, 0, 0, 50, 433, 1, 0, 0, 0, 52, 436, 1, 0, 0, 0, 54, 442, 1, 0, 0, 0, 56, 446, 1, 0, 0, 0, 58, 452, 1, 0, 0, 0, 60, 470, 1, 0, 0, 0, 62, 473, 1, 0, 0, 0, 64, 476, 1, 0, 0, 0, 66, 486, 1, 0, 0, 0, 68, 489, 1, 0, 0, 0, 70, 493, 1, 0, 0, 0, 72, 526, 1, 0, 0, 0, 74, 528, 1, 0, 0, 0, 76, 531, 1, 0, 0, 0, 78, 546, 1, 0, 0, 0, 80, 608, 1, 0, 0, 0, 82, 613, 1, 0, 0, 0, 84, 624, 1, 0, 0, 0, 86, 626, 1, 0, 0, 0, 88, 632, 1, 0, 0, 0, 90, 640, 1, 0, 0, 0, 92, 658, 1, 0, 0, 0, 94, 660, 1, 0, 0, 0, 96, 668, 1, 0, 0, 0, 98, 673, 1, 0, 0, 0, 100, 681, 1, 0, 0, 0, 102, 685, 1, 0, 0, 0, 104, 689, 1, 0, 0, 0, 106, 698, 1, 0, 0, 0, 108, 712, 1, 0, 0, 0, 110, 714, 1, 0, 0, 0, 112, 773, 1, 0, 0, 0, 114, 775, 1, 0, 0, 0, 116, 935, 1, 0, 0, 0, 118, 1044, 1, 0, 0, 0, 120, 1057, 1, 0, 0, 0, 122, 1084, 1, 0, 0, 0, 124, 1121, 1, 0, 0, 0, 126, 1134, 1, 0, 0, 0, 128, 1136, 1, 0, 0, 0, 130, 1157, 1, 0, 0, 0, 132, 1166, 1, 0, 0, 0, 134, 1168, 1, 0, 0, 0, 136, 1185, 1, 0, 0, 0, 138, 1198, 1, 0, 0, 0, 140, 1208, 1, 0, 0, 0, 142, 1212, 1, 0, 0, 0, 144, 1223, 1, 0, 0, 0, 146, 1233, 1, 0, 0, 0, 148, 1236, 1, 0, 0, 0, 150, 1249, 1, 0, 0, 0, 152, 1251, 1, 0, 0, 0, 154, 1253, 1, 0, 0, 0, 156, 1255, 1, 0, 0, 0, 158, 1259, 1, 0, 0, 0, 160, 1264, 1, 0, 0, 0, 162, 1266, 1, 0, 0, 0, 164, 1270, 1, 0, 0, 0, 166, 1276, 1, 0, 0, 0, 168, 1278, 1, 0, 0, 0, 170, 1292, 1, 0, 0, 0, 172, 1294, 1, 0, 0, 0, 174, 1308, 1, 0, 0, 0, 176, 178, 3, 2, 1, 0, 177, 176, 1, 0, 0, 0, 178, 181, 1, 0, 0, 0, 179, 177, 1, 0, 0, 0, 179, 180, 1, 0, 0, 0, 180, 182, 1, 0, 0, 0, 181, 179, 1, 0, 0, 0, 182, 183, 5, 0, 0, 1, 183, 1, 1, 0, 0, 0, 184, 187, 3, 6, 3, 0, 185, 187, 3, 10, 5, 0, 186, 184, 1, 0, 0, 0, 186, 185, 1, 0, 0, 0, 187, 3, 1, 0, 0, 0, 188, 189, 3, 116, 58, 0, 189, 5, 1, 0, 0, 0, 190, 191, 5, 52, 0, 0, 191, 195, 3, 160, 80, 0, 192, 193, 5, 115, 0, 0, 193, 194, 5, 122, 0, 0, 194, 196, 3, 4, 2, 0, 195, 192, 1, 0, 0, 0, 195, 196, 1, 0, 0, 0, 196, 7, 1, 0, 0, 0, 197, 202, 3, 160, 80, 0, 198, 199, 5, 116, 0, 0, 199, 201, 3, 160, 80, 0, 200, 198, 1, 0, 0, 0, 201, 204, 1, 0, 0, 0, 202, 200, 1, 0, 0, 0, 202, 203, 1, 0, 0, 0, 203, 206, 1, 0, 0, 0, 204, 202, 1, 0, 0, 0, 205, 207, 5, 116, 0, 0, 206, 205, 1, 0, 0, 0, 206, 207, 1, 0, 0, 0, 207, 9, 1, 0, 0, 0, 208, 221, 3, 12, 6, 0, 209, 221, 3, 14, 7, 0, 210, 221, 3, 18, 9, 0, 211, 221, 3, 20, 10, 0, 212, 221, 3, 22, 11, 0, 213, 221, 3, 26, 13, 0, 214, 221, 3, 24, 12, 0, 215, 221, 3, 28, 14, 0, 216, 221, 3, 30, 15, 0, 217, 221, 3, 36, 18, 0, 218, 221, 3, 32, 16, 0, 219, 221, 3, 34, 17, 0, 220, 208, 1, 0, 0, 0, 220, 209, 1, 0, 0, 0, 220, 210, 1, 0, 0, 0, 220, 211, 1, 0, 0, 0, 220, 212, 1, 0, 0, 0, 220, 213, 1, 0, 0, 0, 220, 214, 1, 0, 0, 0, 220, 215, 1, 0, 0, 0, 220, 216, 1, 0, 0, 0, 220, 217, 1, 0, 0, 0, 220, 218, 1, 0, 0, 0, 220, 219, 1, 0, 0, 0, 221, 11, 1, 0, 0, 0, 222, 224, 5, 72, 0, 0, 223, 225, 3, 4, 2, 0, 224, 223, 1, 0, 0, 0, 224, 225, 1, 0, 0, 0, 225, 227, 1, 0, 0, 0, 226, 228, 5, 150, 0, 0, 227, 226, 1, 0, 0, 0, 227, 228, 1, 0, 0, 0, 228, 13, 1, 0, 0, 0, 229, 231, 5, 84, 0, 0, 230, 232, 3, 4, 2, 0, 231, 230, 1, 0, 0, 0, 231, 232, 1, 0, 0, 0, 232, 234, 1, 0, 0, 0, 233, 235, 5, 150, 0, 0, 234, 233, 1, 0, 0, 0, 234, 235, 1, 0, 0, 0, 235, 15, 1, 0, 0, 0, 236, 245, 5, 14, 0, 0, 237, 238, 5, 130, 0, 0, 238, 241, 3, 160, 80, 0, 239, 240, 5, 115, 0, 0, 240, 242, 3, 160, 80, 0, 241, 239, 1, 0, 0, 0, 241, 242, 1, 0, 0, 0, 242, 243, 1, 0, 0, 0, 243, 244, 5, 149, 0, 0, 244, 246, 1, 0, 0, 0, 245, 237, 1, 0, 0, 0, 245, 246, 1, 0, 0, 0, 246, 247, 1, 0, 0, 0, 247, 248, 3, 36, 18, 0, 248, 17, 1, 0, 0, 0, 249, 250, 5, 93, 0, 0, 250, 254, 3, 36, 18, 0, 251, 253, 3, 16, 8, 0, 252, 251, 1, 0, 0, 0, 253, 256, 1, 0, 0, 0, 254, 252, 1, 0, 0, 0, 254, 255, 1, 0, 0, 0, 255, 259, 1, 0, 0, 0, 256, 254, 1, 0, 0, 0, 257, 258, 5, 29, 0, 0, 258, 260, 3, 36, 18, 0, 259, 257, 1, 0, 0, 0, 259, 260, 1, 0, 0, 0, 260, 19, 1, 0, 0, 0, 261, 262, 5, 40, 0, 0, 262, 263, 5, 130, 0, 0, 263, 264, 3, 4, 2, 0, 264, 265, 5, 149, 0, 0, 265, 268, 3, 10, 5, 0, 266, 267, 5, 25, 0, 0, 267, 269, 3, 10, 5, 0, 268, 266, 1, 0, 0, 0, 268, 269, 1, 0, 0, 0, 269, 21, 1, 0, 0, 0, 270, 271, 5, 100, 0, 0, 271, 272, 5, 130, 0, 0, 272, 273, 3, 4, 2, 0, 273, 274, 5, 149, 0, 0, 274, 276, 3, 10, 5, 0, 275, 277, 5, 150, 0, 0, 276, 275, 1, 0, 0, 0, 276, 277, 1, 0, 0, 0, 277, 23, 1, 0, 0, 0, 278, 279, 5, 33, 0, 0, 279, 283, 5, 130, 0, 0, 280, 284, 3, 6, 3, 0, 281, 284, 3, 30, 15, 0, 282, 284, 3, 4, 2, 0, 283, 280, 1, 0, 0, 0, 283, 281, 1, 0, 0, 0, 283, 282, 1, 0, 0, 0, 283, 284, 1, 0, 0, 0, 284, 285, 1, 0, 0, 0, 285, 287, 5, 150, 0, 0, 286, 288, 3, 4, 2, 0, 287, 286, 1, 0, 0, 0, 287, 288, 1, 0, 0, 0, 288, 289, 1, 0, 0, 0, 289, 293, 5, 150, 0, 0, 290, 294, 3, 6, 3, 0, 291, 294, 3, 30, 15, 0, 292, 294, 3, 4, 2, 0, 293, 290, 1, 0, 0, 0, 293, 291, 1, 0, 0, 0, 293, 292, 1, 0, 0, 0, 293, 294, 1, 0, 0, 0, 294, 295, 1, 0, 0, 0, 295, 296, 5, 149, 0, 0, 296, 298, 3, 10, 5, 0, 297, 299, 5, 150, 0, 0, 298, 297, 1, 0, 0, 0, 298, 299, 1, 0, 0, 0, 299, 25, 1, 0, 0, 0, 300, 301, 5, 33, 0, 0, 301, 302, 5, 130, 0, 0, 302, 303, 5, 52, 0, 0, 303, 306, 3, 160, 80, 0, 304, 305, 5, 116, 0, 0, 305, 307, 3, 160, 80, 0, 306, 304, 1, 0, 0, 0, 306, 307, 1, 0, 0, 0, 307, 308, 1, 0, 0, 0, 308, 309, 5, 42, 0, 0, 309, 310, 3, 4, 2, 0, 310, 311, 5, 149, 0, 0, 311, 313, 3, 10, 5, 0, 312, 314, 5, 150, 0, 0, 313, 312, 1, 0, 0, 0, 313, 314, 1, 0, 0, 0, 314, 27, 1, 0, 0, 0, 315, 316, 5, 31, 0, 0, 316, 317, 3, 160, 80, 0, 317, 319, 5, 130, 0, 0, 318, 320, 3, 8, 4, 0, 319, 318, 1, 0, 0, 0, 319, 320, 1, 0, 0, 0, 320, 321, 1, 0, 0, 0, 321, 322, 5, 149, 0, 0, 322, 323, 3, 36, 18, 0, 323, 29, 1, 0, 0, 0, 324, 325, 3, 4, 2, 0, 325, 326, 5, 115, 0, 0, 326, 327, 5, 122, 0, 0, 327, 328, 3, 4, 2, 0, 328, 31, 1, 0, 0, 0, 329, 331, 3, 4, 2, 0, 330, 332, 5, 150, 0, 0, 331, 330, 1, 0, 0, 0, 331, 332, 1, 0, 0, 0, 332, 33, 1, 0, 0, 0, 333, 334, 5, 150, 0, 0, 334, 35, 1, 0, 0, 0, 335, 339, 5, 128, 0, 0, 336, 338, 3, 2, 1, 0, 337, 336, 1, 0, 0, 0, 338, 341, 1, 0, 0, 0, 339, 337, 1, 0, 0, 0, 339, 340, 1, 0, 0, 0, 340, 342, 1, 0, 0, 0, 341, 339, 1, 0, 0, 0, 342, 343, 5, 147, 0, 0, 343, 37, 1, 0, 0, 0, 344, 345, 3, 4, 2, 0, 345, 346, 5, 115, 0, 0, 346, 347, 3, 4, 2, 0, 347, 39, 1, 0, 0, 0, 348, 353, 3, 38, 19, 0, 349, 350, 5, 116, 0, 0, 350, 352, 3, 38, 19, 0, 351, 349, 1, 0, 0, 0, 352, 355, 1, 0, 0, 0, 353, 351, 1, 0, 0, 0, 353, 354, 1, 0, 0, 0, 354, 357, 1, 0, 0, 0, 355, 353, 1, 0, 0, 0, 356, 358, 5, 116, 0, 0, 357, 356, 1, 0, 0, 0, 357, 358, 1, 0, 0, 0, 358, 41, 1, 0, 0, 0, 359, 363, 3, 44, 22, 0, 360, 363, 3, 48, 24, 0, 361, 363, 3, 124, 62, 0, 362, 359, 1, 0, 0, 0, 362, 360, 1, 0, 0, 0, 362, 361, 1, 0, 0, 0, 363, 364, 1, 0, 0, 0, 364, 365, 5, 0, 0, 1, 365, 43, 1, 0, 0, 0, 366, 372, 3, 46, 23, 0, 367, 368, 5, 95, 0, 0, 368, 369, 5, 1, 0, 0, 369, 371, 3, 46, 23, 0, 370, 367, 1, 0, 0, 0, 371, 374, 1, 0, 0, 0, 372, 370, 1, 0, 0, 0, 372, 373, 1, 0, 0, 0, 373, 45, 1, 0, 0, 0, 374, 372, 1, 0, 0, 0, 375, 382, 3, 48, 24, 0, 376, 377, 5, 130, 0, 0, 377, 378, 3, 44, 22, 0, 378, 379, 5, 149, 0, 0, 379, 382, 1, 0, 0, 0, 380, 382, 3, 164, 82, 0, 381, 375, 1, 0, 0, 0, 381, 376, 1, 0, 0, 0, 381, 380, 1, 0, 0, 0, 382, 47, 1, 0, 0, 0, 383, 385, 3, 50, 25, 0, 384, 383, 1, 0, 0, 0, 384, 385, 1, 0, 0, 0, 385, 386, 1, 0, 0, 0, 386, 388, 5, 79, 0, 0, 387, 389, 5, 24, 0, 0, 388, 387, 1, 0, 0, 0, 388, 389, 1, 0, 0, 0, 389, 391, 1, 0, 0, 0, 390, 392, 3, 52, 26, 0, 391, 390, 1, 0, 0, 0, 391, 392, 1, 0, 0, 0, 392, 393, 1, 0, 0, 0, 393, 395, 3, 114, 57, 0, 394, 396, 3, 54, 27, 0, 395, 394, 1, 0, 0, 0, 395, 396, 1, 0, 0, 0, 396, 398, 1, 0, 0, 0, 397, 399, 3, 56, 28, 0, 398, 397, 1, 0, 0, 0, 398, 399, 1, 0, 0, 0, 399, 401, 1, 0, 0, 0, 400, 402, 3, 60, 30, 0, 401, 400, 1, 0, 0, 0, 401, 402, 1, 0, 0, 0, 402, 404, 1, 0, 0, 0, 403, 405, 3, 62, 31, 0, 404, 403, 1, 0, 0, 0, 404, 405, 1, 0, 0, 0, 405, 407, 1, 0, 0, 0, 406, 408, 3, 64, 32, 0, 407, 406, 1, 0, 0, 0, 407, 408, 1, 0, 0, 0, 408, 411, 1, 0, 0, 0, 409, 410, 5, 102, 0, 0, 410, 412, 7, 0, 0, 0, 411, 409, 1, 0, 0, 0, 411, 412, 1, 0, 0, 0, 412, 415, 1, 0, 0, 0, 413, 414, 5, 102, 0, 0, 414, 416, 5, 89, 0, 0, 415, 413, 1, 0, 0, 0, 415, 416, 1, 0, 0, 0, 416, 418, 1, 0, 0, 0, 417, 419, 3, 66, 33, 0, 418, 417, 1, 0, 0, 0, 418, 419, 1, 0, 0, 0, 419, 421, 1, 0, 0, 0, 420, 422, 3, 58, 29, 0, 421, 420, 1, 0, 0, 0, 421, 422, 1, 0, 0, 0, 422, 424, 1, 0, 0, 0, 423, 425, 3, 68, 34, 0, 424, 423, 1, 0, 0, 0, 424, 425, 1, 0, 0, 0, 425, 428, 1, 0, 0, 0, 426, 429, 3, 72, 36, 0, 427, 429, 3, 74, 37, 0, 428, 426, 1, 0, 0, 0, 428, 427, 1, 0, 0, 0, 428, 429, 1, 0, 0, 0, 429, 431, 1, 0, 0, 0, 430, 432, 3, 76, 38, 0, 431, 430, 1, 0, 0, 0, 431, 432, 1, 0, 0, 0, 432, 49, 1, 0, 0, 0, 433, 434, 5, 102, 0, 0, 434, 435, 3, 128, 64, 0, 435, 51, 1, 0, 0, 0, 436, 437, 5, 88, 0, 0, 437, 440, 5, 108, 0, 0, 438, 439, 5, 102, 0, 0, 439, 441, 5, 85, 0, 0, 440, 438, 1, 0, 0, 0, 440, 441, 1, 0, 0, 0, 441, 53, 1, 0, 0, 0, 442, 443, 5, 34, 0, 0, 443, 444, 3, 78, 39, 0, 444, 55, 1, 0, 0, 0, 445, 447, 7, 1, 0, 0, 446, 445, 1, 0, 0, 0, 446, 447, 1, 0, 0, 0, 447, 448, 1, 0, 0, 0, 448, 449, 5, 5, 0, 0, 449, 450, 5, 47, 0, 0, 450, 451, 3, 114, 57, 0, 451, 57, 1, 0, 0, 0, 452, 453, 5, 101, 0, 0, 453, 454, 3, 160, 80, 0, 454, 455, 5, 6, 0, 0, 455, 456, 5, 130, 0, 0, 456, 457, 3, 98, 49, 0, 457, 467, 5, 149, 0, 0, 458, 459, 5, 116, 0, 0, 459, 460, 3, 160, 80, 0, 460, 461, 5, 6, 0, 0, 461, 462, 5, 130, 0, 0, 462, 463, 3, 98, 49, 0, 463, 464, 5, 149, 0, 0, 464, 466, 1, 0, 0, 0, 465, 458, 1, 0, 0, 0, 466, 469, 1, 0, 0, 0, 467, 465, 1, 0, 0, 0, 467, 468, 1, 0, 0, 0, 468, 59, 1, 0, 0, 0, 469, 467, 1, 0, 0, 0, 470, 471, 5, 69, 0, 0, 471, 472, 3, 116, 58, 0, 472, 61, 1, 0, 0, 0, 473, 474, 5, 99, 0, 0, 474, 475, 3, 116, 58, 0, 475, 63, 1, 0, 0, 0, 476, 477, 5, 36, 0, 0, 477, 484, 5, 11, 0, 0, 478, 479, 7, 0, 0, 0, 479, 480, 5, 130, 0, 0, 480, 481, 3, 114, 57, 0, 481, 482, 5, 149, 0, 0, 482, 485, 1, 0, 0, 0, 483, 485, 3, 114, 57, 0, 484, 478, 1, 0, 0, 0, 484, 483, 1, 0, 0, 0, 485, 65, 1, 0, 0, 0, 486, 487, 5, 37, 0, 0, 487, 488, 3, 116, 58, 0, 488, 67, 1, 0, 0, 0, 489, 490, 5, 64, 0, 0, 490, 491, 5, 11, 0, 0, 491, 492, 3, 88, 44, 0, 492, 69, 1, 0, 0, 0, 493, 494, 5, 64, 0, 0, 494, 495, 5, 11, 0, 0, 495, 496, 3, 114, 57, 0, 496, 71, 1, 0, 0, 0, 497, 498, 5, 54, 0, 0, 498, 501, 3, 116, 58, 0, 499, 500, 5, 116, 0, 0, 500, 502, 3, 116, 58, 0, 501, 499, 1, 0, 0, 0, 501, 502, 1, 0, 0, 0, 502, 507, 1, 0, 0, 0, 503, 504, 5, 102, 0, 0, 504, 508, 5, 85, 0, 0, 505, 506, 5, 11, 0, 0, 506, 508, 3, 114, 57, 0, 507, 503, 1, 0, 0, 0, 507, 505, 1, 0, 0, 0, 507, 508, 1, 0, 0, 0, 508, 527, 1, 0, 0, 0, 509, 510, 5, 54, 0, 0, 510, 513, 3, 116, 58, 0, 511, 512, 5, 102, 0, 0, 512, 514, 5, 85, 0, 0, 513, 511, 1, 0, 0, 0, 513, 514, 1, 0, 0, 0, 514, 515, 1, 0, 0, 0, 515, 516, 5, 61, 0, 0, 516, 517, 3, 116, 58, 0, 517, 527, 1, 0, 0, 0, 518, 519, 5, 54, 0, 0, 519, 520, 3, 116, 58, 0, 520, 521, 5, 61, 0, 0, 521, 524, 3, 116, 58, 0, 522, 523, 5, 11, 0, 0, 523, 525, 3, 114, 57, 0, 524, 522, 1, 0, 0, 0, 524, 525, 1, 0, 0, 0, 525, 527, 1, 0, 0, 0, 526, 497, 1, 0, 0, 0, 526, 509, 1, 0, 0, 0, 526, 518, 1, 0, 0, 0, 527, 73, 1, 0, 0, 0, 528, 529, 5, 61, 0, 0, 529, 530, 3, 116, 58, 0, 530, 75, 1, 0, 0, 0, 531, 532, 5, 81, 0, 0, 532, 533, 3, 94, 47, 0, 533, 77, 1, 0, 0, 0, 534, 535, 6, 39, -1, 0, 535, 537, 3, 136, 68, 0, 536, 538, 5, 28, 0, 0, 537, 536, 1, 0, 0, 0, 537, 538, 1, 0, 0, 0, 538, 540, 1, 0, 0, 0, 539, 541, 3, 86, 43, 0, 540, 539, 1, 0, 0, 0, 540, 541, 1, 0, 0, 0, 541, 547, 1, 0, 0, 0, 542, 543, 5, 130, 0, 0, 543, 544, 3, 78, 39, 0, 544, 545, 5, 149, 0, 0, 545, 547, 1, 0, 0, 0, 546, 534, 1, 0, 0, 0, 546, 542, 1, 0, 0, 0, 547, 562, 1, 0, 0, 0, 548, 549, 10, 3, 0, 0, 549, 550, 3, 82, 41, 0, 550, 551, 3, 78, 39, 4, 551, 561, 1, 0, 0, 0, 552, 554, 10, 4, 0, 0, 553, 555, 3, 80, 40, 0, 554, 553, 1, 0, 0, 0, 554, 555, 1, 0, 0, 0, 555, 556, 1, 0, 0, 0, 556, 557, 5, 47, 0, 0, 557, 558, 3, 78, 39, 0, 558, 559, 3, 84, 42, 0, 559, 561, 1, 0, 0, 0, 560, 548, 1, 0, 0, 0, 560, 552, 1, 0, 0, 0, 561, 564, 1, 0, 0, 0, 562, 560, 1, 0, 0, 0, 562, 563, 1, 0, 0, 0, 563, 79, 1, 0, 0, 0, 564, 562, 1, 0, 0, 0, 565, 567, 7, 2, 0, 0, 566, 565, 1, 0, 0, 0, 566, 567, 1, 0, 0, 0, 567, 568, 1, 0, 0, 0, 568, 575, 5, 44, 0, 0, 569, 571, 5, 44, 0, 0, 570, 572, 7, 2, 0, 0, 571, 570, 1, 0, 0, 0, 571, 572, 1, 0, 0, 0, 572, 575, 1, 0, 0, 0, 573, 575, 7, 2, 0, 0, 574, 566, 1, 0, 0, 0, 574, 569, 1, 0, 0, 0, 574, 573, 1, 0, 0, 0, 575, 609, 1, 0, 0, 0, 576, 578, 7, 3, 0, 0, 577, 576, 1, 0, 0, 0, 577, 578, 1, 0, 0, 0, 578, 579, 1, 0, 0, 0, 579, 581, 7, 4, 0, 0, 580, 582, 5, 65, 0, 0, 581, 580, 1, 0, 0, 0, 581, 582, 1, 0, 0, 0, 582, 591, 1, 0, 0, 0, 583, 585, 7, 4, 0, 0, 584, 586, 5, 65, 0, 0, 585, 584, 1, 0, 0, 0, 585, 586, 1, 0, 0, 0, 586, 588, 1, 0, 0, 0, 587, 589, 7, 3, 0, 0, 588, 587, 1, 0, 0, 0, 588, 589, 1, 0, 0, 0, 589, 591, 1, 0, 0, 0, 590, 577, 1, 0, 0, 0, 590, 583, 1, 0, 0, 0, 591, 609, 1, 0, 0, 0, 592, 594, 7, 5, 0, 0, 593, 592, 1, 0, 0, 0, 593, 594, 1, 0, 0, 0, 594, 595, 1, 0, 0, 0, 595, 597, 5, 35, 0, 0, 596, 598, 5, 65, 0, 0, 597, 596, 1, 0, 0, 0, 597, 598, 1, 0, 0, 0, 598, 607, 1, 0, 0, 0, 599, 601, 5, 35, 0, 0, 600, 602, 5, 65, 0, 0, 601, 600, 1, 0, 0, 0, 601, 602, 1, 0, 0, 0, 602, 604, 1, 0, 0, 0, 603, 605, 7, 5, 0, 0, 604, 603, 1, 0, 0, 0, 604, 605, 1, 0, 0, 0, 605, 607, 1, 0, 0, 0, 606, 593, 1, 0, 0, 0, 606, 599, 1, 0, 0, 0, 607, 609, 1, 0, 0, 0, 608, 574, 1, 0, 0, 0, 608, 590, 1, 0, 0, 0, 608, 606, 1, 0, 0, 0, 609, 81, 1, 0, 0, 0, 610, 611, 5, 17, 0, 0, 611, 614, 5, 47, 0, 0, 612, 614, 5, 116, 0, 0, 613, 610, 1, 0, 0, 0, 613, 612, 1, 0, 0, 0, 614, 83, 1, 0, 0, 0, 615, 616, 5, 62, 0, 0, 616, 625, 3, 114, 57, 0, 617, 618, 5, 96, 0, 0, 618, 619, 5, 130, 0, 0, 619, 620, 3, 114, 57, 0, 620, 621, 5, 149, 0, 0, 621, 625, 1, 0, 0, 0, 622, 623, 5, 96, 0, 0, 623, 625, 3, 114, 57, 0, 624, 615, 1, 0, 0, 0, 624, 617, 1, 0, 0, 0, 624, 622, 1, 0, 0, 0, 625, 85, 1, 0, 0, 0, 626, 627, 5, 77, 0, 0, 627, 630, 3, 92, 46, 0, 628, 629, 5, 61, 0, 0, 629, 631, 3, 92, 46, 0, 630, 628, 1, 0, 0, 0, 630, 631, 1, 0, 0, 0, 631, 87, 1, 0, 0, 0, 632, 637, 3, 90, 45, 0, 633, 634, 5, 116, 0, 0, 634, 636, 3, 90, 45, 0, 635, 633, 1, 0, 0, 0, 636, 639, 1, 0, 0, 0, 637, 635, 1, 0, 0, 0, 637, 638, 1, 0, 0, 0, 638, 89, 1, 0, 0, 0, 639, 637, 1, 0, 0, 0, 640, 642, 3, 116, 58, 0, 641, 643, 7, 6, 0, 0, 642, 641, 1, 0, 0, 0, 642, 643, 1, 0, 0, 0, 643, 646, 1, 0, 0, 0, 644, 645, 5, 60, 0, 0, 645, 647, 7, 7, 0, 0, 646, 644, 1, 0, 0, 0, 646, 647, 1, 0, 0, 0, 647, 650, 1, 0, 0, 0, 648, 649, 5, 16, 0, 0, 649, 651, 5, 110, 0, 0, 650, 648, 1, 0, 0, 0, 650, 651, 1, 0, 0, 0, 651, 91, 1, 0, 0, 0, 652, 659, 3, 164, 82, 0, 653, 656, 3, 148, 74, 0, 654, 655, 5, 151, 0, 0, 655, 657, 3, 148, 74, 0, 656, 654, 1, 0, 0, 0, 656, 657, 1, 0, 0, 0, 657, 659, 1, 0, 0, 0, 658, 652, 1, 0, 0, 0, 658, 653, 1, 0, 0, 0, 659, 93, 1, 0, 0, 0, 660, 665, 3, 96, 48, 0, 661, 662, 5, 116, 0, 0, 662, 664, 3, 96, 48, 0, 663, 661, 1, 0, 0, 0, 664, 667, 1, 0, 0, 0, 665, 663, 1, 0, 0, 0, 665, 666, 1, 0, 0, 0, 666, 95, 1, 0, 0, 0, 667, 665, 1, 0, 0, 0, 668, 669, 3, 160, 80, 0, 669, 670, 5, 122, 0, 0, 670, 671, 3, 150, 75, 0, 671, 97, 1, 0, 0, 0, 672, 674, 3, 100, 50, 0, 673, 672, 1, 0, 0, 0, 673, 674, 1, 0, 0, 0, 674, 676, 1, 0, 0, 0, 675, 677, 3, 102, 51, 0, 676, 675, 1, 0, 0, 0, 676, 677, 1, 0, 0, 0, 677, 679, 1, 0, 0, 0, 678, 680, 3, 104, 52, 0, 679, 678, 1, 0, 0, 0, 679, 680, 1, 0, 0, 0, 680, 99, 1, 0, 0, 0, 681, 682, 5, 67, 0, 0, 682, 683, 5, 11, 0, 0, 683, 684, 3, 114, 57, 0, 684, 101, 1, 0, 0, 0, 685, 686, 5, 64, 0, 0, 686, 687, 5, 11, 0, 0, 687, 688, 3, 88, 44, 0, 688, 103, 1, 0, 0, 0, 689, 690, 7, 8, 0, 0, 690, 691, 3, 106, 53, 0, 691, 105, 1, 0, 0, 0, 692, 699, 3, 108, 54, 0, 693, 694, 5, 9, 0, 0, 694, 695, 3, 108, 54, 0, 695, 696, 5, 2, 0, 0, 696, 697, 3, 108, 54, 0, 697, 699, 1, 0, 0, 0, 698, 692, 1, 0, 0, 0, 698, 693, 1, 0, 0, 0, 699, 107, 1, 0, 0, 0, 700, 701, 5, 19, 0, 0, 701, 713, 5, 75, 0, 0, 702, 703, 5, 94, 0, 0, 703, 713, 5, 68, 0, 0, 704, 705, 5, 94, 0, 0, 705, 713, 5, 32, 0, 0, 706, 707, 3, 148, 74, 0, 707, 708, 5, 68, 0, 0, 708, 713, 1, 0, 0, 0, 709, 710, 3, 148, 74, 0, 710, 711, 5, 32, 0, 0, 711, 713, 1, 0, 0, 0, 712, 700, 1, 0, 0, 0, 712, 702, 1, 0, 0, 0, 712, 704, 1, 0, 0, 0, 712, 706, 1, 0, 0, 0, 712, 709, 1, 0, 0, 0, 713, 109, 1, 0, 0, 0, 714, 715, 3, 116, 58, 0, 715, 716, 5, 0, 0, 1, 716, 111, 1, 0, 0, 0, 717, 774, 3, 160, 80, 0, 718, 719, 3, 160, 80, 0, 719, 720, 5, 130, 0, 0, 720, 721, 3, 160, 80, 0, 721, 728, 3, 112, 56, 0, 722, 723, 5, 116, 0, 0, 723, 724, 3, 160, 80, 0, 724, 725, 3, 112, 56, 0, 725, 727, 1, 0, 0, 0, 726, 722, 1, 0, 0, 0, 727, 730, 1, 0, 0, 0, 728, 726, 1, 0, 0, 0, 728, 729, 1, 0, 0, 0, 729, 732, 1, 0, 0, 0, 730, 728, 1, 0, 0, 0, 731, 733, 5, 116, 0, 0, 732, 731, 1, 0, 0, 0, 732, 733, 1, 0, 0, 0, 733, 734, 1, 0, 0, 0, 734, 735, 5, 149, 0, 0, 735, 774, 1, 0, 0, 0, 736, 737, 3, 160, 80, 0, 737, 738, 5, 130, 0, 0, 738, 743, 3, 162, 81, 0, 739, 740, 5, 116, 0, 0, 740, 742, 3, 162, 81, 0, 741, 739, 1, 0, 0, 0, 742, 745, 1, 0, 0, 0, 743, 741, 1, 0, 0, 0, 743, 744, 1, 0, 0, 0, 744, 747, 1, 0, 0, 0, 745, 743, 1, 0, 0, 0, 746, 748, 5, 116, 0, 0, 747, 746, 1, 0, 0, 0, 747, 748, 1, 0, 0, 0, 748, 749, 1, 0, 0, 0, 749, 750, 5, 149, 0, 0, 750, 774, 1, 0, 0, 0, 751, 752, 3, 160, 80, 0, 752, 753, 5, 130, 0, 0, 753, 758, 3, 112, 56, 0, 754, 755, 5, 116, 0, 0, 755, 757, 3, 112, 56, 0, 756, 754, 1, 0, 0, 0, 757, 760, 1, 0, 0, 0, 758, 756, 1, 0, 0, 0, 758, 759, 1, 0, 0, 0, 759, 762, 1, 0, 0, 0, 760, 758, 1, 0, 0, 0, 761, 763, 5, 116, 0, 0, 762, 761, 1, 0, 0, 0, 762, 763, 1, 0, 0, 0, 763, 764, 1, 0, 0, 0, 764, 765, 5, 149, 0, 0, 765, 774, 1, 0, 0, 0, 766, 767, 3, 160, 80, 0, 767, 769, 5, 130, 0, 0, 768, 770, 3, 114, 57, 0, 769, 768, 1, 0, 0, 0, 769, 770, 1, 0, 0, 0, 770, 771, 1, 0, 0, 0, 771, 772, 5, 149, 0, 0, 772, 774, 1, 0, 0, 0, 773, 717, 1, 0, 0, 0, 773, 718, 1, 0, 0, 0, 773, 736, 1, 0, 0, 0, 773, 751, 1, 0, 0, 0, 773, 766, 1, 0, 0, 0, 774, 113, 1, 0, 0, 0, 775, 780, 3, 116, 58, 0, 776, 777, 5, 116, 0, 0, 777, 779, 3, 116, 58, 0, 778, 776, 1, 0, 0, 0, 779, 782, 1, 0, 0, 0, 780, 778, 1, 0, 0, 0, 780, 781, 1, 0, 0, 0, 781, 784, 1, 0, 0, 0, 782, 780, 1, 0, 0, 0, 783, 785, 5, 116, 0, 0, 784, 783, 1, 0, 0, 0, 784, 785, 1, 0, 0, 0, 785, 115, 1, 0, 0, 0, 786, 787, 6, 58, -1, 0, 787, 789, 5, 12, 0, 0, 788, 790, 3, 116, 58, 0, 789, 788, 1, 0, 0, 0, 789, 790, 1, 0, 0, 0, 790, 796, 1, 0, 0, 0, 791, 792, 5, 98, 0, 0, 792, 793, 3, 116, 58, 0, 793, 794, 5, 83, 0, 0, 794, 795, 3, 116, 58, 0, 795, 797, 1, 0, 0, 0, 796, 791, 1, 0, 0, 0, 797, 798, 1, 0, 0, 0, 798, 796, 1, 0, 0, 0, 798, 799, 1, 0, 0, 0, 799, 802, 1, 0, 0, 0, 800, 801, 5, 25, 0, 0, 801, 803, 3, 116, 58, 0, 802, 800, 1, 0, 0, 0, 802, 803, 1, 0, 0, 0, 803, 804, 1, 0, 0, 0, 804, 805, 5, 26, 0, 0, 805, 936, 1, 0, 0, 0, 806, 807, 5, 13, 0, 0, 807, 808, 5, 130, 0, 0, 808, 809, 3, 116, 58, 0, 809, 810, 5, 6, 0, 0, 810, 811, 3, 112, 56, 0, 811, 812, 5, 149, 0, 0, 812, 936, 1, 0, 0, 0, 813, 814, 5, 20, 0, 0, 814, 936, 5, 110, 0, 0, 815, 816, 5, 45, 0, 0, 816, 817, 3, 116, 58, 0, 817, 818, 3, 152, 76, 0, 818, 936, 1, 0, 0, 0, 819, 820, 5, 82, 0, 0, 820, 821, 5, 130, 0, 0, 821, 822, 3, 116, 58, 0, 822, 823, 5, 34, 0, 0, 823, 826, 3, 116, 58, 0, 824, 825, 5, 33, 0, 0, 825, 827, 3, 116, 58, 0, 826, 824, 1, 0, 0, 0, 826, 827, 1, 0, 0, 0, 827, 828, 1, 0, 0, 0, 828, 829, 5, 149, 0, 0, 829, 936, 1, 0, 0, 0, 830, 831, 5, 86, 0, 0, 831, 936, 5, 110, 0, 0, 832, 833, 5, 91, 0, 0, 833, 834, 5, 130, 0, 0, 834, 835, 7, 9, 0, 0, 835, 836, 3, 166, 83, 0, 836, 837, 5, 34, 0, 0, 837, 838, 3, 116, 58, 0, 838, 839, 5, 149, 0, 0, 839, 936, 1, 0, 0, 0, 840, 841, 3, 160, 80, 0, 841, 843, 5, 130, 0, 0, 842, 844, 3, 114, 57, 0, 843, 842, 1, 0, 0, 0, 843, 844, 1, 0, 0, 0, 844, 845, 1, 0, 0, 0, 845, 846, 5, 149, 0, 0, 846, 855, 1, 0, 0, 0, 847, 849, 5, 130, 0, 0, 848, 850, 5, 24, 0, 0, 849, 848, 1, 0, 0, 0, 849, 850, 1, 0, 0, 0, 850, 852, 1, 0, 0, 0, 851, 853, 3, 118, 59, 0, 852, 851, 1, 0, 0, 0, 852, 853, 1, 0, 0, 0, 853, 854, 1, 0, 0, 0, 854, 856, 5, 149, 0, 0, 855, 847, 1, 0, 0, 0, 855, 856, 1, 0, 0, 0, 856, 857, 1, 0, 0, 0, 857, 858, 5, 66, 0, 0, 858, 859, 5, 130, 0, 0, 859, 860, 3, 98, 49, 0, 860, 861, 5, 149, 0, 0, 861, 936, 1, 0, 0, 0, 862, 863, 3, 160, 80, 0, 863, 865, 5, 130, 0, 0, 864, 866, 3, 114, 57, 0, 865, 864, 1, 0, 0, 0, 865, 866, 1, 0, 0, 0, 866, 867, 1, 0, 0, 0, 867, 868, 5, 149, 0, 0, 868, 877, 1, 0, 0, 0, 869, 871, 5, 130, 0, 0, 870, 872, 5, 24, 0, 0, 871, 870, 1, 0, 0, 0, 871, 872, 1, 0, 0, 0, 872, 874, 1, 0, 0, 0, 873, 875, 3, 118, 59, 0, 874, 873, 1, 0, 0, 0, 874, 875, 1, 0, 0, 0, 875, 876, 1, 0, 0, 0, 876, 878, 5, 149, 0, 0, 877, 869, 1, 0, 0, 0, 877, 878, 1, 0, 0, 0, 878, 879, 1, 0, 0, 0, 879, 880, 5, 66, 0, 0, 880, 881, 3, 160, 80, 0, 881, 936, 1, 0, 0, 0, 882, 888, 3, 160, 80, 0, 883, 885, 5, 130, 0, 0, 884, 886, 3, 114, 57, 0, 885, 884, 1, 0, 0, 0, 885, 886, 1, 0, 0, 0, 886, 887, 1, 0, 0, 0, 887, 889, 5, 149, 0, 0, 888, 883, 1, 0, 0, 0, 888, 889, 1, 0, 0, 0, 889, 890, 1, 0, 0, 0, 890, 892, 5, 130, 0, 0, 891, 893, 5, 24, 0, 0, 892, 891, 1, 0, 0, 0, 892, 893, 1, 0, 0, 0, 893, 895, 1, 0, 0, 0, 894, 896, 3, 118, 59, 0, 895, 894, 1, 0, 0, 0, 895, 896, 1, 0, 0, 0, 896, 897, 1, 0, 0, 0, 897, 898, 5, 149, 0, 0, 898, 936, 1, 0, 0, 0, 899, 936, 3, 124, 62, 0, 900, 936, 3, 168, 84, 0, 901, 936, 3, 150, 75, 0, 902, 903, 5, 118, 0, 0, 903, 936, 3, 116, 58, 19, 904, 905, 5, 58, 0, 0, 905, 936, 3, 116, 58, 13, 906, 907, 3, 140, 70, 0, 907, 908, 5, 120, 0, 0, 908, 910, 1, 0, 0, 0, 909, 906, 1, 0, 0, 0, 909, 910, 1, 0, 0, 0, 910, 911, 1, 0, 0, 0, 911, 936, 5, 112, 0, 0, 912, 913, 5, 130, 0, 0, 913, 914, 3, 44, 22, 0, 914, 915, 5, 149, 0, 0, 915, 936, 1, 0, 0, 0, 916, 917, 5, 130, 0, 0, 917, 918, 3, 116, 58, 0, 918, 919, 5, 149, 0, 0, 919, 936, 1, 0, 0, 0, 920, 921, 5, 130, 0, 0, 921, 922, 3, 114, 57, 0, 922, 923, 5, 149, 0, 0, 923, 936, 1, 0, 0, 0, 924, 926, 5, 129, 0, 0, 925, 927, 3, 114, 57, 0, 926, 925, 1, 0, 0, 0, 926, 927, 1, 0, 0, 0, 927, 928, 1, 0, 0, 0, 928, 936, 5, 148, 0, 0, 929, 931, 5, 128, 0, 0, 930, 932, 3, 40, 20, 0, 931, 930, 1, 0, 0, 0, 931, 932, 1, 0, 0, 0, 932, 933, 1, 0, 0, 0, 933, 936, 5, 147, 0, 0, 934, 936, 3, 132, 66, 0, 935, 786, 1, 0, 0, 0, 935, 806, 1, 0, 0, 0, 935, 813, 1, 0, 0, 0, 935, 815, 1, 0, 0, 0, 935, 819, 1, 0, 0, 0, 935, 830, 1, 0, 0, 0, 935, 832, 1, 0, 0, 0, 935, 840, 1, 0, 0, 0, 935, 862, 1, 0, 0, 0, 935, 882, 1, 0, 0, 0, 935, 899, 1, 0, 0, 0, 935, 900, 1, 0, 0, 0, 935, 901, 1, 0, 0, 0, 935, 902, 1, 0, 0, 0, 935, 904, 1, 0, 0, 0, 935, 909, 1, 0, 0, 0, 935, 912, 1, 0, 0, 0, 935, 916, 1, 0, 0, 0, 935, 920, 1, 0, 0, 0, 935, 924, 1, 0, 0, 0, 935, 929, 1, 0, 0, 0, 935, 934, 1, 0, 0, 0, 936, 1041, 1, 0, 0, 0, 937, 941, 10, 18, 0, 0, 938, 942, 5, 112, 0, 0, 939, 942, 5, 151, 0, 0, 940, 942, 5, 138, 0, 0, 941, 938, 1, 0, 0, 0, 941, 939, 1, 0, 0, 0, 941, 940, 1, 0, 0, 0, 942, 943, 1, 0, 0, 0, 943, 1040, 3, 116, 58, 19, 944, 948, 10, 17, 0, 0, 945, 949, 5, 139, 0, 0, 946, 949, 5, 118, 0, 0, 947, 949, 5, 117, 0, 0, 948, 945, 1, 0, 0, 0, 948, 946, 1, 0, 0, 0, 948, 947, 1, 0, 0, 0, 949, 950, 1, 0, 0, 0, 950, 1040, 3, 116, 58, 18, 951, 976, 10, 16, 0, 0, 952, 977, 5, 121, 0, 0, 953, 977, 5, 122, 0, 0, 954, 977, 5, 133, 0, 0, 955, 977, 5, 131, 0, 0, 956, 977, 5, 132, 0, 0, 957, 977, 5, 123, 0, 0, 958, 977, 5, 124, 0, 0, 959, 961, 5, 58, 0, 0, 960, 959, 1, 0, 0, 0, 960, 961, 1, 0, 0, 0, 961, 962, 1, 0, 0, 0, 962, 964, 5, 42, 0, 0, 963, 965, 5, 15, 0, 0, 964, 963, 1, 0, 0, 0, 964, 965, 1, 0, 0, 0, 965, 977, 1, 0, 0, 0, 966, 968, 5, 58, 0, 0, 967, 966, 1, 0, 0, 0, 967, 968, 1, 0, 0, 0, 968, 969, 1, 0, 0, 0, 969, 977, 7, 10, 0, 0, 970, 977, 5, 145, 0, 0, 971, 977, 5, 146, 0, 0, 972, 977, 5, 135, 0, 0, 973, 977, 5, 126, 0, 0, 974, 977, 5, 127, 0, 0, 975, 977, 5, 134, 0, 0, 976, 952, 1, 0, 0, 0, 976, 953, 1, 0, 0, 0, 976, 954, 1, 0, 0, 0, 976, 955, 1, 0, 0, 0, 976, 956, 1, 0, 0, 0, 976, 957, 1, 0, 0, 0, 976, 958, 1, 0, 0, 0, 976, 960, 1, 0, 0, 0, 976, 967, 1, 0, 0, 0, 976, 970, 1, 0, 0, 0, 976, 971, 1, 0, 0, 0, 976, 972, 1, 0, 0, 0, 976, 973, 1, 0, 0, 0, 976, 974, 1, 0, 0, 0, 976, 975, 1, 0, 0, 0, 977, 978, 1, 0, 0, 0, 978, 1040, 3, 116, 58, 17, 979, 980, 10, 14, 0, 0, 980, 981, 5, 137, 0, 0, 981, 1040, 3, 116, 58, 15, 982, 983, 10, 12, 0, 0, 983, 984, 5, 2, 0, 0, 984, 1040, 3, 116, 58, 13, 985, 986, 10, 11, 0, 0, 986, 987, 5, 63, 0, 0, 987, 1040, 3, 116, 58, 12, 988, 990, 10, 10, 0, 0, 989, 991, 5, 58, 0, 0, 990, 989, 1, 0, 0, 0, 990, 991, 1, 0, 0, 0, 991, 992, 1, 0, 0, 0, 992, 993, 5, 9, 0, 0, 993, 994, 3, 116, 58, 0, 994, 995, 5, 2, 0, 0, 995, 996, 3, 116, 58, 11, 996, 1040, 1, 0, 0, 0, 997, 998, 10, 9, 0, 0, 998, 999, 5, 140, 0, 0, 999, 1000, 3, 116, 58, 0, 1000, 1001, 5, 115, 0, 0, 1001, 1002, 3, 116, 58, 9, 1002, 1040, 1, 0, 0, 0, 1003, 1004, 10, 25, 0, 0, 1004, 1005, 5, 129, 0, 0, 1005, 1006, 3, 116, 58, 0, 1006, 1007, 5, 148, 0, 0, 1007, 1040, 1, 0, 0, 0, 1008, 1009, 10, 24, 0, 0, 1009, 1010, 5, 120, 0, 0, 1010, 1040, 5, 108, 0, 0, 1011, 1012, 10, 23, 0, 0, 1012, 1013, 5, 120, 0, 0, 1013, 1040, 3, 160, 80, 0, 1014, 1015, 10, 22, 0, 0, 1015, 1016, 5, 136, 0, 0, 1016, 1017, 5, 129, 0, 0, 1017, 1018, 3, 116, 58, 0, 1018, 1019, 5, 148, 0, 0, 1019, 1040, 1, 0, 0, 0, 1020, 1021, 10, 21, 0, 0, 1021, 1022, 5, 136, 0, 0, 1022, 1040, 5, 108, 0, 0, 1023, 1024, 10, 20, 0, 0, 1024, 1025, 5, 136, 0, 0, 1025, 1040, 3, 160, 80, 0, 1026, 1027, 10, 15, 0, 0, 1027, 1029, 5, 46, 0, 0, 1028, 1030, 5, 58, 0, 0, 1029, 1028, 1, 0, 0, 0, 1029, 1030, 1, 0, 0, 0, 1030, 1031, 1, 0, 0, 0, 1031, 1040, 5, 59, 0, 0, 1032, 1037, 10, 8, 0, 0, 1033, 1034, 5, 6, 0, 0, 1034, 1038, 3, 160, 80, 0, 1035, 1036, 5, 6, 0, 0, 1036, 1038, 5, 110, 0, 0, 1037, 1033, 1, 0, 0, 0, 1037, 1035, 1, 0, 0, 0, 1038, 1040, 1, 0, 0, 0, 1039, 937, 1, 0, 0, 0, 1039, 944, 1, 0, 0, 0, 1039, 951, 1, 0, 0, 0, 1039, 979, 1, 0, 0, 0, 1039, 982, 1, 0, 0, 0, 1039, 985, 1, 0, 0, 0, 1039, 988, 1, 0, 0, 0, 1039, 997, 1, 0, 0, 0, 1039, 1003, 1, 0, 0, 0, 1039, 1008, 1, 0, 0, 0, 1039, 1011, 1, 0, 0, 0, 1039, 1014, 1, 0, 0, 0, 1039, 1020, 1, 0, 0, 0, 1039, 1023, 1, 0, 0, 0, 1039, 1026, 1, 0, 0, 0, 1039, 1032, 1, 0, 0, 0, 1040, 1043, 1, 0, 0, 0, 1041, 1039, 1, 0, 0, 0, 1041, 1042, 1, 0, 0, 0, 1042, 117, 1, 0, 0, 0, 1043, 1041, 1, 0, 0, 0, 1044, 1049, 3, 120, 60, 0, 1045, 1046, 5, 116, 0, 0, 1046, 1048, 3, 120, 60, 0, 1047, 1045, 1, 0, 0, 0, 1048, 1051, 1, 0, 0, 0, 1049, 1047, 1, 0, 0, 0, 1049, 1050, 1, 0, 0, 0, 1050, 1053, 1, 0, 0, 0, 1051, 1049, 1, 0, 0, 0, 1052, 1054, 5, 116, 0, 0, 1053, 1052, 1, 0, 0, 0, 1053, 1054, 1, 0, 0, 0, 1054, 119, 1, 0, 0, 0, 1055, 1058, 3, 122, 61, 0, 1056, 1058, 3, 116, 58, 0, 1057, 1055, 1, 0, 0, 0, 1057, 1056, 1, 0, 0, 0, 1058, 121, 1, 0, 0, 0, 1059, 1060, 5, 130, 0, 0, 1060, 1065, 3, 160, 80, 0, 1061, 1062, 5, 116, 0, 0, 1062, 1064, 3, 160, 80, 0, 1063, 1061, 1, 0, 0, 0, 1064, 1067, 1, 0, 0, 0, 1065, 1063, 1, 0, 0, 0, 1065, 1066, 1, 0, 0, 0, 1066, 1069, 1, 0, 0, 0, 1067, 1065, 1, 0, 0, 0, 1068, 1070, 5, 116, 0, 0, 1069, 1068, 1, 0, 0, 0, 1069, 1070, 1, 0, 0, 0, 1070, 1071, 1, 0, 0, 0, 1071, 1072, 5, 149, 0, 0, 1072, 1085, 1, 0, 0, 0, 1073, 1078, 3, 160, 80, 0, 1074, 1075, 5, 116, 0, 0, 1075, 1077, 3, 160, 80, 0, 1076, 1074, 1, 0, 0, 0, 1077, 1080, 1, 0, 0, 0, 1078, 1076, 1, 0, 0, 0, 1078, 1079, 1, 0, 0, 0, 1079, 1082, 1, 0, 0, 0, 1080, 1078, 1, 0, 0, 0, 1081, 1083, 5, 116, 0, 0, 1082, 1081, 1, 0, 0, 0, 1082, 1083, 1, 0, 0, 0, 1083, 1085, 1, 0, 0, 0, 1084, 1059, 1, 0, 0, 0, 1084, 1073, 1, 0, 0, 0, 1085, 1086, 1, 0, 0, 0, 1086, 1087, 5, 111, 0, 0, 1087, 1088, 3, 116, 58, 0, 1088, 123, 1, 0, 0, 0, 1089, 1090, 5, 132, 0, 0, 1090, 1094, 3, 160, 80, 0, 1091, 1093, 3, 126, 63, 0, 1092, 1091, 1, 0, 0, 0, 1093, 1096, 1, 0, 0, 0, 1094, 1092, 1, 0, 0, 0, 1094, 1095, 1, 0, 0, 0, 1095, 1097, 1, 0, 0, 0, 1096, 1094, 1, 0, 0, 0, 1097, 1098, 5, 151, 0, 0, 1098, 1099, 5, 124, 0, 0, 1099, 1122, 1, 0, 0, 0, 1100, 1101, 5, 132, 0, 0, 1101, 1105, 3, 160, 80, 0, 1102, 1104, 3, 126, 63, 0, 1103, 1102, 1, 0, 0, 0, 1104, 1107, 1, 0, 0, 0, 1105, 1103, 1, 0, 0, 0, 1105, 1106, 1, 0, 0, 0, 1106, 1108, 1, 0, 0, 0, 1107, 1105, 1, 0, 0, 0, 1108, 1114, 5, 124, 0, 0, 1109, 1115, 3, 124, 62, 0, 1110, 1111, 5, 128, 0, 0, 1111, 1112, 3, 116, 58, 0, 1112, 1113, 5, 147, 0, 0, 1113, 1115, 1, 0, 0, 0, 1114, 1109, 1, 0, 0, 0, 1114, 1110, 1, 0, 0, 0, 1114, 1115, 1, 0, 0, 0, 1115, 1116, 1, 0, 0, 0, 1116, 1117, 5, 132, 0, 0, 1117, 1118, 5, 151, 0, 0, 1118, 1119, 3, 160, 80, 0, 1119, 1120, 5, 124, 0, 0, 1120, 1122, 1, 0, 0, 0, 1121, 1089, 1, 0, 0, 0, 1121, 1100, 1, 0, 0, 0, 1122, 125, 1, 0, 0, 0, 1123, 1124, 3, 160, 80, 0, 1124, 1125, 5, 122, 0, 0, 1125, 1126, 3, 166, 83, 0, 1126, 1135, 1, 0, 0, 0, 1127, 1128, 3, 160, 80, 0, 1128, 1129, 5, 122, 0, 0, 1129, 1130, 5, 128, 0, 0, 1130, 1131, 3, 116, 58, 0, 1131, 1132, 5, 147, 0, 0, 1132, 1135, 1, 0, 0, 0, 1133, 1135, 3, 160, 80, 0, 1134, 1123, 1, 0, 0, 0, 1134, 1127, 1, 0, 0, 0, 1134, 1133, 1, 0, 0, 0, 1135, 127, 1, 0, 0, 0, 1136, 1141, 3, 130, 65, 0, 1137, 1138, 5, 116, 0, 0, 1138, 1140, 3, 130, 65, 0, 1139, 1137, 1, 0, 0, 0, 1140, 1143, 1, 0, 0, 0, 1141, 1139, 1, 0, 0, 0, 1141, 1142, 1, 0, 0, 0, 1142, 1145, 1, 0, 0, 0, 1143, 1141, 1, 0, 0, 0, 1144, 1146, 5, 116, 0, 0, 1145, 1144, 1, 0, 0, 0, 1145, 1146, 1, 0, 0, 0, 1146, 129, 1, 0, 0, 0, 1147, 1148, 3, 160, 80, 0, 1148, 1149, 5, 6, 0, 0, 1149, 1150, 5, 130, 0, 0, 1150, 1151, 3, 44, 22, 0, 1151, 1152, 5, 149, 0, 0, 1152, 1158, 1, 0, 0, 0, 1153, 1154, 3, 116, 58, 0, 1154, 1155, 5, 6, 0, 0, 1155, 1156, 3, 160, 80, 0, 1156, 1158, 1, 0, 0, 0, 1157, 1147, 1, 0, 0, 0, 1157, 1153, 1, 0, 0, 0, 1158, 131, 1, 0, 0, 0, 1159, 1167, 3, 164, 82, 0, 1160, 1161, 3, 140, 70, 0, 1161, 1162, 5, 120, 0, 0, 1162, 1164, 1, 0, 0, 0, 1163, 1160, 1, 0, 0, 0, 1163, 1164, 1, 0, 0, 0, 1164, 1165, 1, 0, 0, 0, 1165, 1167, 3, 134, 67, 0, 1166, 1159, 1, 0, 0, 0, 1166, 1163, 1, 0, 0, 0, 1167, 133, 1, 0, 0, 0, 1168, 1173, 3, 160, 80, 0, 1169, 1170, 5, 120, 0, 0, 1170, 1172, 3, 160, 80, 0, 1171, 1169, 1, 0, 0, 0, 1172, 1175, 1, 0, 0, 0, 1173, 1171, 1, 0, 0, 0, 1173, 1174, 1, 0, 0, 0, 1174, 135, 1, 0, 0, 0, 1175, 1173, 1, 0, 0, 0, 1176, 1177, 6, 68, -1, 0, 1177, 1186, 3, 140, 70, 0, 1178, 1186, 3, 138, 69, 0, 1179, 1180, 5, 130, 0, 0, 1180, 1181, 3, 44, 22, 0, 1181, 1182, 5, 149, 0, 0, 1182, 1186, 1, 0, 0, 0, 1183, 1186, 3, 124, 62, 0, 1184, 1186, 3, 164, 82, 0, 1185, 1176, 1, 0, 0, 0, 1185, 1178, 1, 0, 0, 0, 1185, 1179, 1, 0, 0, 0, 1185, 1183, 1, 0, 0, 0, 1185, 1184, 1, 0, 0, 0, 1186, 1195, 1, 0, 0, 0, 1187, 1191, 10, 3, 0, 0, 1188, 1192, 3, 158, 79, 0, 1189, 1190, 5, 6, 0, 0, 1190, 1192, 3, 160, 80, 0, 1191, 1188, 1, 0, 0, 0, 1191, 1189, 1, 0, 0, 0, 1192, 1194, 1, 0, 0, 0, 1193, 1187, 1, 0, 0, 0, 1194, 1197, 1, 0, 0, 0, 1195, 1193, 1, 0, 0, 0, 1195, 1196, 1, 0, 0, 0, 1196, 137, 1, 0, 0, 0, 1197, 1195, 1, 0, 0, 0, 1198, 1199, 3, 160, 80, 0, 1199, 1201, 5, 130, 0, 0, 1200, 1202, 3, 142, 71, 0, 1201, 1200, 1, 0, 0, 0, 1201, 1202, 1, 0, 0, 0, 1202, 1203, 1, 0, 0, 0, 1203, 1204, 5, 149, 0, 0, 1204, 139, 1, 0, 0, 0, 1205, 1206, 3, 144, 72, 0, 1206, 1207, 5, 120, 0, 0, 1207, 1209, 1, 0, 0, 0, 1208, 1205, 1, 0, 0, 0, 1208, 1209, 1, 0, 0, 0, 1209, 1210, 1, 0, 0, 0, 1210, 1211, 3, 160, 80, 0, 1211, 141, 1, 0, 0, 0, 1212, 1217, 3, 116, 58, 0, 1213, 1214, 5, 116, 0, 0, 1214, 1216, 3, 116, 58, 0, 1215, 1213, 1, 0, 0, 0, 1216, 1219, 1, 0, 0, 0, 1217, 1215, 1, 0, 0, 0, 1217, 1218, 1, 0, 0, 0, 1218, 1221, 1, 0, 0, 0, 1219, 1217, 1, 0, 0, 0, 1220, 1222, 5, 116, 0, 0, 1221, 1220, 1, 0, 0, 0, 1221, 1222, 1, 0, 0, 0, 1222, 143, 1, 0, 0, 0, 1223, 1224, 3, 160, 80, 0, 1224, 145, 1, 0, 0, 0, 1225, 1234, 5, 106, 0, 0, 1226, 1227, 5, 120, 0, 0, 1227, 1234, 7, 11, 0, 0, 1228, 1229, 5, 108, 0, 0, 1229, 1231, 5, 120, 0, 0, 1230, 1232, 7, 11, 0, 0, 1231, 1230, 1, 0, 0, 0, 1231, 1232, 1, 0, 0, 0, 1232, 1234, 1, 0, 0, 0, 1233, 1225, 1, 0, 0, 0, 1233, 1226, 1, 0, 0, 0, 1233, 1228, 1, 0, 0, 0, 1234, 147, 1, 0, 0, 0, 1235, 1237, 7, 12, 0, 0, 1236, 1235, 1, 0, 0, 0, 1236, 1237, 1, 0, 0, 0, 1237, 1244, 1, 0, 0, 0, 1238, 1245, 3, 146, 73, 0, 1239, 1245, 5, 107, 0, 0, 1240, 1245, 5, 108, 0, 0, 1241, 1245, 5, 109, 0, 0, 1242, 1245, 5, 43, 0, 0, 1243, 1245, 5, 57, 0, 0, 1244, 1238, 1, 0, 0, 0, 1244, 1239, 1, 0, 0, 0, 1244, 1240, 1, 0, 0, 0, 1244, 1241, 1, 0, 0, 0, 1244, 1242, 1, 0, 0, 0, 1244, 1243, 1, 0, 0, 0, 1245, 149, 1, 0, 0, 0, 1246, 1250, 3, 148, 74, 0, 1247, 1250, 5, 110, 0, 0, 1248, 1250, 5, 59, 0, 0, 1249, 1246, 1, 0, 0, 0, 1249, 1247, 1, 0, 0, 0, 1249, 1248, 1, 0, 0, 0, 1250, 151, 1, 0, 0, 0, 1251, 1252, 7, 13, 0, 0, 1252, 153, 1, 0, 0, 0, 1253, 1254, 7, 14, 0, 0, 1254, 155, 1, 0, 0, 0, 1255, 1256, 7, 15, 0, 0, 1256, 157, 1, 0, 0, 0, 1257, 1260, 5, 105, 0, 0, 1258, 1260, 3, 156, 78, 0, 1259, 1257, 1, 0, 0, 0, 1259, 1258, 1, 0, 0, 0, 1260, 159, 1, 0, 0, 0, 1261, 1265, 5, 105, 0, 0, 1262, 1265, 3, 152, 76, 0, 1263, 1265, 3, 154, 77, 0, 1264, 1261, 1, 0, 0, 0, 1264, 1262, 1, 0, 0, 0, 1264, 1263, 1, 0, 0, 0, 1265, 161, 1, 0, 0, 0, 1266, 1267, 3, 166, 83, 0, 1267, 1268, 5, 122, 0, 0, 1268, 1269, 3, 148, 74, 0, 1269, 163, 1, 0, 0, 0, 1270, 1271, 5, 128, 0, 0, 1271, 1272, 3, 134, 67, 0, 1272, 1273, 5, 147, 0, 0, 1273, 165, 1, 0, 0, 0, 1274, 1277, 5, 110, 0, 0, 1275, 1277, 3, 168, 84, 0, 1276, 1274, 1, 0, 0, 0, 1276, 1275, 1, 0, 0, 0, 1277, 167, 1, 0, 0, 0, 1278, 1282, 5, 142, 0, 0, 1279, 1281, 3, 170, 85, 0, 1280, 1279, 1, 0, 0, 0, 1281, 1284, 1, 0, 0, 0, 1282, 1280, 1, 0, 0, 0, 1282, 1283, 1, 0, 0, 0, 1283, 1285, 1, 0, 0, 0, 1284, 1282, 1, 0, 0, 0, 1285, 1286, 5, 144, 0, 0, 1286, 169, 1, 0, 0, 0, 1287, 1288, 5, 157, 0, 0, 1288, 1289, 3, 116, 58, 0, 1289, 1290, 5, 147, 0, 0, 1290, 1293, 1, 0, 0, 0, 1291, 1293, 5, 156, 0, 0, 1292, 1287, 1, 0, 0, 0, 1292, 1291, 1, 0, 0, 0, 1293, 171, 1, 0, 0, 0, 1294, 1298, 5, 143, 0, 0, 1295, 1297, 3, 174, 87, 0, 1296, 1295, 1, 0, 0, 0, 1297, 1300, 1, 0, 0, 0, 1298, 1296, 1, 0, 0, 0, 1298, 1299, 1, 0, 0, 0, 1299, 1301, 1, 0, 0, 0, 1300, 1298, 1, 0, 0, 0, 1301, 1302, 5, 0, 0, 1, 1302, 173, 1, 0, 0, 0, 1303, 1304, 5, 159, 0, 0, 1304, 1305, 3, 116, 58, 0, 1305, 1306, 5, 147, 0, 0, 1306, 1309, 1, 0, 0, 0, 1307, 1309, 5, 158, 0, 0, 1308, 1303, 1, 0, 0, 0, 1308, 1307, 1, 0, 0, 0, 1309, 175, 1, 0, 0, 0, 168, 179, 186, 195, 202, 206, 220, 224, 227, 231, 234, 241, 245, 254, 259, 268, 276, 283, 287, 293, 298, 306, 313, 319, 331, 339, 353, 357, 362, 372, 381, 384, 388, 391, 395, 398, 401, 404, 407, 411, 415, 418, 421, 424, 428, 431, 440, 446, 467, 484, 501, 507, 513, 524, 526, 537, 540, 546, 554, 560, 562, 566, 571, 574, 577, 581, 585, 588, 590, 593, 597, 601, 604, 606, 608, 613, 624, 630, 637, 642, 646, 650, 656, 658, 665, 673, 676, 679, 698, 712, 728, 732, 743, 747, 758, 762, 769, 773, 780, 784, 789, 798, 802, 826, 843, 849, 852, 855, 865, 871, 874, 877, 885, 888, 892, 895, 909, 926, 931, 935, 941, 948, 960, 964, 967, 976, 990, 1029, 1037, 1039, 1041, 1049, 1053, 1057, 1065, 1069, 1078, 1082, 1084, 1094, 1105, 1114, 1121, 1134, 1141, 1145, 1157, 1163, 1166, 1173, 1185, 1191, 1195, 1201, 1208, 1217, 1221, 1231, 1233, 1236, 1244, 1249, 1259, 1264, 1276, 1282, 1292, 1298, 1308] \ No newline at end of file +[4, 1, 159, 1303, 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, 1, 0, 5, 0, 174, 8, 0, 10, 0, 12, 0, 177, 9, 0, 1, 0, 1, 0, 1, 1, 1, 1, 3, 1, 183, 8, 1, 1, 2, 1, 2, 1, 3, 1, 3, 1, 3, 1, 3, 1, 3, 3, 3, 192, 8, 3, 1, 4, 1, 4, 1, 4, 5, 4, 197, 8, 4, 10, 4, 12, 4, 200, 9, 4, 1, 4, 3, 4, 203, 8, 4, 1, 5, 1, 5, 1, 5, 1, 5, 1, 5, 1, 5, 1, 5, 1, 5, 1, 5, 1, 5, 1, 5, 1, 5, 3, 5, 217, 8, 5, 1, 6, 1, 6, 3, 6, 221, 8, 6, 1, 6, 3, 6, 224, 8, 6, 1, 7, 1, 7, 3, 7, 228, 8, 7, 1, 7, 3, 7, 231, 8, 7, 1, 8, 1, 8, 1, 8, 1, 8, 1, 8, 3, 8, 238, 8, 8, 1, 8, 1, 8, 3, 8, 242, 8, 8, 1, 8, 1, 8, 1, 9, 1, 9, 1, 9, 5, 9, 249, 8, 9, 10, 9, 12, 9, 252, 9, 9, 1, 9, 1, 9, 3, 9, 256, 8, 9, 1, 10, 1, 10, 1, 10, 1, 10, 1, 10, 1, 10, 1, 10, 3, 10, 265, 8, 10, 1, 11, 1, 11, 1, 11, 1, 11, 1, 11, 1, 11, 3, 11, 273, 8, 11, 1, 12, 1, 12, 1, 12, 1, 12, 1, 12, 3, 12, 280, 8, 12, 1, 12, 1, 12, 3, 12, 284, 8, 12, 1, 12, 1, 12, 1, 12, 1, 12, 3, 12, 290, 8, 12, 1, 12, 1, 12, 1, 12, 3, 12, 295, 8, 12, 1, 13, 1, 13, 1, 13, 1, 13, 1, 13, 1, 13, 3, 13, 303, 8, 13, 1, 13, 1, 13, 1, 13, 1, 13, 1, 13, 3, 13, 310, 8, 13, 1, 14, 1, 14, 1, 14, 1, 14, 3, 14, 316, 8, 14, 1, 14, 1, 14, 1, 14, 1, 15, 1, 15, 1, 15, 1, 15, 1, 15, 1, 16, 1, 16, 3, 16, 328, 8, 16, 1, 17, 1, 17, 1, 18, 1, 18, 5, 18, 334, 8, 18, 10, 18, 12, 18, 337, 9, 18, 1, 18, 1, 18, 1, 19, 1, 19, 1, 19, 1, 19, 1, 20, 1, 20, 1, 20, 5, 20, 348, 8, 20, 10, 20, 12, 20, 351, 9, 20, 1, 20, 3, 20, 354, 8, 20, 1, 21, 1, 21, 1, 21, 3, 21, 359, 8, 21, 1, 21, 1, 21, 1, 22, 1, 22, 1, 22, 1, 22, 5, 22, 367, 8, 22, 10, 22, 12, 22, 370, 9, 22, 1, 23, 1, 23, 1, 23, 1, 23, 1, 23, 1, 23, 3, 23, 378, 8, 23, 1, 24, 3, 24, 381, 8, 24, 1, 24, 1, 24, 3, 24, 385, 8, 24, 1, 24, 3, 24, 388, 8, 24, 1, 24, 1, 24, 3, 24, 392, 8, 24, 1, 24, 3, 24, 395, 8, 24, 1, 24, 3, 24, 398, 8, 24, 1, 24, 3, 24, 401, 8, 24, 1, 24, 3, 24, 404, 8, 24, 1, 24, 1, 24, 3, 24, 408, 8, 24, 1, 24, 1, 24, 3, 24, 412, 8, 24, 1, 24, 3, 24, 415, 8, 24, 1, 24, 3, 24, 418, 8, 24, 1, 24, 3, 24, 421, 8, 24, 1, 24, 1, 24, 3, 24, 425, 8, 24, 1, 24, 3, 24, 428, 8, 24, 1, 25, 1, 25, 1, 25, 1, 26, 1, 26, 1, 26, 1, 26, 3, 26, 437, 8, 26, 1, 27, 1, 27, 1, 27, 1, 28, 3, 28, 443, 8, 28, 1, 28, 1, 28, 1, 28, 1, 28, 1, 29, 1, 29, 1, 29, 1, 29, 1, 29, 1, 29, 1, 29, 1, 29, 1, 29, 1, 29, 1, 29, 1, 29, 1, 29, 5, 29, 462, 8, 29, 10, 29, 12, 29, 465, 9, 29, 1, 30, 1, 30, 1, 30, 1, 31, 1, 31, 1, 31, 1, 32, 1, 32, 1, 32, 1, 32, 1, 32, 1, 32, 1, 32, 1, 32, 3, 32, 481, 8, 32, 1, 33, 1, 33, 1, 33, 1, 34, 1, 34, 1, 34, 1, 34, 1, 35, 1, 35, 1, 35, 1, 35, 1, 36, 1, 36, 1, 36, 1, 36, 3, 36, 498, 8, 36, 1, 36, 1, 36, 1, 36, 1, 36, 3, 36, 504, 8, 36, 1, 36, 1, 36, 1, 36, 1, 36, 3, 36, 510, 8, 36, 1, 36, 1, 36, 1, 36, 1, 36, 1, 36, 1, 36, 1, 36, 1, 36, 1, 36, 3, 36, 521, 8, 36, 3, 36, 523, 8, 36, 1, 37, 1, 37, 1, 37, 1, 38, 1, 38, 1, 38, 1, 39, 1, 39, 1, 39, 3, 39, 534, 8, 39, 1, 39, 3, 39, 537, 8, 39, 1, 39, 1, 39, 1, 39, 1, 39, 3, 39, 543, 8, 39, 1, 39, 1, 39, 1, 39, 1, 39, 1, 39, 1, 39, 3, 39, 551, 8, 39, 1, 39, 1, 39, 1, 39, 1, 39, 5, 39, 557, 8, 39, 10, 39, 12, 39, 560, 9, 39, 1, 40, 3, 40, 563, 8, 40, 1, 40, 1, 40, 1, 40, 3, 40, 568, 8, 40, 1, 40, 3, 40, 571, 8, 40, 1, 40, 3, 40, 574, 8, 40, 1, 40, 1, 40, 3, 40, 578, 8, 40, 1, 40, 1, 40, 3, 40, 582, 8, 40, 1, 40, 3, 40, 585, 8, 40, 3, 40, 587, 8, 40, 1, 40, 3, 40, 590, 8, 40, 1, 40, 1, 40, 3, 40, 594, 8, 40, 1, 40, 1, 40, 3, 40, 598, 8, 40, 1, 40, 3, 40, 601, 8, 40, 3, 40, 603, 8, 40, 3, 40, 605, 8, 40, 1, 41, 1, 41, 1, 41, 3, 41, 610, 8, 41, 1, 42, 1, 42, 1, 42, 1, 42, 1, 42, 1, 42, 1, 42, 1, 42, 1, 42, 3, 42, 621, 8, 42, 1, 43, 1, 43, 1, 43, 1, 43, 3, 43, 627, 8, 43, 1, 44, 1, 44, 1, 44, 5, 44, 632, 8, 44, 10, 44, 12, 44, 635, 9, 44, 1, 45, 1, 45, 3, 45, 639, 8, 45, 1, 45, 1, 45, 3, 45, 643, 8, 45, 1, 45, 1, 45, 3, 45, 647, 8, 45, 1, 46, 1, 46, 1, 46, 1, 46, 3, 46, 653, 8, 46, 3, 46, 655, 8, 46, 1, 47, 1, 47, 1, 47, 5, 47, 660, 8, 47, 10, 47, 12, 47, 663, 9, 47, 1, 48, 1, 48, 1, 48, 1, 48, 1, 49, 3, 49, 670, 8, 49, 1, 49, 3, 49, 673, 8, 49, 1, 49, 3, 49, 676, 8, 49, 1, 50, 1, 50, 1, 50, 1, 50, 1, 51, 1, 51, 1, 51, 1, 51, 1, 52, 1, 52, 1, 52, 1, 53, 1, 53, 1, 53, 1, 53, 1, 53, 1, 53, 3, 53, 695, 8, 53, 1, 54, 1, 54, 1, 54, 1, 54, 1, 54, 1, 54, 1, 54, 1, 54, 1, 54, 1, 54, 1, 54, 1, 54, 3, 54, 709, 8, 54, 1, 55, 1, 55, 1, 55, 1, 56, 1, 56, 1, 56, 1, 56, 1, 56, 1, 56, 1, 56, 1, 56, 1, 56, 5, 56, 723, 8, 56, 10, 56, 12, 56, 726, 9, 56, 1, 56, 3, 56, 729, 8, 56, 1, 56, 1, 56, 1, 56, 1, 56, 1, 56, 1, 56, 1, 56, 5, 56, 738, 8, 56, 10, 56, 12, 56, 741, 9, 56, 1, 56, 3, 56, 744, 8, 56, 1, 56, 1, 56, 1, 56, 1, 56, 1, 56, 1, 56, 1, 56, 5, 56, 753, 8, 56, 10, 56, 12, 56, 756, 9, 56, 1, 56, 3, 56, 759, 8, 56, 1, 56, 1, 56, 1, 56, 1, 56, 1, 56, 3, 56, 766, 8, 56, 1, 56, 1, 56, 3, 56, 770, 8, 56, 1, 57, 1, 57, 1, 57, 5, 57, 775, 8, 57, 10, 57, 12, 57, 778, 9, 57, 1, 57, 3, 57, 781, 8, 57, 1, 58, 1, 58, 1, 58, 3, 58, 786, 8, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 4, 58, 793, 8, 58, 11, 58, 12, 58, 794, 1, 58, 1, 58, 3, 58, 799, 8, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 3, 58, 823, 8, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 3, 58, 840, 8, 58, 1, 58, 1, 58, 1, 58, 1, 58, 3, 58, 846, 8, 58, 1, 58, 3, 58, 849, 8, 58, 1, 58, 3, 58, 852, 8, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 3, 58, 862, 8, 58, 1, 58, 1, 58, 1, 58, 1, 58, 3, 58, 868, 8, 58, 1, 58, 3, 58, 871, 8, 58, 1, 58, 3, 58, 874, 8, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 3, 58, 882, 8, 58, 1, 58, 3, 58, 885, 8, 58, 1, 58, 1, 58, 3, 58, 889, 8, 58, 1, 58, 3, 58, 892, 8, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 3, 58, 906, 8, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 3, 58, 923, 8, 58, 1, 58, 1, 58, 1, 58, 3, 58, 928, 8, 58, 1, 58, 1, 58, 1, 58, 3, 58, 933, 8, 58, 1, 58, 1, 58, 1, 58, 1, 58, 3, 58, 939, 8, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 3, 58, 946, 8, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 3, 58, 958, 8, 58, 1, 58, 1, 58, 3, 58, 962, 8, 58, 1, 58, 3, 58, 965, 8, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 3, 58, 974, 8, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 3, 58, 988, 8, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 3, 58, 1004, 8, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 3, 58, 1033, 8, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 3, 58, 1041, 8, 58, 5, 58, 1043, 8, 58, 10, 58, 12, 58, 1046, 9, 58, 1, 59, 1, 59, 1, 59, 1, 59, 5, 59, 1052, 8, 59, 10, 59, 12, 59, 1055, 9, 59, 1, 59, 3, 59, 1058, 8, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 5, 59, 1065, 8, 59, 10, 59, 12, 59, 1068, 9, 59, 1, 59, 3, 59, 1071, 8, 59, 1, 59, 1, 59, 3, 59, 1075, 8, 59, 1, 59, 1, 59, 1, 59, 3, 59, 1080, 8, 59, 1, 60, 1, 60, 1, 60, 5, 60, 1085, 8, 60, 10, 60, 12, 60, 1088, 9, 60, 1, 60, 1, 60, 1, 60, 1, 60, 1, 60, 1, 60, 5, 60, 1096, 8, 60, 10, 60, 12, 60, 1099, 9, 60, 1, 60, 1, 60, 1, 60, 1, 60, 1, 60, 1, 60, 3, 60, 1107, 8, 60, 1, 60, 1, 60, 1, 60, 1, 60, 1, 60, 3, 60, 1114, 8, 60, 1, 61, 1, 61, 1, 61, 1, 61, 1, 61, 1, 61, 1, 61, 1, 61, 1, 61, 1, 61, 1, 61, 3, 61, 1127, 8, 61, 1, 62, 1, 62, 1, 62, 5, 62, 1132, 8, 62, 10, 62, 12, 62, 1135, 9, 62, 1, 62, 3, 62, 1138, 8, 62, 1, 63, 1, 63, 1, 63, 1, 63, 1, 63, 1, 63, 1, 63, 1, 63, 1, 63, 1, 63, 3, 63, 1150, 8, 63, 1, 64, 1, 64, 1, 64, 1, 64, 3, 64, 1156, 8, 64, 1, 64, 3, 64, 1159, 8, 64, 1, 65, 1, 65, 1, 65, 5, 65, 1164, 8, 65, 10, 65, 12, 65, 1167, 9, 65, 1, 66, 1, 66, 1, 66, 1, 66, 1, 66, 1, 66, 1, 66, 1, 66, 1, 66, 3, 66, 1178, 8, 66, 1, 66, 1, 66, 1, 66, 1, 66, 3, 66, 1184, 8, 66, 5, 66, 1186, 8, 66, 10, 66, 12, 66, 1189, 9, 66, 1, 67, 1, 67, 1, 67, 3, 67, 1194, 8, 67, 1, 67, 1, 67, 1, 68, 1, 68, 1, 68, 3, 68, 1201, 8, 68, 1, 68, 1, 68, 1, 69, 1, 69, 1, 69, 5, 69, 1208, 8, 69, 10, 69, 12, 69, 1211, 9, 69, 1, 69, 3, 69, 1214, 8, 69, 1, 70, 1, 70, 1, 71, 1, 71, 1, 71, 1, 71, 1, 71, 1, 71, 3, 71, 1224, 8, 71, 3, 71, 1226, 8, 71, 1, 72, 3, 72, 1229, 8, 72, 1, 72, 1, 72, 1, 72, 1, 72, 1, 72, 1, 72, 3, 72, 1237, 8, 72, 1, 73, 1, 73, 1, 73, 3, 73, 1242, 8, 73, 1, 74, 1, 74, 1, 75, 1, 75, 1, 76, 1, 76, 1, 77, 1, 77, 3, 77, 1252, 8, 77, 1, 78, 1, 78, 1, 78, 3, 78, 1257, 8, 78, 1, 79, 1, 79, 1, 79, 1, 79, 1, 80, 1, 80, 1, 80, 1, 80, 1, 81, 1, 81, 3, 81, 1269, 8, 81, 1, 82, 1, 82, 5, 82, 1273, 8, 82, 10, 82, 12, 82, 1276, 9, 82, 1, 82, 1, 82, 1, 83, 1, 83, 1, 83, 1, 83, 1, 83, 3, 83, 1285, 8, 83, 1, 84, 1, 84, 5, 84, 1289, 8, 84, 10, 84, 12, 84, 1292, 9, 84, 1, 84, 1, 84, 1, 85, 1, 85, 1, 85, 1, 85, 1, 85, 3, 85, 1301, 8, 85, 1, 85, 0, 3, 78, 116, 132, 86, 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, 0, 16, 2, 0, 18, 18, 74, 74, 2, 0, 44, 44, 51, 51, 3, 0, 1, 1, 4, 4, 8, 8, 4, 0, 1, 1, 3, 4, 8, 8, 80, 80, 2, 0, 51, 51, 73, 73, 2, 0, 1, 1, 4, 4, 2, 0, 7, 7, 22, 23, 2, 0, 30, 30, 49, 49, 2, 0, 71, 71, 76, 76, 3, 0, 10, 10, 50, 50, 90, 90, 2, 0, 41, 41, 53, 53, 1, 0, 107, 108, 2, 0, 118, 118, 139, 139, 7, 0, 21, 21, 38, 38, 55, 56, 70, 70, 78, 78, 97, 97, 103, 103, 16, 0, 1, 13, 15, 20, 22, 28, 30, 30, 32, 37, 39, 42, 44, 51, 53, 54, 58, 58, 60, 69, 71, 77, 79, 83, 85, 92, 94, 96, 98, 99, 101, 102, 4, 0, 20, 20, 30, 30, 39, 39, 48, 48, 1475, 0, 175, 1, 0, 0, 0, 2, 182, 1, 0, 0, 0, 4, 184, 1, 0, 0, 0, 6, 186, 1, 0, 0, 0, 8, 193, 1, 0, 0, 0, 10, 216, 1, 0, 0, 0, 12, 218, 1, 0, 0, 0, 14, 225, 1, 0, 0, 0, 16, 232, 1, 0, 0, 0, 18, 245, 1, 0, 0, 0, 20, 257, 1, 0, 0, 0, 22, 266, 1, 0, 0, 0, 24, 274, 1, 0, 0, 0, 26, 296, 1, 0, 0, 0, 28, 311, 1, 0, 0, 0, 30, 320, 1, 0, 0, 0, 32, 325, 1, 0, 0, 0, 34, 329, 1, 0, 0, 0, 36, 331, 1, 0, 0, 0, 38, 340, 1, 0, 0, 0, 40, 344, 1, 0, 0, 0, 42, 358, 1, 0, 0, 0, 44, 362, 1, 0, 0, 0, 46, 377, 1, 0, 0, 0, 48, 380, 1, 0, 0, 0, 50, 429, 1, 0, 0, 0, 52, 432, 1, 0, 0, 0, 54, 438, 1, 0, 0, 0, 56, 442, 1, 0, 0, 0, 58, 448, 1, 0, 0, 0, 60, 466, 1, 0, 0, 0, 62, 469, 1, 0, 0, 0, 64, 472, 1, 0, 0, 0, 66, 482, 1, 0, 0, 0, 68, 485, 1, 0, 0, 0, 70, 489, 1, 0, 0, 0, 72, 522, 1, 0, 0, 0, 74, 524, 1, 0, 0, 0, 76, 527, 1, 0, 0, 0, 78, 542, 1, 0, 0, 0, 80, 604, 1, 0, 0, 0, 82, 609, 1, 0, 0, 0, 84, 620, 1, 0, 0, 0, 86, 622, 1, 0, 0, 0, 88, 628, 1, 0, 0, 0, 90, 636, 1, 0, 0, 0, 92, 654, 1, 0, 0, 0, 94, 656, 1, 0, 0, 0, 96, 664, 1, 0, 0, 0, 98, 669, 1, 0, 0, 0, 100, 677, 1, 0, 0, 0, 102, 681, 1, 0, 0, 0, 104, 685, 1, 0, 0, 0, 106, 694, 1, 0, 0, 0, 108, 708, 1, 0, 0, 0, 110, 710, 1, 0, 0, 0, 112, 769, 1, 0, 0, 0, 114, 771, 1, 0, 0, 0, 116, 932, 1, 0, 0, 0, 118, 1074, 1, 0, 0, 0, 120, 1113, 1, 0, 0, 0, 122, 1126, 1, 0, 0, 0, 124, 1128, 1, 0, 0, 0, 126, 1149, 1, 0, 0, 0, 128, 1158, 1, 0, 0, 0, 130, 1160, 1, 0, 0, 0, 132, 1177, 1, 0, 0, 0, 134, 1190, 1, 0, 0, 0, 136, 1200, 1, 0, 0, 0, 138, 1204, 1, 0, 0, 0, 140, 1215, 1, 0, 0, 0, 142, 1225, 1, 0, 0, 0, 144, 1228, 1, 0, 0, 0, 146, 1241, 1, 0, 0, 0, 148, 1243, 1, 0, 0, 0, 150, 1245, 1, 0, 0, 0, 152, 1247, 1, 0, 0, 0, 154, 1251, 1, 0, 0, 0, 156, 1256, 1, 0, 0, 0, 158, 1258, 1, 0, 0, 0, 160, 1262, 1, 0, 0, 0, 162, 1268, 1, 0, 0, 0, 164, 1270, 1, 0, 0, 0, 166, 1284, 1, 0, 0, 0, 168, 1286, 1, 0, 0, 0, 170, 1300, 1, 0, 0, 0, 172, 174, 3, 2, 1, 0, 173, 172, 1, 0, 0, 0, 174, 177, 1, 0, 0, 0, 175, 173, 1, 0, 0, 0, 175, 176, 1, 0, 0, 0, 176, 178, 1, 0, 0, 0, 177, 175, 1, 0, 0, 0, 178, 179, 5, 0, 0, 1, 179, 1, 1, 0, 0, 0, 180, 183, 3, 6, 3, 0, 181, 183, 3, 10, 5, 0, 182, 180, 1, 0, 0, 0, 182, 181, 1, 0, 0, 0, 183, 3, 1, 0, 0, 0, 184, 185, 3, 116, 58, 0, 185, 5, 1, 0, 0, 0, 186, 187, 5, 52, 0, 0, 187, 191, 3, 156, 78, 0, 188, 189, 5, 115, 0, 0, 189, 190, 5, 122, 0, 0, 190, 192, 3, 4, 2, 0, 191, 188, 1, 0, 0, 0, 191, 192, 1, 0, 0, 0, 192, 7, 1, 0, 0, 0, 193, 198, 3, 156, 78, 0, 194, 195, 5, 116, 0, 0, 195, 197, 3, 156, 78, 0, 196, 194, 1, 0, 0, 0, 197, 200, 1, 0, 0, 0, 198, 196, 1, 0, 0, 0, 198, 199, 1, 0, 0, 0, 199, 202, 1, 0, 0, 0, 200, 198, 1, 0, 0, 0, 201, 203, 5, 116, 0, 0, 202, 201, 1, 0, 0, 0, 202, 203, 1, 0, 0, 0, 203, 9, 1, 0, 0, 0, 204, 217, 3, 12, 6, 0, 205, 217, 3, 14, 7, 0, 206, 217, 3, 18, 9, 0, 207, 217, 3, 20, 10, 0, 208, 217, 3, 22, 11, 0, 209, 217, 3, 26, 13, 0, 210, 217, 3, 24, 12, 0, 211, 217, 3, 28, 14, 0, 212, 217, 3, 30, 15, 0, 213, 217, 3, 36, 18, 0, 214, 217, 3, 32, 16, 0, 215, 217, 3, 34, 17, 0, 216, 204, 1, 0, 0, 0, 216, 205, 1, 0, 0, 0, 216, 206, 1, 0, 0, 0, 216, 207, 1, 0, 0, 0, 216, 208, 1, 0, 0, 0, 216, 209, 1, 0, 0, 0, 216, 210, 1, 0, 0, 0, 216, 211, 1, 0, 0, 0, 216, 212, 1, 0, 0, 0, 216, 213, 1, 0, 0, 0, 216, 214, 1, 0, 0, 0, 216, 215, 1, 0, 0, 0, 217, 11, 1, 0, 0, 0, 218, 220, 5, 72, 0, 0, 219, 221, 3, 4, 2, 0, 220, 219, 1, 0, 0, 0, 220, 221, 1, 0, 0, 0, 221, 223, 1, 0, 0, 0, 222, 224, 5, 150, 0, 0, 223, 222, 1, 0, 0, 0, 223, 224, 1, 0, 0, 0, 224, 13, 1, 0, 0, 0, 225, 227, 5, 84, 0, 0, 226, 228, 3, 4, 2, 0, 227, 226, 1, 0, 0, 0, 227, 228, 1, 0, 0, 0, 228, 230, 1, 0, 0, 0, 229, 231, 5, 150, 0, 0, 230, 229, 1, 0, 0, 0, 230, 231, 1, 0, 0, 0, 231, 15, 1, 0, 0, 0, 232, 241, 5, 14, 0, 0, 233, 234, 5, 130, 0, 0, 234, 237, 3, 156, 78, 0, 235, 236, 5, 115, 0, 0, 236, 238, 3, 156, 78, 0, 237, 235, 1, 0, 0, 0, 237, 238, 1, 0, 0, 0, 238, 239, 1, 0, 0, 0, 239, 240, 5, 149, 0, 0, 240, 242, 1, 0, 0, 0, 241, 233, 1, 0, 0, 0, 241, 242, 1, 0, 0, 0, 242, 243, 1, 0, 0, 0, 243, 244, 3, 36, 18, 0, 244, 17, 1, 0, 0, 0, 245, 246, 5, 93, 0, 0, 246, 250, 3, 36, 18, 0, 247, 249, 3, 16, 8, 0, 248, 247, 1, 0, 0, 0, 249, 252, 1, 0, 0, 0, 250, 248, 1, 0, 0, 0, 250, 251, 1, 0, 0, 0, 251, 255, 1, 0, 0, 0, 252, 250, 1, 0, 0, 0, 253, 254, 5, 29, 0, 0, 254, 256, 3, 36, 18, 0, 255, 253, 1, 0, 0, 0, 255, 256, 1, 0, 0, 0, 256, 19, 1, 0, 0, 0, 257, 258, 5, 40, 0, 0, 258, 259, 5, 130, 0, 0, 259, 260, 3, 4, 2, 0, 260, 261, 5, 149, 0, 0, 261, 264, 3, 10, 5, 0, 262, 263, 5, 25, 0, 0, 263, 265, 3, 10, 5, 0, 264, 262, 1, 0, 0, 0, 264, 265, 1, 0, 0, 0, 265, 21, 1, 0, 0, 0, 266, 267, 5, 100, 0, 0, 267, 268, 5, 130, 0, 0, 268, 269, 3, 4, 2, 0, 269, 270, 5, 149, 0, 0, 270, 272, 3, 10, 5, 0, 271, 273, 5, 150, 0, 0, 272, 271, 1, 0, 0, 0, 272, 273, 1, 0, 0, 0, 273, 23, 1, 0, 0, 0, 274, 275, 5, 33, 0, 0, 275, 279, 5, 130, 0, 0, 276, 280, 3, 6, 3, 0, 277, 280, 3, 30, 15, 0, 278, 280, 3, 4, 2, 0, 279, 276, 1, 0, 0, 0, 279, 277, 1, 0, 0, 0, 279, 278, 1, 0, 0, 0, 279, 280, 1, 0, 0, 0, 280, 281, 1, 0, 0, 0, 281, 283, 5, 150, 0, 0, 282, 284, 3, 4, 2, 0, 283, 282, 1, 0, 0, 0, 283, 284, 1, 0, 0, 0, 284, 285, 1, 0, 0, 0, 285, 289, 5, 150, 0, 0, 286, 290, 3, 6, 3, 0, 287, 290, 3, 30, 15, 0, 288, 290, 3, 4, 2, 0, 289, 286, 1, 0, 0, 0, 289, 287, 1, 0, 0, 0, 289, 288, 1, 0, 0, 0, 289, 290, 1, 0, 0, 0, 290, 291, 1, 0, 0, 0, 291, 292, 5, 149, 0, 0, 292, 294, 3, 10, 5, 0, 293, 295, 5, 150, 0, 0, 294, 293, 1, 0, 0, 0, 294, 295, 1, 0, 0, 0, 295, 25, 1, 0, 0, 0, 296, 297, 5, 33, 0, 0, 297, 298, 5, 130, 0, 0, 298, 299, 5, 52, 0, 0, 299, 302, 3, 156, 78, 0, 300, 301, 5, 116, 0, 0, 301, 303, 3, 156, 78, 0, 302, 300, 1, 0, 0, 0, 302, 303, 1, 0, 0, 0, 303, 304, 1, 0, 0, 0, 304, 305, 5, 42, 0, 0, 305, 306, 3, 4, 2, 0, 306, 307, 5, 149, 0, 0, 307, 309, 3, 10, 5, 0, 308, 310, 5, 150, 0, 0, 309, 308, 1, 0, 0, 0, 309, 310, 1, 0, 0, 0, 310, 27, 1, 0, 0, 0, 311, 312, 5, 31, 0, 0, 312, 313, 3, 156, 78, 0, 313, 315, 5, 130, 0, 0, 314, 316, 3, 8, 4, 0, 315, 314, 1, 0, 0, 0, 315, 316, 1, 0, 0, 0, 316, 317, 1, 0, 0, 0, 317, 318, 5, 149, 0, 0, 318, 319, 3, 36, 18, 0, 319, 29, 1, 0, 0, 0, 320, 321, 3, 4, 2, 0, 321, 322, 5, 115, 0, 0, 322, 323, 5, 122, 0, 0, 323, 324, 3, 4, 2, 0, 324, 31, 1, 0, 0, 0, 325, 327, 3, 4, 2, 0, 326, 328, 5, 150, 0, 0, 327, 326, 1, 0, 0, 0, 327, 328, 1, 0, 0, 0, 328, 33, 1, 0, 0, 0, 329, 330, 5, 150, 0, 0, 330, 35, 1, 0, 0, 0, 331, 335, 5, 128, 0, 0, 332, 334, 3, 2, 1, 0, 333, 332, 1, 0, 0, 0, 334, 337, 1, 0, 0, 0, 335, 333, 1, 0, 0, 0, 335, 336, 1, 0, 0, 0, 336, 338, 1, 0, 0, 0, 337, 335, 1, 0, 0, 0, 338, 339, 5, 147, 0, 0, 339, 37, 1, 0, 0, 0, 340, 341, 3, 4, 2, 0, 341, 342, 5, 115, 0, 0, 342, 343, 3, 4, 2, 0, 343, 39, 1, 0, 0, 0, 344, 349, 3, 38, 19, 0, 345, 346, 5, 116, 0, 0, 346, 348, 3, 38, 19, 0, 347, 345, 1, 0, 0, 0, 348, 351, 1, 0, 0, 0, 349, 347, 1, 0, 0, 0, 349, 350, 1, 0, 0, 0, 350, 353, 1, 0, 0, 0, 351, 349, 1, 0, 0, 0, 352, 354, 5, 116, 0, 0, 353, 352, 1, 0, 0, 0, 353, 354, 1, 0, 0, 0, 354, 41, 1, 0, 0, 0, 355, 359, 3, 44, 22, 0, 356, 359, 3, 48, 24, 0, 357, 359, 3, 120, 60, 0, 358, 355, 1, 0, 0, 0, 358, 356, 1, 0, 0, 0, 358, 357, 1, 0, 0, 0, 359, 360, 1, 0, 0, 0, 360, 361, 5, 0, 0, 1, 361, 43, 1, 0, 0, 0, 362, 368, 3, 46, 23, 0, 363, 364, 5, 95, 0, 0, 364, 365, 5, 1, 0, 0, 365, 367, 3, 46, 23, 0, 366, 363, 1, 0, 0, 0, 367, 370, 1, 0, 0, 0, 368, 366, 1, 0, 0, 0, 368, 369, 1, 0, 0, 0, 369, 45, 1, 0, 0, 0, 370, 368, 1, 0, 0, 0, 371, 378, 3, 48, 24, 0, 372, 373, 5, 130, 0, 0, 373, 374, 3, 44, 22, 0, 374, 375, 5, 149, 0, 0, 375, 378, 1, 0, 0, 0, 376, 378, 3, 160, 80, 0, 377, 371, 1, 0, 0, 0, 377, 372, 1, 0, 0, 0, 377, 376, 1, 0, 0, 0, 378, 47, 1, 0, 0, 0, 379, 381, 3, 50, 25, 0, 380, 379, 1, 0, 0, 0, 380, 381, 1, 0, 0, 0, 381, 382, 1, 0, 0, 0, 382, 384, 5, 79, 0, 0, 383, 385, 5, 24, 0, 0, 384, 383, 1, 0, 0, 0, 384, 385, 1, 0, 0, 0, 385, 387, 1, 0, 0, 0, 386, 388, 3, 52, 26, 0, 387, 386, 1, 0, 0, 0, 387, 388, 1, 0, 0, 0, 388, 389, 1, 0, 0, 0, 389, 391, 3, 114, 57, 0, 390, 392, 3, 54, 27, 0, 391, 390, 1, 0, 0, 0, 391, 392, 1, 0, 0, 0, 392, 394, 1, 0, 0, 0, 393, 395, 3, 56, 28, 0, 394, 393, 1, 0, 0, 0, 394, 395, 1, 0, 0, 0, 395, 397, 1, 0, 0, 0, 396, 398, 3, 60, 30, 0, 397, 396, 1, 0, 0, 0, 397, 398, 1, 0, 0, 0, 398, 400, 1, 0, 0, 0, 399, 401, 3, 62, 31, 0, 400, 399, 1, 0, 0, 0, 400, 401, 1, 0, 0, 0, 401, 403, 1, 0, 0, 0, 402, 404, 3, 64, 32, 0, 403, 402, 1, 0, 0, 0, 403, 404, 1, 0, 0, 0, 404, 407, 1, 0, 0, 0, 405, 406, 5, 102, 0, 0, 406, 408, 7, 0, 0, 0, 407, 405, 1, 0, 0, 0, 407, 408, 1, 0, 0, 0, 408, 411, 1, 0, 0, 0, 409, 410, 5, 102, 0, 0, 410, 412, 5, 89, 0, 0, 411, 409, 1, 0, 0, 0, 411, 412, 1, 0, 0, 0, 412, 414, 1, 0, 0, 0, 413, 415, 3, 66, 33, 0, 414, 413, 1, 0, 0, 0, 414, 415, 1, 0, 0, 0, 415, 417, 1, 0, 0, 0, 416, 418, 3, 58, 29, 0, 417, 416, 1, 0, 0, 0, 417, 418, 1, 0, 0, 0, 418, 420, 1, 0, 0, 0, 419, 421, 3, 68, 34, 0, 420, 419, 1, 0, 0, 0, 420, 421, 1, 0, 0, 0, 421, 424, 1, 0, 0, 0, 422, 425, 3, 72, 36, 0, 423, 425, 3, 74, 37, 0, 424, 422, 1, 0, 0, 0, 424, 423, 1, 0, 0, 0, 424, 425, 1, 0, 0, 0, 425, 427, 1, 0, 0, 0, 426, 428, 3, 76, 38, 0, 427, 426, 1, 0, 0, 0, 427, 428, 1, 0, 0, 0, 428, 49, 1, 0, 0, 0, 429, 430, 5, 102, 0, 0, 430, 431, 3, 124, 62, 0, 431, 51, 1, 0, 0, 0, 432, 433, 5, 88, 0, 0, 433, 436, 5, 108, 0, 0, 434, 435, 5, 102, 0, 0, 435, 437, 5, 85, 0, 0, 436, 434, 1, 0, 0, 0, 436, 437, 1, 0, 0, 0, 437, 53, 1, 0, 0, 0, 438, 439, 5, 34, 0, 0, 439, 440, 3, 78, 39, 0, 440, 55, 1, 0, 0, 0, 441, 443, 7, 1, 0, 0, 442, 441, 1, 0, 0, 0, 442, 443, 1, 0, 0, 0, 443, 444, 1, 0, 0, 0, 444, 445, 5, 5, 0, 0, 445, 446, 5, 47, 0, 0, 446, 447, 3, 114, 57, 0, 447, 57, 1, 0, 0, 0, 448, 449, 5, 101, 0, 0, 449, 450, 3, 156, 78, 0, 450, 451, 5, 6, 0, 0, 451, 452, 5, 130, 0, 0, 452, 453, 3, 98, 49, 0, 453, 463, 5, 149, 0, 0, 454, 455, 5, 116, 0, 0, 455, 456, 3, 156, 78, 0, 456, 457, 5, 6, 0, 0, 457, 458, 5, 130, 0, 0, 458, 459, 3, 98, 49, 0, 459, 460, 5, 149, 0, 0, 460, 462, 1, 0, 0, 0, 461, 454, 1, 0, 0, 0, 462, 465, 1, 0, 0, 0, 463, 461, 1, 0, 0, 0, 463, 464, 1, 0, 0, 0, 464, 59, 1, 0, 0, 0, 465, 463, 1, 0, 0, 0, 466, 467, 5, 69, 0, 0, 467, 468, 3, 116, 58, 0, 468, 61, 1, 0, 0, 0, 469, 470, 5, 99, 0, 0, 470, 471, 3, 116, 58, 0, 471, 63, 1, 0, 0, 0, 472, 473, 5, 36, 0, 0, 473, 480, 5, 11, 0, 0, 474, 475, 7, 0, 0, 0, 475, 476, 5, 130, 0, 0, 476, 477, 3, 114, 57, 0, 477, 478, 5, 149, 0, 0, 478, 481, 1, 0, 0, 0, 479, 481, 3, 114, 57, 0, 480, 474, 1, 0, 0, 0, 480, 479, 1, 0, 0, 0, 481, 65, 1, 0, 0, 0, 482, 483, 5, 37, 0, 0, 483, 484, 3, 116, 58, 0, 484, 67, 1, 0, 0, 0, 485, 486, 5, 64, 0, 0, 486, 487, 5, 11, 0, 0, 487, 488, 3, 88, 44, 0, 488, 69, 1, 0, 0, 0, 489, 490, 5, 64, 0, 0, 490, 491, 5, 11, 0, 0, 491, 492, 3, 114, 57, 0, 492, 71, 1, 0, 0, 0, 493, 494, 5, 54, 0, 0, 494, 497, 3, 116, 58, 0, 495, 496, 5, 116, 0, 0, 496, 498, 3, 116, 58, 0, 497, 495, 1, 0, 0, 0, 497, 498, 1, 0, 0, 0, 498, 503, 1, 0, 0, 0, 499, 500, 5, 102, 0, 0, 500, 504, 5, 85, 0, 0, 501, 502, 5, 11, 0, 0, 502, 504, 3, 114, 57, 0, 503, 499, 1, 0, 0, 0, 503, 501, 1, 0, 0, 0, 503, 504, 1, 0, 0, 0, 504, 523, 1, 0, 0, 0, 505, 506, 5, 54, 0, 0, 506, 509, 3, 116, 58, 0, 507, 508, 5, 102, 0, 0, 508, 510, 5, 85, 0, 0, 509, 507, 1, 0, 0, 0, 509, 510, 1, 0, 0, 0, 510, 511, 1, 0, 0, 0, 511, 512, 5, 61, 0, 0, 512, 513, 3, 116, 58, 0, 513, 523, 1, 0, 0, 0, 514, 515, 5, 54, 0, 0, 515, 516, 3, 116, 58, 0, 516, 517, 5, 61, 0, 0, 517, 520, 3, 116, 58, 0, 518, 519, 5, 11, 0, 0, 519, 521, 3, 114, 57, 0, 520, 518, 1, 0, 0, 0, 520, 521, 1, 0, 0, 0, 521, 523, 1, 0, 0, 0, 522, 493, 1, 0, 0, 0, 522, 505, 1, 0, 0, 0, 522, 514, 1, 0, 0, 0, 523, 73, 1, 0, 0, 0, 524, 525, 5, 61, 0, 0, 525, 526, 3, 116, 58, 0, 526, 75, 1, 0, 0, 0, 527, 528, 5, 81, 0, 0, 528, 529, 3, 94, 47, 0, 529, 77, 1, 0, 0, 0, 530, 531, 6, 39, -1, 0, 531, 533, 3, 132, 66, 0, 532, 534, 5, 28, 0, 0, 533, 532, 1, 0, 0, 0, 533, 534, 1, 0, 0, 0, 534, 536, 1, 0, 0, 0, 535, 537, 3, 86, 43, 0, 536, 535, 1, 0, 0, 0, 536, 537, 1, 0, 0, 0, 537, 543, 1, 0, 0, 0, 538, 539, 5, 130, 0, 0, 539, 540, 3, 78, 39, 0, 540, 541, 5, 149, 0, 0, 541, 543, 1, 0, 0, 0, 542, 530, 1, 0, 0, 0, 542, 538, 1, 0, 0, 0, 543, 558, 1, 0, 0, 0, 544, 545, 10, 3, 0, 0, 545, 546, 3, 82, 41, 0, 546, 547, 3, 78, 39, 4, 547, 557, 1, 0, 0, 0, 548, 550, 10, 4, 0, 0, 549, 551, 3, 80, 40, 0, 550, 549, 1, 0, 0, 0, 550, 551, 1, 0, 0, 0, 551, 552, 1, 0, 0, 0, 552, 553, 5, 47, 0, 0, 553, 554, 3, 78, 39, 0, 554, 555, 3, 84, 42, 0, 555, 557, 1, 0, 0, 0, 556, 544, 1, 0, 0, 0, 556, 548, 1, 0, 0, 0, 557, 560, 1, 0, 0, 0, 558, 556, 1, 0, 0, 0, 558, 559, 1, 0, 0, 0, 559, 79, 1, 0, 0, 0, 560, 558, 1, 0, 0, 0, 561, 563, 7, 2, 0, 0, 562, 561, 1, 0, 0, 0, 562, 563, 1, 0, 0, 0, 563, 564, 1, 0, 0, 0, 564, 571, 5, 44, 0, 0, 565, 567, 5, 44, 0, 0, 566, 568, 7, 2, 0, 0, 567, 566, 1, 0, 0, 0, 567, 568, 1, 0, 0, 0, 568, 571, 1, 0, 0, 0, 569, 571, 7, 2, 0, 0, 570, 562, 1, 0, 0, 0, 570, 565, 1, 0, 0, 0, 570, 569, 1, 0, 0, 0, 571, 605, 1, 0, 0, 0, 572, 574, 7, 3, 0, 0, 573, 572, 1, 0, 0, 0, 573, 574, 1, 0, 0, 0, 574, 575, 1, 0, 0, 0, 575, 577, 7, 4, 0, 0, 576, 578, 5, 65, 0, 0, 577, 576, 1, 0, 0, 0, 577, 578, 1, 0, 0, 0, 578, 587, 1, 0, 0, 0, 579, 581, 7, 4, 0, 0, 580, 582, 5, 65, 0, 0, 581, 580, 1, 0, 0, 0, 581, 582, 1, 0, 0, 0, 582, 584, 1, 0, 0, 0, 583, 585, 7, 3, 0, 0, 584, 583, 1, 0, 0, 0, 584, 585, 1, 0, 0, 0, 585, 587, 1, 0, 0, 0, 586, 573, 1, 0, 0, 0, 586, 579, 1, 0, 0, 0, 587, 605, 1, 0, 0, 0, 588, 590, 7, 5, 0, 0, 589, 588, 1, 0, 0, 0, 589, 590, 1, 0, 0, 0, 590, 591, 1, 0, 0, 0, 591, 593, 5, 35, 0, 0, 592, 594, 5, 65, 0, 0, 593, 592, 1, 0, 0, 0, 593, 594, 1, 0, 0, 0, 594, 603, 1, 0, 0, 0, 595, 597, 5, 35, 0, 0, 596, 598, 5, 65, 0, 0, 597, 596, 1, 0, 0, 0, 597, 598, 1, 0, 0, 0, 598, 600, 1, 0, 0, 0, 599, 601, 7, 5, 0, 0, 600, 599, 1, 0, 0, 0, 600, 601, 1, 0, 0, 0, 601, 603, 1, 0, 0, 0, 602, 589, 1, 0, 0, 0, 602, 595, 1, 0, 0, 0, 603, 605, 1, 0, 0, 0, 604, 570, 1, 0, 0, 0, 604, 586, 1, 0, 0, 0, 604, 602, 1, 0, 0, 0, 605, 81, 1, 0, 0, 0, 606, 607, 5, 17, 0, 0, 607, 610, 5, 47, 0, 0, 608, 610, 5, 116, 0, 0, 609, 606, 1, 0, 0, 0, 609, 608, 1, 0, 0, 0, 610, 83, 1, 0, 0, 0, 611, 612, 5, 62, 0, 0, 612, 621, 3, 114, 57, 0, 613, 614, 5, 96, 0, 0, 614, 615, 5, 130, 0, 0, 615, 616, 3, 114, 57, 0, 616, 617, 5, 149, 0, 0, 617, 621, 1, 0, 0, 0, 618, 619, 5, 96, 0, 0, 619, 621, 3, 114, 57, 0, 620, 611, 1, 0, 0, 0, 620, 613, 1, 0, 0, 0, 620, 618, 1, 0, 0, 0, 621, 85, 1, 0, 0, 0, 622, 623, 5, 77, 0, 0, 623, 626, 3, 92, 46, 0, 624, 625, 5, 61, 0, 0, 625, 627, 3, 92, 46, 0, 626, 624, 1, 0, 0, 0, 626, 627, 1, 0, 0, 0, 627, 87, 1, 0, 0, 0, 628, 633, 3, 90, 45, 0, 629, 630, 5, 116, 0, 0, 630, 632, 3, 90, 45, 0, 631, 629, 1, 0, 0, 0, 632, 635, 1, 0, 0, 0, 633, 631, 1, 0, 0, 0, 633, 634, 1, 0, 0, 0, 634, 89, 1, 0, 0, 0, 635, 633, 1, 0, 0, 0, 636, 638, 3, 116, 58, 0, 637, 639, 7, 6, 0, 0, 638, 637, 1, 0, 0, 0, 638, 639, 1, 0, 0, 0, 639, 642, 1, 0, 0, 0, 640, 641, 5, 60, 0, 0, 641, 643, 7, 7, 0, 0, 642, 640, 1, 0, 0, 0, 642, 643, 1, 0, 0, 0, 643, 646, 1, 0, 0, 0, 644, 645, 5, 16, 0, 0, 645, 647, 5, 110, 0, 0, 646, 644, 1, 0, 0, 0, 646, 647, 1, 0, 0, 0, 647, 91, 1, 0, 0, 0, 648, 655, 3, 160, 80, 0, 649, 652, 3, 144, 72, 0, 650, 651, 5, 151, 0, 0, 651, 653, 3, 144, 72, 0, 652, 650, 1, 0, 0, 0, 652, 653, 1, 0, 0, 0, 653, 655, 1, 0, 0, 0, 654, 648, 1, 0, 0, 0, 654, 649, 1, 0, 0, 0, 655, 93, 1, 0, 0, 0, 656, 661, 3, 96, 48, 0, 657, 658, 5, 116, 0, 0, 658, 660, 3, 96, 48, 0, 659, 657, 1, 0, 0, 0, 660, 663, 1, 0, 0, 0, 661, 659, 1, 0, 0, 0, 661, 662, 1, 0, 0, 0, 662, 95, 1, 0, 0, 0, 663, 661, 1, 0, 0, 0, 664, 665, 3, 156, 78, 0, 665, 666, 5, 122, 0, 0, 666, 667, 3, 146, 73, 0, 667, 97, 1, 0, 0, 0, 668, 670, 3, 100, 50, 0, 669, 668, 1, 0, 0, 0, 669, 670, 1, 0, 0, 0, 670, 672, 1, 0, 0, 0, 671, 673, 3, 102, 51, 0, 672, 671, 1, 0, 0, 0, 672, 673, 1, 0, 0, 0, 673, 675, 1, 0, 0, 0, 674, 676, 3, 104, 52, 0, 675, 674, 1, 0, 0, 0, 675, 676, 1, 0, 0, 0, 676, 99, 1, 0, 0, 0, 677, 678, 5, 67, 0, 0, 678, 679, 5, 11, 0, 0, 679, 680, 3, 114, 57, 0, 680, 101, 1, 0, 0, 0, 681, 682, 5, 64, 0, 0, 682, 683, 5, 11, 0, 0, 683, 684, 3, 88, 44, 0, 684, 103, 1, 0, 0, 0, 685, 686, 7, 8, 0, 0, 686, 687, 3, 106, 53, 0, 687, 105, 1, 0, 0, 0, 688, 695, 3, 108, 54, 0, 689, 690, 5, 9, 0, 0, 690, 691, 3, 108, 54, 0, 691, 692, 5, 2, 0, 0, 692, 693, 3, 108, 54, 0, 693, 695, 1, 0, 0, 0, 694, 688, 1, 0, 0, 0, 694, 689, 1, 0, 0, 0, 695, 107, 1, 0, 0, 0, 696, 697, 5, 19, 0, 0, 697, 709, 5, 75, 0, 0, 698, 699, 5, 94, 0, 0, 699, 709, 5, 68, 0, 0, 700, 701, 5, 94, 0, 0, 701, 709, 5, 32, 0, 0, 702, 703, 3, 144, 72, 0, 703, 704, 5, 68, 0, 0, 704, 709, 1, 0, 0, 0, 705, 706, 3, 144, 72, 0, 706, 707, 5, 32, 0, 0, 707, 709, 1, 0, 0, 0, 708, 696, 1, 0, 0, 0, 708, 698, 1, 0, 0, 0, 708, 700, 1, 0, 0, 0, 708, 702, 1, 0, 0, 0, 708, 705, 1, 0, 0, 0, 709, 109, 1, 0, 0, 0, 710, 711, 3, 116, 58, 0, 711, 712, 5, 0, 0, 1, 712, 111, 1, 0, 0, 0, 713, 770, 3, 156, 78, 0, 714, 715, 3, 156, 78, 0, 715, 716, 5, 130, 0, 0, 716, 717, 3, 156, 78, 0, 717, 724, 3, 112, 56, 0, 718, 719, 5, 116, 0, 0, 719, 720, 3, 156, 78, 0, 720, 721, 3, 112, 56, 0, 721, 723, 1, 0, 0, 0, 722, 718, 1, 0, 0, 0, 723, 726, 1, 0, 0, 0, 724, 722, 1, 0, 0, 0, 724, 725, 1, 0, 0, 0, 725, 728, 1, 0, 0, 0, 726, 724, 1, 0, 0, 0, 727, 729, 5, 116, 0, 0, 728, 727, 1, 0, 0, 0, 728, 729, 1, 0, 0, 0, 729, 730, 1, 0, 0, 0, 730, 731, 5, 149, 0, 0, 731, 770, 1, 0, 0, 0, 732, 733, 3, 156, 78, 0, 733, 734, 5, 130, 0, 0, 734, 739, 3, 158, 79, 0, 735, 736, 5, 116, 0, 0, 736, 738, 3, 158, 79, 0, 737, 735, 1, 0, 0, 0, 738, 741, 1, 0, 0, 0, 739, 737, 1, 0, 0, 0, 739, 740, 1, 0, 0, 0, 740, 743, 1, 0, 0, 0, 741, 739, 1, 0, 0, 0, 742, 744, 5, 116, 0, 0, 743, 742, 1, 0, 0, 0, 743, 744, 1, 0, 0, 0, 744, 745, 1, 0, 0, 0, 745, 746, 5, 149, 0, 0, 746, 770, 1, 0, 0, 0, 747, 748, 3, 156, 78, 0, 748, 749, 5, 130, 0, 0, 749, 754, 3, 112, 56, 0, 750, 751, 5, 116, 0, 0, 751, 753, 3, 112, 56, 0, 752, 750, 1, 0, 0, 0, 753, 756, 1, 0, 0, 0, 754, 752, 1, 0, 0, 0, 754, 755, 1, 0, 0, 0, 755, 758, 1, 0, 0, 0, 756, 754, 1, 0, 0, 0, 757, 759, 5, 116, 0, 0, 758, 757, 1, 0, 0, 0, 758, 759, 1, 0, 0, 0, 759, 760, 1, 0, 0, 0, 760, 761, 5, 149, 0, 0, 761, 770, 1, 0, 0, 0, 762, 763, 3, 156, 78, 0, 763, 765, 5, 130, 0, 0, 764, 766, 3, 114, 57, 0, 765, 764, 1, 0, 0, 0, 765, 766, 1, 0, 0, 0, 766, 767, 1, 0, 0, 0, 767, 768, 5, 149, 0, 0, 768, 770, 1, 0, 0, 0, 769, 713, 1, 0, 0, 0, 769, 714, 1, 0, 0, 0, 769, 732, 1, 0, 0, 0, 769, 747, 1, 0, 0, 0, 769, 762, 1, 0, 0, 0, 770, 113, 1, 0, 0, 0, 771, 776, 3, 116, 58, 0, 772, 773, 5, 116, 0, 0, 773, 775, 3, 116, 58, 0, 774, 772, 1, 0, 0, 0, 775, 778, 1, 0, 0, 0, 776, 774, 1, 0, 0, 0, 776, 777, 1, 0, 0, 0, 777, 780, 1, 0, 0, 0, 778, 776, 1, 0, 0, 0, 779, 781, 5, 116, 0, 0, 780, 779, 1, 0, 0, 0, 780, 781, 1, 0, 0, 0, 781, 115, 1, 0, 0, 0, 782, 783, 6, 58, -1, 0, 783, 785, 5, 12, 0, 0, 784, 786, 3, 116, 58, 0, 785, 784, 1, 0, 0, 0, 785, 786, 1, 0, 0, 0, 786, 792, 1, 0, 0, 0, 787, 788, 5, 98, 0, 0, 788, 789, 3, 116, 58, 0, 789, 790, 5, 83, 0, 0, 790, 791, 3, 116, 58, 0, 791, 793, 1, 0, 0, 0, 792, 787, 1, 0, 0, 0, 793, 794, 1, 0, 0, 0, 794, 792, 1, 0, 0, 0, 794, 795, 1, 0, 0, 0, 795, 798, 1, 0, 0, 0, 796, 797, 5, 25, 0, 0, 797, 799, 3, 116, 58, 0, 798, 796, 1, 0, 0, 0, 798, 799, 1, 0, 0, 0, 799, 800, 1, 0, 0, 0, 800, 801, 5, 26, 0, 0, 801, 933, 1, 0, 0, 0, 802, 803, 5, 13, 0, 0, 803, 804, 5, 130, 0, 0, 804, 805, 3, 116, 58, 0, 805, 806, 5, 6, 0, 0, 806, 807, 3, 112, 56, 0, 807, 808, 5, 149, 0, 0, 808, 933, 1, 0, 0, 0, 809, 810, 5, 20, 0, 0, 810, 933, 5, 110, 0, 0, 811, 812, 5, 45, 0, 0, 812, 813, 3, 116, 58, 0, 813, 814, 3, 148, 74, 0, 814, 933, 1, 0, 0, 0, 815, 816, 5, 82, 0, 0, 816, 817, 5, 130, 0, 0, 817, 818, 3, 116, 58, 0, 818, 819, 5, 34, 0, 0, 819, 822, 3, 116, 58, 0, 820, 821, 5, 33, 0, 0, 821, 823, 3, 116, 58, 0, 822, 820, 1, 0, 0, 0, 822, 823, 1, 0, 0, 0, 823, 824, 1, 0, 0, 0, 824, 825, 5, 149, 0, 0, 825, 933, 1, 0, 0, 0, 826, 827, 5, 86, 0, 0, 827, 933, 5, 110, 0, 0, 828, 829, 5, 91, 0, 0, 829, 830, 5, 130, 0, 0, 830, 831, 7, 9, 0, 0, 831, 832, 3, 162, 81, 0, 832, 833, 5, 34, 0, 0, 833, 834, 3, 116, 58, 0, 834, 835, 5, 149, 0, 0, 835, 933, 1, 0, 0, 0, 836, 837, 3, 156, 78, 0, 837, 839, 5, 130, 0, 0, 838, 840, 3, 114, 57, 0, 839, 838, 1, 0, 0, 0, 839, 840, 1, 0, 0, 0, 840, 841, 1, 0, 0, 0, 841, 842, 5, 149, 0, 0, 842, 851, 1, 0, 0, 0, 843, 845, 5, 130, 0, 0, 844, 846, 5, 24, 0, 0, 845, 844, 1, 0, 0, 0, 845, 846, 1, 0, 0, 0, 846, 848, 1, 0, 0, 0, 847, 849, 3, 114, 57, 0, 848, 847, 1, 0, 0, 0, 848, 849, 1, 0, 0, 0, 849, 850, 1, 0, 0, 0, 850, 852, 5, 149, 0, 0, 851, 843, 1, 0, 0, 0, 851, 852, 1, 0, 0, 0, 852, 853, 1, 0, 0, 0, 853, 854, 5, 66, 0, 0, 854, 855, 5, 130, 0, 0, 855, 856, 3, 98, 49, 0, 856, 857, 5, 149, 0, 0, 857, 933, 1, 0, 0, 0, 858, 859, 3, 156, 78, 0, 859, 861, 5, 130, 0, 0, 860, 862, 3, 114, 57, 0, 861, 860, 1, 0, 0, 0, 861, 862, 1, 0, 0, 0, 862, 863, 1, 0, 0, 0, 863, 864, 5, 149, 0, 0, 864, 873, 1, 0, 0, 0, 865, 867, 5, 130, 0, 0, 866, 868, 5, 24, 0, 0, 867, 866, 1, 0, 0, 0, 867, 868, 1, 0, 0, 0, 868, 870, 1, 0, 0, 0, 869, 871, 3, 114, 57, 0, 870, 869, 1, 0, 0, 0, 870, 871, 1, 0, 0, 0, 871, 872, 1, 0, 0, 0, 872, 874, 5, 149, 0, 0, 873, 865, 1, 0, 0, 0, 873, 874, 1, 0, 0, 0, 874, 875, 1, 0, 0, 0, 875, 876, 5, 66, 0, 0, 876, 877, 3, 156, 78, 0, 877, 933, 1, 0, 0, 0, 878, 884, 3, 156, 78, 0, 879, 881, 5, 130, 0, 0, 880, 882, 3, 114, 57, 0, 881, 880, 1, 0, 0, 0, 881, 882, 1, 0, 0, 0, 882, 883, 1, 0, 0, 0, 883, 885, 5, 149, 0, 0, 884, 879, 1, 0, 0, 0, 884, 885, 1, 0, 0, 0, 885, 886, 1, 0, 0, 0, 886, 888, 5, 130, 0, 0, 887, 889, 5, 24, 0, 0, 888, 887, 1, 0, 0, 0, 888, 889, 1, 0, 0, 0, 889, 891, 1, 0, 0, 0, 890, 892, 3, 114, 57, 0, 891, 890, 1, 0, 0, 0, 891, 892, 1, 0, 0, 0, 892, 893, 1, 0, 0, 0, 893, 894, 5, 149, 0, 0, 894, 933, 1, 0, 0, 0, 895, 933, 3, 120, 60, 0, 896, 933, 3, 164, 82, 0, 897, 933, 3, 146, 73, 0, 898, 899, 5, 118, 0, 0, 899, 933, 3, 116, 58, 20, 900, 901, 5, 58, 0, 0, 901, 933, 3, 116, 58, 14, 902, 903, 3, 136, 68, 0, 903, 904, 5, 120, 0, 0, 904, 906, 1, 0, 0, 0, 905, 902, 1, 0, 0, 0, 905, 906, 1, 0, 0, 0, 906, 907, 1, 0, 0, 0, 907, 933, 5, 112, 0, 0, 908, 909, 5, 130, 0, 0, 909, 910, 3, 44, 22, 0, 910, 911, 5, 149, 0, 0, 911, 933, 1, 0, 0, 0, 912, 913, 5, 130, 0, 0, 913, 914, 3, 116, 58, 0, 914, 915, 5, 149, 0, 0, 915, 933, 1, 0, 0, 0, 916, 917, 5, 130, 0, 0, 917, 918, 3, 114, 57, 0, 918, 919, 5, 149, 0, 0, 919, 933, 1, 0, 0, 0, 920, 922, 5, 129, 0, 0, 921, 923, 3, 114, 57, 0, 922, 921, 1, 0, 0, 0, 922, 923, 1, 0, 0, 0, 923, 924, 1, 0, 0, 0, 924, 933, 5, 148, 0, 0, 925, 927, 5, 128, 0, 0, 926, 928, 3, 40, 20, 0, 927, 926, 1, 0, 0, 0, 927, 928, 1, 0, 0, 0, 928, 929, 1, 0, 0, 0, 929, 933, 5, 147, 0, 0, 930, 933, 3, 118, 59, 0, 931, 933, 3, 128, 64, 0, 932, 782, 1, 0, 0, 0, 932, 802, 1, 0, 0, 0, 932, 809, 1, 0, 0, 0, 932, 811, 1, 0, 0, 0, 932, 815, 1, 0, 0, 0, 932, 826, 1, 0, 0, 0, 932, 828, 1, 0, 0, 0, 932, 836, 1, 0, 0, 0, 932, 858, 1, 0, 0, 0, 932, 878, 1, 0, 0, 0, 932, 895, 1, 0, 0, 0, 932, 896, 1, 0, 0, 0, 932, 897, 1, 0, 0, 0, 932, 898, 1, 0, 0, 0, 932, 900, 1, 0, 0, 0, 932, 905, 1, 0, 0, 0, 932, 908, 1, 0, 0, 0, 932, 912, 1, 0, 0, 0, 932, 916, 1, 0, 0, 0, 932, 920, 1, 0, 0, 0, 932, 925, 1, 0, 0, 0, 932, 930, 1, 0, 0, 0, 932, 931, 1, 0, 0, 0, 933, 1044, 1, 0, 0, 0, 934, 938, 10, 19, 0, 0, 935, 939, 5, 112, 0, 0, 936, 939, 5, 151, 0, 0, 937, 939, 5, 138, 0, 0, 938, 935, 1, 0, 0, 0, 938, 936, 1, 0, 0, 0, 938, 937, 1, 0, 0, 0, 939, 940, 1, 0, 0, 0, 940, 1043, 3, 116, 58, 20, 941, 945, 10, 18, 0, 0, 942, 946, 5, 139, 0, 0, 943, 946, 5, 118, 0, 0, 944, 946, 5, 117, 0, 0, 945, 942, 1, 0, 0, 0, 945, 943, 1, 0, 0, 0, 945, 944, 1, 0, 0, 0, 946, 947, 1, 0, 0, 0, 947, 1043, 3, 116, 58, 19, 948, 973, 10, 17, 0, 0, 949, 974, 5, 121, 0, 0, 950, 974, 5, 122, 0, 0, 951, 974, 5, 133, 0, 0, 952, 974, 5, 131, 0, 0, 953, 974, 5, 132, 0, 0, 954, 974, 5, 123, 0, 0, 955, 974, 5, 124, 0, 0, 956, 958, 5, 58, 0, 0, 957, 956, 1, 0, 0, 0, 957, 958, 1, 0, 0, 0, 958, 959, 1, 0, 0, 0, 959, 961, 5, 42, 0, 0, 960, 962, 5, 15, 0, 0, 961, 960, 1, 0, 0, 0, 961, 962, 1, 0, 0, 0, 962, 974, 1, 0, 0, 0, 963, 965, 5, 58, 0, 0, 964, 963, 1, 0, 0, 0, 964, 965, 1, 0, 0, 0, 965, 966, 1, 0, 0, 0, 966, 974, 7, 10, 0, 0, 967, 974, 5, 145, 0, 0, 968, 974, 5, 146, 0, 0, 969, 974, 5, 135, 0, 0, 970, 974, 5, 126, 0, 0, 971, 974, 5, 127, 0, 0, 972, 974, 5, 134, 0, 0, 973, 949, 1, 0, 0, 0, 973, 950, 1, 0, 0, 0, 973, 951, 1, 0, 0, 0, 973, 952, 1, 0, 0, 0, 973, 953, 1, 0, 0, 0, 973, 954, 1, 0, 0, 0, 973, 955, 1, 0, 0, 0, 973, 957, 1, 0, 0, 0, 973, 964, 1, 0, 0, 0, 973, 967, 1, 0, 0, 0, 973, 968, 1, 0, 0, 0, 973, 969, 1, 0, 0, 0, 973, 970, 1, 0, 0, 0, 973, 971, 1, 0, 0, 0, 973, 972, 1, 0, 0, 0, 974, 975, 1, 0, 0, 0, 975, 1043, 3, 116, 58, 18, 976, 977, 10, 15, 0, 0, 977, 978, 5, 137, 0, 0, 978, 1043, 3, 116, 58, 16, 979, 980, 10, 13, 0, 0, 980, 981, 5, 2, 0, 0, 981, 1043, 3, 116, 58, 14, 982, 983, 10, 12, 0, 0, 983, 984, 5, 63, 0, 0, 984, 1043, 3, 116, 58, 13, 985, 987, 10, 11, 0, 0, 986, 988, 5, 58, 0, 0, 987, 986, 1, 0, 0, 0, 987, 988, 1, 0, 0, 0, 988, 989, 1, 0, 0, 0, 989, 990, 5, 9, 0, 0, 990, 991, 3, 116, 58, 0, 991, 992, 5, 2, 0, 0, 992, 993, 3, 116, 58, 12, 993, 1043, 1, 0, 0, 0, 994, 995, 10, 10, 0, 0, 995, 996, 5, 140, 0, 0, 996, 997, 3, 116, 58, 0, 997, 998, 5, 115, 0, 0, 998, 999, 3, 116, 58, 10, 999, 1043, 1, 0, 0, 0, 1000, 1001, 10, 30, 0, 0, 1001, 1003, 5, 130, 0, 0, 1002, 1004, 3, 114, 57, 0, 1003, 1002, 1, 0, 0, 0, 1003, 1004, 1, 0, 0, 0, 1004, 1005, 1, 0, 0, 0, 1005, 1043, 5, 149, 0, 0, 1006, 1007, 10, 26, 0, 0, 1007, 1008, 5, 129, 0, 0, 1008, 1009, 3, 116, 58, 0, 1009, 1010, 5, 148, 0, 0, 1010, 1043, 1, 0, 0, 0, 1011, 1012, 10, 25, 0, 0, 1012, 1013, 5, 120, 0, 0, 1013, 1043, 5, 108, 0, 0, 1014, 1015, 10, 24, 0, 0, 1015, 1016, 5, 120, 0, 0, 1016, 1043, 3, 156, 78, 0, 1017, 1018, 10, 23, 0, 0, 1018, 1019, 5, 136, 0, 0, 1019, 1020, 5, 129, 0, 0, 1020, 1021, 3, 116, 58, 0, 1021, 1022, 5, 148, 0, 0, 1022, 1043, 1, 0, 0, 0, 1023, 1024, 10, 22, 0, 0, 1024, 1025, 5, 136, 0, 0, 1025, 1043, 5, 108, 0, 0, 1026, 1027, 10, 21, 0, 0, 1027, 1028, 5, 136, 0, 0, 1028, 1043, 3, 156, 78, 0, 1029, 1030, 10, 16, 0, 0, 1030, 1032, 5, 46, 0, 0, 1031, 1033, 5, 58, 0, 0, 1032, 1031, 1, 0, 0, 0, 1032, 1033, 1, 0, 0, 0, 1033, 1034, 1, 0, 0, 0, 1034, 1043, 5, 59, 0, 0, 1035, 1040, 10, 9, 0, 0, 1036, 1037, 5, 6, 0, 0, 1037, 1041, 3, 156, 78, 0, 1038, 1039, 5, 6, 0, 0, 1039, 1041, 5, 110, 0, 0, 1040, 1036, 1, 0, 0, 0, 1040, 1038, 1, 0, 0, 0, 1041, 1043, 1, 0, 0, 0, 1042, 934, 1, 0, 0, 0, 1042, 941, 1, 0, 0, 0, 1042, 948, 1, 0, 0, 0, 1042, 976, 1, 0, 0, 0, 1042, 979, 1, 0, 0, 0, 1042, 982, 1, 0, 0, 0, 1042, 985, 1, 0, 0, 0, 1042, 994, 1, 0, 0, 0, 1042, 1000, 1, 0, 0, 0, 1042, 1006, 1, 0, 0, 0, 1042, 1011, 1, 0, 0, 0, 1042, 1014, 1, 0, 0, 0, 1042, 1017, 1, 0, 0, 0, 1042, 1023, 1, 0, 0, 0, 1042, 1026, 1, 0, 0, 0, 1042, 1029, 1, 0, 0, 0, 1042, 1035, 1, 0, 0, 0, 1043, 1046, 1, 0, 0, 0, 1044, 1042, 1, 0, 0, 0, 1044, 1045, 1, 0, 0, 0, 1045, 117, 1, 0, 0, 0, 1046, 1044, 1, 0, 0, 0, 1047, 1048, 5, 130, 0, 0, 1048, 1053, 3, 156, 78, 0, 1049, 1050, 5, 116, 0, 0, 1050, 1052, 3, 156, 78, 0, 1051, 1049, 1, 0, 0, 0, 1052, 1055, 1, 0, 0, 0, 1053, 1051, 1, 0, 0, 0, 1053, 1054, 1, 0, 0, 0, 1054, 1057, 1, 0, 0, 0, 1055, 1053, 1, 0, 0, 0, 1056, 1058, 5, 116, 0, 0, 1057, 1056, 1, 0, 0, 0, 1057, 1058, 1, 0, 0, 0, 1058, 1059, 1, 0, 0, 0, 1059, 1060, 5, 149, 0, 0, 1060, 1075, 1, 0, 0, 0, 1061, 1066, 3, 156, 78, 0, 1062, 1063, 5, 116, 0, 0, 1063, 1065, 3, 156, 78, 0, 1064, 1062, 1, 0, 0, 0, 1065, 1068, 1, 0, 0, 0, 1066, 1064, 1, 0, 0, 0, 1066, 1067, 1, 0, 0, 0, 1067, 1070, 1, 0, 0, 0, 1068, 1066, 1, 0, 0, 0, 1069, 1071, 5, 116, 0, 0, 1070, 1069, 1, 0, 0, 0, 1070, 1071, 1, 0, 0, 0, 1071, 1075, 1, 0, 0, 0, 1072, 1073, 5, 130, 0, 0, 1073, 1075, 5, 149, 0, 0, 1074, 1047, 1, 0, 0, 0, 1074, 1061, 1, 0, 0, 0, 1074, 1072, 1, 0, 0, 0, 1075, 1076, 1, 0, 0, 0, 1076, 1079, 5, 111, 0, 0, 1077, 1080, 3, 116, 58, 0, 1078, 1080, 3, 36, 18, 0, 1079, 1077, 1, 0, 0, 0, 1079, 1078, 1, 0, 0, 0, 1080, 119, 1, 0, 0, 0, 1081, 1082, 5, 132, 0, 0, 1082, 1086, 3, 156, 78, 0, 1083, 1085, 3, 122, 61, 0, 1084, 1083, 1, 0, 0, 0, 1085, 1088, 1, 0, 0, 0, 1086, 1084, 1, 0, 0, 0, 1086, 1087, 1, 0, 0, 0, 1087, 1089, 1, 0, 0, 0, 1088, 1086, 1, 0, 0, 0, 1089, 1090, 5, 151, 0, 0, 1090, 1091, 5, 124, 0, 0, 1091, 1114, 1, 0, 0, 0, 1092, 1093, 5, 132, 0, 0, 1093, 1097, 3, 156, 78, 0, 1094, 1096, 3, 122, 61, 0, 1095, 1094, 1, 0, 0, 0, 1096, 1099, 1, 0, 0, 0, 1097, 1095, 1, 0, 0, 0, 1097, 1098, 1, 0, 0, 0, 1098, 1100, 1, 0, 0, 0, 1099, 1097, 1, 0, 0, 0, 1100, 1106, 5, 124, 0, 0, 1101, 1107, 3, 120, 60, 0, 1102, 1103, 5, 128, 0, 0, 1103, 1104, 3, 116, 58, 0, 1104, 1105, 5, 147, 0, 0, 1105, 1107, 1, 0, 0, 0, 1106, 1101, 1, 0, 0, 0, 1106, 1102, 1, 0, 0, 0, 1106, 1107, 1, 0, 0, 0, 1107, 1108, 1, 0, 0, 0, 1108, 1109, 5, 132, 0, 0, 1109, 1110, 5, 151, 0, 0, 1110, 1111, 3, 156, 78, 0, 1111, 1112, 5, 124, 0, 0, 1112, 1114, 1, 0, 0, 0, 1113, 1081, 1, 0, 0, 0, 1113, 1092, 1, 0, 0, 0, 1114, 121, 1, 0, 0, 0, 1115, 1116, 3, 156, 78, 0, 1116, 1117, 5, 122, 0, 0, 1117, 1118, 3, 162, 81, 0, 1118, 1127, 1, 0, 0, 0, 1119, 1120, 3, 156, 78, 0, 1120, 1121, 5, 122, 0, 0, 1121, 1122, 5, 128, 0, 0, 1122, 1123, 3, 116, 58, 0, 1123, 1124, 5, 147, 0, 0, 1124, 1127, 1, 0, 0, 0, 1125, 1127, 3, 156, 78, 0, 1126, 1115, 1, 0, 0, 0, 1126, 1119, 1, 0, 0, 0, 1126, 1125, 1, 0, 0, 0, 1127, 123, 1, 0, 0, 0, 1128, 1133, 3, 126, 63, 0, 1129, 1130, 5, 116, 0, 0, 1130, 1132, 3, 126, 63, 0, 1131, 1129, 1, 0, 0, 0, 1132, 1135, 1, 0, 0, 0, 1133, 1131, 1, 0, 0, 0, 1133, 1134, 1, 0, 0, 0, 1134, 1137, 1, 0, 0, 0, 1135, 1133, 1, 0, 0, 0, 1136, 1138, 5, 116, 0, 0, 1137, 1136, 1, 0, 0, 0, 1137, 1138, 1, 0, 0, 0, 1138, 125, 1, 0, 0, 0, 1139, 1140, 3, 156, 78, 0, 1140, 1141, 5, 6, 0, 0, 1141, 1142, 5, 130, 0, 0, 1142, 1143, 3, 44, 22, 0, 1143, 1144, 5, 149, 0, 0, 1144, 1150, 1, 0, 0, 0, 1145, 1146, 3, 116, 58, 0, 1146, 1147, 5, 6, 0, 0, 1147, 1148, 3, 156, 78, 0, 1148, 1150, 1, 0, 0, 0, 1149, 1139, 1, 0, 0, 0, 1149, 1145, 1, 0, 0, 0, 1150, 127, 1, 0, 0, 0, 1151, 1159, 3, 160, 80, 0, 1152, 1153, 3, 136, 68, 0, 1153, 1154, 5, 120, 0, 0, 1154, 1156, 1, 0, 0, 0, 1155, 1152, 1, 0, 0, 0, 1155, 1156, 1, 0, 0, 0, 1156, 1157, 1, 0, 0, 0, 1157, 1159, 3, 130, 65, 0, 1158, 1151, 1, 0, 0, 0, 1158, 1155, 1, 0, 0, 0, 1159, 129, 1, 0, 0, 0, 1160, 1165, 3, 156, 78, 0, 1161, 1162, 5, 120, 0, 0, 1162, 1164, 3, 156, 78, 0, 1163, 1161, 1, 0, 0, 0, 1164, 1167, 1, 0, 0, 0, 1165, 1163, 1, 0, 0, 0, 1165, 1166, 1, 0, 0, 0, 1166, 131, 1, 0, 0, 0, 1167, 1165, 1, 0, 0, 0, 1168, 1169, 6, 66, -1, 0, 1169, 1178, 3, 136, 68, 0, 1170, 1178, 3, 134, 67, 0, 1171, 1172, 5, 130, 0, 0, 1172, 1173, 3, 44, 22, 0, 1173, 1174, 5, 149, 0, 0, 1174, 1178, 1, 0, 0, 0, 1175, 1178, 3, 120, 60, 0, 1176, 1178, 3, 160, 80, 0, 1177, 1168, 1, 0, 0, 0, 1177, 1170, 1, 0, 0, 0, 1177, 1171, 1, 0, 0, 0, 1177, 1175, 1, 0, 0, 0, 1177, 1176, 1, 0, 0, 0, 1178, 1187, 1, 0, 0, 0, 1179, 1183, 10, 3, 0, 0, 1180, 1184, 3, 154, 77, 0, 1181, 1182, 5, 6, 0, 0, 1182, 1184, 3, 156, 78, 0, 1183, 1180, 1, 0, 0, 0, 1183, 1181, 1, 0, 0, 0, 1184, 1186, 1, 0, 0, 0, 1185, 1179, 1, 0, 0, 0, 1186, 1189, 1, 0, 0, 0, 1187, 1185, 1, 0, 0, 0, 1187, 1188, 1, 0, 0, 0, 1188, 133, 1, 0, 0, 0, 1189, 1187, 1, 0, 0, 0, 1190, 1191, 3, 156, 78, 0, 1191, 1193, 5, 130, 0, 0, 1192, 1194, 3, 138, 69, 0, 1193, 1192, 1, 0, 0, 0, 1193, 1194, 1, 0, 0, 0, 1194, 1195, 1, 0, 0, 0, 1195, 1196, 5, 149, 0, 0, 1196, 135, 1, 0, 0, 0, 1197, 1198, 3, 140, 70, 0, 1198, 1199, 5, 120, 0, 0, 1199, 1201, 1, 0, 0, 0, 1200, 1197, 1, 0, 0, 0, 1200, 1201, 1, 0, 0, 0, 1201, 1202, 1, 0, 0, 0, 1202, 1203, 3, 156, 78, 0, 1203, 137, 1, 0, 0, 0, 1204, 1209, 3, 116, 58, 0, 1205, 1206, 5, 116, 0, 0, 1206, 1208, 3, 116, 58, 0, 1207, 1205, 1, 0, 0, 0, 1208, 1211, 1, 0, 0, 0, 1209, 1207, 1, 0, 0, 0, 1209, 1210, 1, 0, 0, 0, 1210, 1213, 1, 0, 0, 0, 1211, 1209, 1, 0, 0, 0, 1212, 1214, 5, 116, 0, 0, 1213, 1212, 1, 0, 0, 0, 1213, 1214, 1, 0, 0, 0, 1214, 139, 1, 0, 0, 0, 1215, 1216, 3, 156, 78, 0, 1216, 141, 1, 0, 0, 0, 1217, 1226, 5, 106, 0, 0, 1218, 1219, 5, 120, 0, 0, 1219, 1226, 7, 11, 0, 0, 1220, 1221, 5, 108, 0, 0, 1221, 1223, 5, 120, 0, 0, 1222, 1224, 7, 11, 0, 0, 1223, 1222, 1, 0, 0, 0, 1223, 1224, 1, 0, 0, 0, 1224, 1226, 1, 0, 0, 0, 1225, 1217, 1, 0, 0, 0, 1225, 1218, 1, 0, 0, 0, 1225, 1220, 1, 0, 0, 0, 1226, 143, 1, 0, 0, 0, 1227, 1229, 7, 12, 0, 0, 1228, 1227, 1, 0, 0, 0, 1228, 1229, 1, 0, 0, 0, 1229, 1236, 1, 0, 0, 0, 1230, 1237, 3, 142, 71, 0, 1231, 1237, 5, 107, 0, 0, 1232, 1237, 5, 108, 0, 0, 1233, 1237, 5, 109, 0, 0, 1234, 1237, 5, 43, 0, 0, 1235, 1237, 5, 57, 0, 0, 1236, 1230, 1, 0, 0, 0, 1236, 1231, 1, 0, 0, 0, 1236, 1232, 1, 0, 0, 0, 1236, 1233, 1, 0, 0, 0, 1236, 1234, 1, 0, 0, 0, 1236, 1235, 1, 0, 0, 0, 1237, 145, 1, 0, 0, 0, 1238, 1242, 3, 144, 72, 0, 1239, 1242, 5, 110, 0, 0, 1240, 1242, 5, 59, 0, 0, 1241, 1238, 1, 0, 0, 0, 1241, 1239, 1, 0, 0, 0, 1241, 1240, 1, 0, 0, 0, 1242, 147, 1, 0, 0, 0, 1243, 1244, 7, 13, 0, 0, 1244, 149, 1, 0, 0, 0, 1245, 1246, 7, 14, 0, 0, 1246, 151, 1, 0, 0, 0, 1247, 1248, 7, 15, 0, 0, 1248, 153, 1, 0, 0, 0, 1249, 1252, 5, 105, 0, 0, 1250, 1252, 3, 152, 76, 0, 1251, 1249, 1, 0, 0, 0, 1251, 1250, 1, 0, 0, 0, 1252, 155, 1, 0, 0, 0, 1253, 1257, 5, 105, 0, 0, 1254, 1257, 3, 148, 74, 0, 1255, 1257, 3, 150, 75, 0, 1256, 1253, 1, 0, 0, 0, 1256, 1254, 1, 0, 0, 0, 1256, 1255, 1, 0, 0, 0, 1257, 157, 1, 0, 0, 0, 1258, 1259, 3, 162, 81, 0, 1259, 1260, 5, 122, 0, 0, 1260, 1261, 3, 144, 72, 0, 1261, 159, 1, 0, 0, 0, 1262, 1263, 5, 128, 0, 0, 1263, 1264, 3, 130, 65, 0, 1264, 1265, 5, 147, 0, 0, 1265, 161, 1, 0, 0, 0, 1266, 1269, 5, 110, 0, 0, 1267, 1269, 3, 164, 82, 0, 1268, 1266, 1, 0, 0, 0, 1268, 1267, 1, 0, 0, 0, 1269, 163, 1, 0, 0, 0, 1270, 1274, 5, 142, 0, 0, 1271, 1273, 3, 166, 83, 0, 1272, 1271, 1, 0, 0, 0, 1273, 1276, 1, 0, 0, 0, 1274, 1272, 1, 0, 0, 0, 1274, 1275, 1, 0, 0, 0, 1275, 1277, 1, 0, 0, 0, 1276, 1274, 1, 0, 0, 0, 1277, 1278, 5, 144, 0, 0, 1278, 165, 1, 0, 0, 0, 1279, 1280, 5, 157, 0, 0, 1280, 1281, 3, 116, 58, 0, 1281, 1282, 5, 147, 0, 0, 1282, 1285, 1, 0, 0, 0, 1283, 1285, 5, 156, 0, 0, 1284, 1279, 1, 0, 0, 0, 1284, 1283, 1, 0, 0, 0, 1285, 167, 1, 0, 0, 0, 1286, 1290, 5, 143, 0, 0, 1287, 1289, 3, 170, 85, 0, 1288, 1287, 1, 0, 0, 0, 1289, 1292, 1, 0, 0, 0, 1290, 1288, 1, 0, 0, 0, 1290, 1291, 1, 0, 0, 0, 1291, 1293, 1, 0, 0, 0, 1292, 1290, 1, 0, 0, 0, 1293, 1294, 5, 0, 0, 1, 1294, 169, 1, 0, 0, 0, 1295, 1296, 5, 159, 0, 0, 1296, 1297, 3, 116, 58, 0, 1297, 1298, 5, 147, 0, 0, 1298, 1301, 1, 0, 0, 0, 1299, 1301, 5, 158, 0, 0, 1300, 1295, 1, 0, 0, 0, 1300, 1299, 1, 0, 0, 0, 1301, 171, 1, 0, 0, 0, 167, 175, 182, 191, 198, 202, 216, 220, 223, 227, 230, 237, 241, 250, 255, 264, 272, 279, 283, 289, 294, 302, 309, 315, 327, 335, 349, 353, 358, 368, 377, 380, 384, 387, 391, 394, 397, 400, 403, 407, 411, 414, 417, 420, 424, 427, 436, 442, 463, 480, 497, 503, 509, 520, 522, 533, 536, 542, 550, 556, 558, 562, 567, 570, 573, 577, 581, 584, 586, 589, 593, 597, 600, 602, 604, 609, 620, 626, 633, 638, 642, 646, 652, 654, 661, 669, 672, 675, 694, 708, 724, 728, 739, 743, 754, 758, 765, 769, 776, 780, 785, 794, 798, 822, 839, 845, 848, 851, 861, 867, 870, 873, 881, 884, 888, 891, 905, 922, 927, 932, 938, 945, 957, 961, 964, 973, 987, 1003, 1032, 1040, 1042, 1044, 1053, 1057, 1066, 1070, 1074, 1079, 1086, 1097, 1106, 1113, 1126, 1133, 1137, 1149, 1155, 1158, 1165, 1177, 1183, 1187, 1193, 1200, 1209, 1213, 1223, 1225, 1228, 1236, 1241, 1251, 1256, 1268, 1274, 1284, 1290, 1300] \ No newline at end of file diff --git a/hogql_parser/HogQLParserBaseVisitor.cpp b/hogql_parser/HogQLParserBaseVisitor.cpp index 03bf38add14d5..b5a8af7e0f7aa 100644 --- a/hogql_parser/HogQLParserBaseVisitor.cpp +++ b/hogql_parser/HogQLParserBaseVisitor.cpp @@ -1,5 +1,5 @@ -// Generated from HogQLParser.g4 by ANTLR 4.13.1 +// Generated from HogQLParser.g4 by ANTLR 4.13.2 #include "HogQLParserBaseVisitor.h" diff --git a/hogql_parser/HogQLParserBaseVisitor.h b/hogql_parser/HogQLParserBaseVisitor.h index 7329e835cad57..80b4d5d487765 100644 --- a/hogql_parser/HogQLParserBaseVisitor.h +++ b/hogql_parser/HogQLParserBaseVisitor.h @@ -1,5 +1,5 @@ -// Generated from HogQLParser.g4 by ANTLR 4.13.1 +// Generated from HogQLParser.g4 by ANTLR 4.13.2 #pragma once @@ -375,6 +375,10 @@ class HogQLParserBaseVisitor : public HogQLParserVisitor { return visitChildren(ctx); } + virtual std::any visitColumnExprCall(HogQLParser::ColumnExprCallContext *ctx) override { + return visitChildren(ctx); + } + virtual std::any visitColumnExprArrayAccess(HogQLParser::ColumnExprArrayAccessContext *ctx) override { return visitChildren(ctx); } @@ -427,23 +431,19 @@ class HogQLParserBaseVisitor : public HogQLParserVisitor { return visitChildren(ctx); } - virtual std::any visitColumnExprIdentifier(HogQLParser::ColumnExprIdentifierContext *ctx) override { - return visitChildren(ctx); - } - - virtual std::any visitColumnExprFunction(HogQLParser::ColumnExprFunctionContext *ctx) override { + virtual std::any visitColumnExprLambda(HogQLParser::ColumnExprLambdaContext *ctx) override { return visitChildren(ctx); } - virtual std::any visitColumnExprAsterisk(HogQLParser::ColumnExprAsteriskContext *ctx) override { + virtual std::any visitColumnExprIdentifier(HogQLParser::ColumnExprIdentifierContext *ctx) override { return visitChildren(ctx); } - virtual std::any visitColumnArgList(HogQLParser::ColumnArgListContext *ctx) override { + virtual std::any visitColumnExprFunction(HogQLParser::ColumnExprFunctionContext *ctx) override { return visitChildren(ctx); } - virtual std::any visitColumnArgExpr(HogQLParser::ColumnArgExprContext *ctx) override { + virtual std::any visitColumnExprAsterisk(HogQLParser::ColumnExprAsteriskContext *ctx) override { return visitChildren(ctx); } diff --git a/hogql_parser/HogQLParserVisitor.cpp b/hogql_parser/HogQLParserVisitor.cpp index 82a2f14e4ec57..07a511ac187fc 100644 --- a/hogql_parser/HogQLParserVisitor.cpp +++ b/hogql_parser/HogQLParserVisitor.cpp @@ -1,5 +1,5 @@ -// Generated from HogQLParser.g4 by ANTLR 4.13.1 +// Generated from HogQLParser.g4 by ANTLR 4.13.2 #include "HogQLParserVisitor.h" diff --git a/hogql_parser/HogQLParserVisitor.h b/hogql_parser/HogQLParserVisitor.h index 8e4259a8209b1..0b9e1797ad836 100644 --- a/hogql_parser/HogQLParserVisitor.h +++ b/hogql_parser/HogQLParserVisitor.h @@ -1,5 +1,5 @@ -// Generated from HogQLParser.g4 by ANTLR 4.13.1 +// Generated from HogQLParser.g4 by ANTLR 4.13.2 #pragma once @@ -199,6 +199,8 @@ class HogQLParserVisitor : public antlr4::tree::AbstractParseTreeVisitor { virtual std::any visitColumnExprTuple(HogQLParser::ColumnExprTupleContext *context) = 0; + virtual std::any visitColumnExprCall(HogQLParser::ColumnExprCallContext *context) = 0; + virtual std::any visitColumnExprArrayAccess(HogQLParser::ColumnExprArrayAccessContext *context) = 0; virtual std::any visitColumnExprBetween(HogQLParser::ColumnExprBetweenContext *context) = 0; @@ -225,16 +227,14 @@ class HogQLParserVisitor : public antlr4::tree::AbstractParseTreeVisitor { virtual std::any visitColumnExprWinFunction(HogQLParser::ColumnExprWinFunctionContext *context) = 0; + virtual std::any visitColumnExprLambda(HogQLParser::ColumnExprLambdaContext *context) = 0; + virtual std::any visitColumnExprIdentifier(HogQLParser::ColumnExprIdentifierContext *context) = 0; virtual std::any visitColumnExprFunction(HogQLParser::ColumnExprFunctionContext *context) = 0; virtual std::any visitColumnExprAsterisk(HogQLParser::ColumnExprAsteriskContext *context) = 0; - virtual std::any visitColumnArgList(HogQLParser::ColumnArgListContext *context) = 0; - - virtual std::any visitColumnArgExpr(HogQLParser::ColumnArgExprContext *context) = 0; - virtual std::any visitColumnLambdaExpr(HogQLParser::ColumnLambdaExprContext *context) = 0; virtual std::any visitHogqlxTagElementClosed(HogQLParser::HogqlxTagElementClosedContext *context) = 0; diff --git a/hogql_parser/parser.cpp b/hogql_parser/parser.cpp index 54a1eeedd8e29..409f2fdb46f7b 100644 --- a/hogql_parser/parser.cpp +++ b/hogql_parser/parser.cpp @@ -2151,13 +2151,13 @@ class HogQLParseTreeConverter : public HogQLParserBaseVisitor { VISIT(ColumnExprNot) { RETURN_NEW_AST_NODE("Not", "{s:N}", "expr", visitAsPyObject(ctx->columnExpr())); } VISIT(ColumnExprWinFunctionTarget) { - auto column_expr_list_ctx = ctx->columnExprList(); + auto column_expr_list_ctx = ctx->columnExprs; string name = visitAsString(ctx->identifier(0)); string over_identifier = visitAsString(ctx->identifier(1)); PyObject* exprs = visitAsPyObjectOrEmptyList(column_expr_list_ctx); PyObject* args; try { - args = visitAsPyObjectOrEmptyList(ctx->columnArgList()); + args = visitAsPyObjectOrEmptyList(ctx->columnArgList); } catch (...) { Py_DECREF(exprs); throw; @@ -2170,11 +2170,11 @@ class HogQLParseTreeConverter : public HogQLParserBaseVisitor { VISIT(ColumnExprWinFunction) { string identifier = visitAsString(ctx->identifier()); - auto column_expr_list_ctx = ctx->columnExprList(); + auto column_expr_list_ctx = ctx->columnExprs; PyObject* exprs = visitAsPyObjectOrEmptyList(column_expr_list_ctx); PyObject* args; try { - args = visitAsPyObjectOrEmptyList(ctx->columnArgList()); + args = visitAsPyObjectOrEmptyList(ctx->columnArgList); } catch (...) { Py_DECREF(exprs); throw; @@ -2197,10 +2197,18 @@ class HogQLParseTreeConverter : public HogQLParserBaseVisitor { VISIT(ColumnExprFunction) { string name = visitAsString(ctx->identifier()); - PyObject* params = visitAsPyObjectOrNone(ctx->columnExprList()); + + // if two LPARENs ()(), make sure the first one is at least an empty list + PyObject* params; + if (ctx->LPAREN(1)) { + params = visitAsPyObjectOrEmptyList(ctx->columnExprs); + } else { + params = visitAsPyObjectOrNone(ctx->columnExprs); + } + PyObject* args; try { - args = visitAsPyObjectOrEmptyList(ctx->columnArgList()); + args = visitAsPyObjectOrEmptyList(ctx->columnArgList); } catch (...) { Py_DECREF(params); throw; @@ -2223,10 +2231,18 @@ class HogQLParseTreeConverter : public HogQLParserBaseVisitor { VISIT(ColumnExprTagElement) { return visit(ctx->hogqlxTagElement()); } - VISIT(ColumnArgList) { return visitPyListOfObjects(ctx->columnArgExpr()); } - VISIT(ColumnLambdaExpr) { - PyObject* expr = visitAsPyObject(ctx->columnExpr()); + PyObject* expr; + auto column_expr_ctx = ctx->columnExpr(); + auto block_ctx = ctx->block(); + if (!column_expr_ctx && !block_ctx) { + throw ParsingError("ColumnLambdaExpr must have either a columnExpr or a block"); + } + if (column_expr_ctx) { + expr = visitAsPyObject(column_expr_ctx); + } else { + expr = visitAsPyObject(block_ctx); + } PyObject* args; try { args = X_PyList_FromStrings(visitAsVectorOfStrings(ctx->identifier())); @@ -2575,6 +2591,18 @@ class HogQLParseTreeConverter : public HogQLParserBaseVisitor { RETURN_NEW_AST_NODE("Call", "{s:s, s:[NN]}", "name", "ifNull", "args", value, fallback); } + VISIT(ColumnExprCall) { + PyObject* expr = visitAsPyObject(ctx->columnExpr()); + PyObject* args; + try { + args = visitAsPyObjectOrEmptyList(ctx->columnExprList()); + } catch (...) { + Py_DECREF(expr); + throw; + } + RETURN_NEW_AST_NODE("ExprCall", "{s:N, s:N}", "expr", expr, "args", args); + } + VISIT(ColumnExprTemplateString) { return visit(ctx->templateString()); } VISIT(String) { diff --git a/hogql_parser/setup.py b/hogql_parser/setup.py index 1eb433f6d1d9a..ba14c773be681 100644 --- a/hogql_parser/setup.py +++ b/hogql_parser/setup.py @@ -32,7 +32,7 @@ setup( name="hogql_parser", - version="1.0.36", + version="1.0.38", url="https://github.com/PostHog/posthog/tree/master/hogql_parser", author="PostHog Inc.", author_email="hey@posthog.com", diff --git a/posthog/hogql/ast.py b/posthog/hogql/ast.py index 575085ca1ed45..30602da11df05 100644 --- a/posthog/hogql/ast.py +++ b/posthog/hogql/ast.py @@ -718,6 +718,12 @@ class Call(Expr): distinct: bool = False +@dataclass(kw_only=True) +class ExprCall(Expr): + expr: Expr + args: list[Expr] + + @dataclass(kw_only=True) class JoinConstraint(Expr): expr: Expr diff --git a/posthog/hogql/grammar/HogQLLexer.py b/posthog/hogql/grammar/HogQLLexer.py index 1ce68bc24a643..4647d13b29108 100644 --- a/posthog/hogql/grammar/HogQLLexer.py +++ b/posthog/hogql/grammar/HogQLLexer.py @@ -1,4 +1,4 @@ -# Generated from HogQLLexer.g4 by ANTLR 4.13.1 +# Generated from HogQLLexer.g4 by ANTLR 4.13.2 from antlr4 import * from io import StringIO import sys @@ -830,7 +830,7 @@ class HogQLLexer(Lexer): def __init__(self, input=None, output:TextIO = sys.stdout): super().__init__(input, output) - self.checkVersion("4.13.1") + self.checkVersion("4.13.2") self._interp = LexerATNSimulator(self, self.atn, self.decisionsToDFA, PredictionContextCache()) self._actions = None self._predicates = None diff --git a/posthog/hogql/grammar/HogQLParser.g4 b/posthog/hogql/grammar/HogQLParser.g4 index 4a6e187643877..6e86a6f86afd9 100644 --- a/posthog/hogql/grammar/HogQLParser.g4 +++ b/posthog/hogql/grammar/HogQLParser.g4 @@ -151,9 +151,10 @@ columnExpr | SUBSTRING LPAREN columnExpr FROM columnExpr (FOR columnExpr)? RPAREN # ColumnExprSubstring | TIMESTAMP STRING_LITERAL # ColumnExprTimestamp | TRIM LPAREN (BOTH | LEADING | TRAILING) string FROM columnExpr RPAREN # ColumnExprTrim - | identifier (LPAREN columnExprList? RPAREN) (LPAREN DISTINCT? columnArgList? RPAREN)? OVER LPAREN windowExpr RPAREN # ColumnExprWinFunction - | identifier (LPAREN columnExprList? RPAREN) (LPAREN DISTINCT? columnArgList? RPAREN)? OVER identifier # ColumnExprWinFunctionTarget - | identifier (LPAREN columnExprList? RPAREN)? LPAREN DISTINCT? columnArgList? RPAREN # ColumnExprFunction + | identifier (LPAREN columnExprs=columnExprList? RPAREN) (LPAREN DISTINCT? columnArgList=columnExprList? RPAREN)? OVER LPAREN windowExpr RPAREN # ColumnExprWinFunction + | identifier (LPAREN columnExprs=columnExprList? RPAREN) (LPAREN DISTINCT? columnArgList=columnExprList? RPAREN)? OVER identifier # ColumnExprWinFunctionTarget + | identifier (LPAREN columnExprs=columnExprList? RPAREN)? LPAREN DISTINCT? columnArgList=columnExprList? RPAREN # ColumnExprFunction + | columnExpr LPAREN columnExprList? RPAREN # ColumnExprCall | hogqlxTagElement # ColumnExprTagElement | templateString # ColumnExprTemplateString | literal # ColumnExprLiteral @@ -198,24 +199,23 @@ columnExpr // TODO(ilezhankin): `BETWEEN a AND b AND c` is parsed in a wrong way: `BETWEEN (a AND b) AND c` | columnExpr NOT? BETWEEN columnExpr AND columnExpr # ColumnExprBetween | columnExpr QUERY columnExpr COLON columnExpr # ColumnExprTernaryOp - | columnExpr (AS identifier | AS STRING_LITERAL) # ColumnExprAlias - + | columnExpr (AS identifier | AS STRING_LITERAL) # ColumnExprAlias | (tableIdentifier DOT)? ASTERISK # ColumnExprAsterisk // single-column only | LPAREN selectUnionStmt RPAREN # ColumnExprSubquery // single-column only | LPAREN columnExpr RPAREN # ColumnExprParens // single-column only | LPAREN columnExprList RPAREN # ColumnExprTuple | LBRACKET columnExprList? RBRACKET # ColumnExprArray | LBRACE (kvPairList)? RBRACE # ColumnExprDict + | columnLambdaExpr # ColumnExprLambda | columnIdentifier # ColumnExprIdentifier ; -columnArgList: columnArgExpr (COMMA columnArgExpr)* COMMA?; -columnArgExpr: columnLambdaExpr | columnExpr; columnLambdaExpr: ( LPAREN identifier (COMMA identifier)* COMMA? RPAREN | identifier (COMMA identifier)* COMMA? + | LPAREN RPAREN ) - ARROW columnExpr + ARROW (columnExpr | block) ; diff --git a/posthog/hogql/grammar/HogQLParser.interp b/posthog/hogql/grammar/HogQLParser.interp index 183059ec0fd79..b965cfbb577c7 100644 --- a/posthog/hogql/grammar/HogQLParser.interp +++ b/posthog/hogql/grammar/HogQLParser.interp @@ -382,8 +382,6 @@ expr columnTypeExpr columnExprList columnExpr -columnArgList -columnArgExpr columnLambdaExpr hogqlxTagElement hogqlxTagAttribute @@ -414,4 +412,4 @@ stringContentsFull atn: -[4, 1, 159, 1311, 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, 1, 0, 5, 0, 178, 8, 0, 10, 0, 12, 0, 181, 9, 0, 1, 0, 1, 0, 1, 1, 1, 1, 3, 1, 187, 8, 1, 1, 2, 1, 2, 1, 3, 1, 3, 1, 3, 1, 3, 1, 3, 3, 3, 196, 8, 3, 1, 4, 1, 4, 1, 4, 5, 4, 201, 8, 4, 10, 4, 12, 4, 204, 9, 4, 1, 4, 3, 4, 207, 8, 4, 1, 5, 1, 5, 1, 5, 1, 5, 1, 5, 1, 5, 1, 5, 1, 5, 1, 5, 1, 5, 1, 5, 1, 5, 3, 5, 221, 8, 5, 1, 6, 1, 6, 3, 6, 225, 8, 6, 1, 6, 3, 6, 228, 8, 6, 1, 7, 1, 7, 3, 7, 232, 8, 7, 1, 7, 3, 7, 235, 8, 7, 1, 8, 1, 8, 1, 8, 1, 8, 1, 8, 3, 8, 242, 8, 8, 1, 8, 1, 8, 3, 8, 246, 8, 8, 1, 8, 1, 8, 1, 9, 1, 9, 1, 9, 5, 9, 253, 8, 9, 10, 9, 12, 9, 256, 9, 9, 1, 9, 1, 9, 3, 9, 260, 8, 9, 1, 10, 1, 10, 1, 10, 1, 10, 1, 10, 1, 10, 1, 10, 3, 10, 269, 8, 10, 1, 11, 1, 11, 1, 11, 1, 11, 1, 11, 1, 11, 3, 11, 277, 8, 11, 1, 12, 1, 12, 1, 12, 1, 12, 1, 12, 3, 12, 284, 8, 12, 1, 12, 1, 12, 3, 12, 288, 8, 12, 1, 12, 1, 12, 1, 12, 1, 12, 3, 12, 294, 8, 12, 1, 12, 1, 12, 1, 12, 3, 12, 299, 8, 12, 1, 13, 1, 13, 1, 13, 1, 13, 1, 13, 1, 13, 3, 13, 307, 8, 13, 1, 13, 1, 13, 1, 13, 1, 13, 1, 13, 3, 13, 314, 8, 13, 1, 14, 1, 14, 1, 14, 1, 14, 3, 14, 320, 8, 14, 1, 14, 1, 14, 1, 14, 1, 15, 1, 15, 1, 15, 1, 15, 1, 15, 1, 16, 1, 16, 3, 16, 332, 8, 16, 1, 17, 1, 17, 1, 18, 1, 18, 5, 18, 338, 8, 18, 10, 18, 12, 18, 341, 9, 18, 1, 18, 1, 18, 1, 19, 1, 19, 1, 19, 1, 19, 1, 20, 1, 20, 1, 20, 5, 20, 352, 8, 20, 10, 20, 12, 20, 355, 9, 20, 1, 20, 3, 20, 358, 8, 20, 1, 21, 1, 21, 1, 21, 3, 21, 363, 8, 21, 1, 21, 1, 21, 1, 22, 1, 22, 1, 22, 1, 22, 5, 22, 371, 8, 22, 10, 22, 12, 22, 374, 9, 22, 1, 23, 1, 23, 1, 23, 1, 23, 1, 23, 1, 23, 3, 23, 382, 8, 23, 1, 24, 3, 24, 385, 8, 24, 1, 24, 1, 24, 3, 24, 389, 8, 24, 1, 24, 3, 24, 392, 8, 24, 1, 24, 1, 24, 3, 24, 396, 8, 24, 1, 24, 3, 24, 399, 8, 24, 1, 24, 3, 24, 402, 8, 24, 1, 24, 3, 24, 405, 8, 24, 1, 24, 3, 24, 408, 8, 24, 1, 24, 1, 24, 3, 24, 412, 8, 24, 1, 24, 1, 24, 3, 24, 416, 8, 24, 1, 24, 3, 24, 419, 8, 24, 1, 24, 3, 24, 422, 8, 24, 1, 24, 3, 24, 425, 8, 24, 1, 24, 1, 24, 3, 24, 429, 8, 24, 1, 24, 3, 24, 432, 8, 24, 1, 25, 1, 25, 1, 25, 1, 26, 1, 26, 1, 26, 1, 26, 3, 26, 441, 8, 26, 1, 27, 1, 27, 1, 27, 1, 28, 3, 28, 447, 8, 28, 1, 28, 1, 28, 1, 28, 1, 28, 1, 29, 1, 29, 1, 29, 1, 29, 1, 29, 1, 29, 1, 29, 1, 29, 1, 29, 1, 29, 1, 29, 1, 29, 1, 29, 5, 29, 466, 8, 29, 10, 29, 12, 29, 469, 9, 29, 1, 30, 1, 30, 1, 30, 1, 31, 1, 31, 1, 31, 1, 32, 1, 32, 1, 32, 1, 32, 1, 32, 1, 32, 1, 32, 1, 32, 3, 32, 485, 8, 32, 1, 33, 1, 33, 1, 33, 1, 34, 1, 34, 1, 34, 1, 34, 1, 35, 1, 35, 1, 35, 1, 35, 1, 36, 1, 36, 1, 36, 1, 36, 3, 36, 502, 8, 36, 1, 36, 1, 36, 1, 36, 1, 36, 3, 36, 508, 8, 36, 1, 36, 1, 36, 1, 36, 1, 36, 3, 36, 514, 8, 36, 1, 36, 1, 36, 1, 36, 1, 36, 1, 36, 1, 36, 1, 36, 1, 36, 1, 36, 3, 36, 525, 8, 36, 3, 36, 527, 8, 36, 1, 37, 1, 37, 1, 37, 1, 38, 1, 38, 1, 38, 1, 39, 1, 39, 1, 39, 3, 39, 538, 8, 39, 1, 39, 3, 39, 541, 8, 39, 1, 39, 1, 39, 1, 39, 1, 39, 3, 39, 547, 8, 39, 1, 39, 1, 39, 1, 39, 1, 39, 1, 39, 1, 39, 3, 39, 555, 8, 39, 1, 39, 1, 39, 1, 39, 1, 39, 5, 39, 561, 8, 39, 10, 39, 12, 39, 564, 9, 39, 1, 40, 3, 40, 567, 8, 40, 1, 40, 1, 40, 1, 40, 3, 40, 572, 8, 40, 1, 40, 3, 40, 575, 8, 40, 1, 40, 3, 40, 578, 8, 40, 1, 40, 1, 40, 3, 40, 582, 8, 40, 1, 40, 1, 40, 3, 40, 586, 8, 40, 1, 40, 3, 40, 589, 8, 40, 3, 40, 591, 8, 40, 1, 40, 3, 40, 594, 8, 40, 1, 40, 1, 40, 3, 40, 598, 8, 40, 1, 40, 1, 40, 3, 40, 602, 8, 40, 1, 40, 3, 40, 605, 8, 40, 3, 40, 607, 8, 40, 3, 40, 609, 8, 40, 1, 41, 1, 41, 1, 41, 3, 41, 614, 8, 41, 1, 42, 1, 42, 1, 42, 1, 42, 1, 42, 1, 42, 1, 42, 1, 42, 1, 42, 3, 42, 625, 8, 42, 1, 43, 1, 43, 1, 43, 1, 43, 3, 43, 631, 8, 43, 1, 44, 1, 44, 1, 44, 5, 44, 636, 8, 44, 10, 44, 12, 44, 639, 9, 44, 1, 45, 1, 45, 3, 45, 643, 8, 45, 1, 45, 1, 45, 3, 45, 647, 8, 45, 1, 45, 1, 45, 3, 45, 651, 8, 45, 1, 46, 1, 46, 1, 46, 1, 46, 3, 46, 657, 8, 46, 3, 46, 659, 8, 46, 1, 47, 1, 47, 1, 47, 5, 47, 664, 8, 47, 10, 47, 12, 47, 667, 9, 47, 1, 48, 1, 48, 1, 48, 1, 48, 1, 49, 3, 49, 674, 8, 49, 1, 49, 3, 49, 677, 8, 49, 1, 49, 3, 49, 680, 8, 49, 1, 50, 1, 50, 1, 50, 1, 50, 1, 51, 1, 51, 1, 51, 1, 51, 1, 52, 1, 52, 1, 52, 1, 53, 1, 53, 1, 53, 1, 53, 1, 53, 1, 53, 3, 53, 699, 8, 53, 1, 54, 1, 54, 1, 54, 1, 54, 1, 54, 1, 54, 1, 54, 1, 54, 1, 54, 1, 54, 1, 54, 1, 54, 3, 54, 713, 8, 54, 1, 55, 1, 55, 1, 55, 1, 56, 1, 56, 1, 56, 1, 56, 1, 56, 1, 56, 1, 56, 1, 56, 1, 56, 5, 56, 727, 8, 56, 10, 56, 12, 56, 730, 9, 56, 1, 56, 3, 56, 733, 8, 56, 1, 56, 1, 56, 1, 56, 1, 56, 1, 56, 1, 56, 1, 56, 5, 56, 742, 8, 56, 10, 56, 12, 56, 745, 9, 56, 1, 56, 3, 56, 748, 8, 56, 1, 56, 1, 56, 1, 56, 1, 56, 1, 56, 1, 56, 1, 56, 5, 56, 757, 8, 56, 10, 56, 12, 56, 760, 9, 56, 1, 56, 3, 56, 763, 8, 56, 1, 56, 1, 56, 1, 56, 1, 56, 1, 56, 3, 56, 770, 8, 56, 1, 56, 1, 56, 3, 56, 774, 8, 56, 1, 57, 1, 57, 1, 57, 5, 57, 779, 8, 57, 10, 57, 12, 57, 782, 9, 57, 1, 57, 3, 57, 785, 8, 57, 1, 58, 1, 58, 1, 58, 3, 58, 790, 8, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 4, 58, 797, 8, 58, 11, 58, 12, 58, 798, 1, 58, 1, 58, 3, 58, 803, 8, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 3, 58, 827, 8, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 3, 58, 844, 8, 58, 1, 58, 1, 58, 1, 58, 1, 58, 3, 58, 850, 8, 58, 1, 58, 3, 58, 853, 8, 58, 1, 58, 3, 58, 856, 8, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 3, 58, 866, 8, 58, 1, 58, 1, 58, 1, 58, 1, 58, 3, 58, 872, 8, 58, 1, 58, 3, 58, 875, 8, 58, 1, 58, 3, 58, 878, 8, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 3, 58, 886, 8, 58, 1, 58, 3, 58, 889, 8, 58, 1, 58, 1, 58, 3, 58, 893, 8, 58, 1, 58, 3, 58, 896, 8, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 3, 58, 910, 8, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 3, 58, 927, 8, 58, 1, 58, 1, 58, 1, 58, 3, 58, 932, 8, 58, 1, 58, 1, 58, 3, 58, 936, 8, 58, 1, 58, 1, 58, 1, 58, 1, 58, 3, 58, 942, 8, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 3, 58, 949, 8, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 3, 58, 961, 8, 58, 1, 58, 1, 58, 3, 58, 965, 8, 58, 1, 58, 3, 58, 968, 8, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 3, 58, 977, 8, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 3, 58, 991, 8, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 3, 58, 1030, 8, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 3, 58, 1038, 8, 58, 5, 58, 1040, 8, 58, 10, 58, 12, 58, 1043, 9, 58, 1, 59, 1, 59, 1, 59, 5, 59, 1048, 8, 59, 10, 59, 12, 59, 1051, 9, 59, 1, 59, 3, 59, 1054, 8, 59, 1, 60, 1, 60, 3, 60, 1058, 8, 60, 1, 61, 1, 61, 1, 61, 1, 61, 5, 61, 1064, 8, 61, 10, 61, 12, 61, 1067, 9, 61, 1, 61, 3, 61, 1070, 8, 61, 1, 61, 1, 61, 1, 61, 1, 61, 1, 61, 5, 61, 1077, 8, 61, 10, 61, 12, 61, 1080, 9, 61, 1, 61, 3, 61, 1083, 8, 61, 3, 61, 1085, 8, 61, 1, 61, 1, 61, 1, 61, 1, 62, 1, 62, 1, 62, 5, 62, 1093, 8, 62, 10, 62, 12, 62, 1096, 9, 62, 1, 62, 1, 62, 1, 62, 1, 62, 1, 62, 1, 62, 5, 62, 1104, 8, 62, 10, 62, 12, 62, 1107, 9, 62, 1, 62, 1, 62, 1, 62, 1, 62, 1, 62, 1, 62, 3, 62, 1115, 8, 62, 1, 62, 1, 62, 1, 62, 1, 62, 1, 62, 3, 62, 1122, 8, 62, 1, 63, 1, 63, 1, 63, 1, 63, 1, 63, 1, 63, 1, 63, 1, 63, 1, 63, 1, 63, 1, 63, 3, 63, 1135, 8, 63, 1, 64, 1, 64, 1, 64, 5, 64, 1140, 8, 64, 10, 64, 12, 64, 1143, 9, 64, 1, 64, 3, 64, 1146, 8, 64, 1, 65, 1, 65, 1, 65, 1, 65, 1, 65, 1, 65, 1, 65, 1, 65, 1, 65, 1, 65, 3, 65, 1158, 8, 65, 1, 66, 1, 66, 1, 66, 1, 66, 3, 66, 1164, 8, 66, 1, 66, 3, 66, 1167, 8, 66, 1, 67, 1, 67, 1, 67, 5, 67, 1172, 8, 67, 10, 67, 12, 67, 1175, 9, 67, 1, 68, 1, 68, 1, 68, 1, 68, 1, 68, 1, 68, 1, 68, 1, 68, 1, 68, 3, 68, 1186, 8, 68, 1, 68, 1, 68, 1, 68, 1, 68, 3, 68, 1192, 8, 68, 5, 68, 1194, 8, 68, 10, 68, 12, 68, 1197, 9, 68, 1, 69, 1, 69, 1, 69, 3, 69, 1202, 8, 69, 1, 69, 1, 69, 1, 70, 1, 70, 1, 70, 3, 70, 1209, 8, 70, 1, 70, 1, 70, 1, 71, 1, 71, 1, 71, 5, 71, 1216, 8, 71, 10, 71, 12, 71, 1219, 9, 71, 1, 71, 3, 71, 1222, 8, 71, 1, 72, 1, 72, 1, 73, 1, 73, 1, 73, 1, 73, 1, 73, 1, 73, 3, 73, 1232, 8, 73, 3, 73, 1234, 8, 73, 1, 74, 3, 74, 1237, 8, 74, 1, 74, 1, 74, 1, 74, 1, 74, 1, 74, 1, 74, 3, 74, 1245, 8, 74, 1, 75, 1, 75, 1, 75, 3, 75, 1250, 8, 75, 1, 76, 1, 76, 1, 77, 1, 77, 1, 78, 1, 78, 1, 79, 1, 79, 3, 79, 1260, 8, 79, 1, 80, 1, 80, 1, 80, 3, 80, 1265, 8, 80, 1, 81, 1, 81, 1, 81, 1, 81, 1, 82, 1, 82, 1, 82, 1, 82, 1, 83, 1, 83, 3, 83, 1277, 8, 83, 1, 84, 1, 84, 5, 84, 1281, 8, 84, 10, 84, 12, 84, 1284, 9, 84, 1, 84, 1, 84, 1, 85, 1, 85, 1, 85, 1, 85, 1, 85, 3, 85, 1293, 8, 85, 1, 86, 1, 86, 5, 86, 1297, 8, 86, 10, 86, 12, 86, 1300, 9, 86, 1, 86, 1, 86, 1, 87, 1, 87, 1, 87, 1, 87, 1, 87, 3, 87, 1309, 8, 87, 1, 87, 0, 3, 78, 116, 136, 88, 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, 0, 16, 2, 0, 18, 18, 74, 74, 2, 0, 44, 44, 51, 51, 3, 0, 1, 1, 4, 4, 8, 8, 4, 0, 1, 1, 3, 4, 8, 8, 80, 80, 2, 0, 51, 51, 73, 73, 2, 0, 1, 1, 4, 4, 2, 0, 7, 7, 22, 23, 2, 0, 30, 30, 49, 49, 2, 0, 71, 71, 76, 76, 3, 0, 10, 10, 50, 50, 90, 90, 2, 0, 41, 41, 53, 53, 1, 0, 107, 108, 2, 0, 118, 118, 139, 139, 7, 0, 21, 21, 38, 38, 55, 56, 70, 70, 78, 78, 97, 97, 103, 103, 16, 0, 1, 13, 15, 20, 22, 28, 30, 30, 32, 37, 39, 42, 44, 51, 53, 54, 58, 58, 60, 69, 71, 77, 79, 83, 85, 92, 94, 96, 98, 99, 101, 102, 4, 0, 20, 20, 30, 30, 39, 39, 48, 48, 1479, 0, 179, 1, 0, 0, 0, 2, 186, 1, 0, 0, 0, 4, 188, 1, 0, 0, 0, 6, 190, 1, 0, 0, 0, 8, 197, 1, 0, 0, 0, 10, 220, 1, 0, 0, 0, 12, 222, 1, 0, 0, 0, 14, 229, 1, 0, 0, 0, 16, 236, 1, 0, 0, 0, 18, 249, 1, 0, 0, 0, 20, 261, 1, 0, 0, 0, 22, 270, 1, 0, 0, 0, 24, 278, 1, 0, 0, 0, 26, 300, 1, 0, 0, 0, 28, 315, 1, 0, 0, 0, 30, 324, 1, 0, 0, 0, 32, 329, 1, 0, 0, 0, 34, 333, 1, 0, 0, 0, 36, 335, 1, 0, 0, 0, 38, 344, 1, 0, 0, 0, 40, 348, 1, 0, 0, 0, 42, 362, 1, 0, 0, 0, 44, 366, 1, 0, 0, 0, 46, 381, 1, 0, 0, 0, 48, 384, 1, 0, 0, 0, 50, 433, 1, 0, 0, 0, 52, 436, 1, 0, 0, 0, 54, 442, 1, 0, 0, 0, 56, 446, 1, 0, 0, 0, 58, 452, 1, 0, 0, 0, 60, 470, 1, 0, 0, 0, 62, 473, 1, 0, 0, 0, 64, 476, 1, 0, 0, 0, 66, 486, 1, 0, 0, 0, 68, 489, 1, 0, 0, 0, 70, 493, 1, 0, 0, 0, 72, 526, 1, 0, 0, 0, 74, 528, 1, 0, 0, 0, 76, 531, 1, 0, 0, 0, 78, 546, 1, 0, 0, 0, 80, 608, 1, 0, 0, 0, 82, 613, 1, 0, 0, 0, 84, 624, 1, 0, 0, 0, 86, 626, 1, 0, 0, 0, 88, 632, 1, 0, 0, 0, 90, 640, 1, 0, 0, 0, 92, 658, 1, 0, 0, 0, 94, 660, 1, 0, 0, 0, 96, 668, 1, 0, 0, 0, 98, 673, 1, 0, 0, 0, 100, 681, 1, 0, 0, 0, 102, 685, 1, 0, 0, 0, 104, 689, 1, 0, 0, 0, 106, 698, 1, 0, 0, 0, 108, 712, 1, 0, 0, 0, 110, 714, 1, 0, 0, 0, 112, 773, 1, 0, 0, 0, 114, 775, 1, 0, 0, 0, 116, 935, 1, 0, 0, 0, 118, 1044, 1, 0, 0, 0, 120, 1057, 1, 0, 0, 0, 122, 1084, 1, 0, 0, 0, 124, 1121, 1, 0, 0, 0, 126, 1134, 1, 0, 0, 0, 128, 1136, 1, 0, 0, 0, 130, 1157, 1, 0, 0, 0, 132, 1166, 1, 0, 0, 0, 134, 1168, 1, 0, 0, 0, 136, 1185, 1, 0, 0, 0, 138, 1198, 1, 0, 0, 0, 140, 1208, 1, 0, 0, 0, 142, 1212, 1, 0, 0, 0, 144, 1223, 1, 0, 0, 0, 146, 1233, 1, 0, 0, 0, 148, 1236, 1, 0, 0, 0, 150, 1249, 1, 0, 0, 0, 152, 1251, 1, 0, 0, 0, 154, 1253, 1, 0, 0, 0, 156, 1255, 1, 0, 0, 0, 158, 1259, 1, 0, 0, 0, 160, 1264, 1, 0, 0, 0, 162, 1266, 1, 0, 0, 0, 164, 1270, 1, 0, 0, 0, 166, 1276, 1, 0, 0, 0, 168, 1278, 1, 0, 0, 0, 170, 1292, 1, 0, 0, 0, 172, 1294, 1, 0, 0, 0, 174, 1308, 1, 0, 0, 0, 176, 178, 3, 2, 1, 0, 177, 176, 1, 0, 0, 0, 178, 181, 1, 0, 0, 0, 179, 177, 1, 0, 0, 0, 179, 180, 1, 0, 0, 0, 180, 182, 1, 0, 0, 0, 181, 179, 1, 0, 0, 0, 182, 183, 5, 0, 0, 1, 183, 1, 1, 0, 0, 0, 184, 187, 3, 6, 3, 0, 185, 187, 3, 10, 5, 0, 186, 184, 1, 0, 0, 0, 186, 185, 1, 0, 0, 0, 187, 3, 1, 0, 0, 0, 188, 189, 3, 116, 58, 0, 189, 5, 1, 0, 0, 0, 190, 191, 5, 52, 0, 0, 191, 195, 3, 160, 80, 0, 192, 193, 5, 115, 0, 0, 193, 194, 5, 122, 0, 0, 194, 196, 3, 4, 2, 0, 195, 192, 1, 0, 0, 0, 195, 196, 1, 0, 0, 0, 196, 7, 1, 0, 0, 0, 197, 202, 3, 160, 80, 0, 198, 199, 5, 116, 0, 0, 199, 201, 3, 160, 80, 0, 200, 198, 1, 0, 0, 0, 201, 204, 1, 0, 0, 0, 202, 200, 1, 0, 0, 0, 202, 203, 1, 0, 0, 0, 203, 206, 1, 0, 0, 0, 204, 202, 1, 0, 0, 0, 205, 207, 5, 116, 0, 0, 206, 205, 1, 0, 0, 0, 206, 207, 1, 0, 0, 0, 207, 9, 1, 0, 0, 0, 208, 221, 3, 12, 6, 0, 209, 221, 3, 14, 7, 0, 210, 221, 3, 18, 9, 0, 211, 221, 3, 20, 10, 0, 212, 221, 3, 22, 11, 0, 213, 221, 3, 26, 13, 0, 214, 221, 3, 24, 12, 0, 215, 221, 3, 28, 14, 0, 216, 221, 3, 30, 15, 0, 217, 221, 3, 36, 18, 0, 218, 221, 3, 32, 16, 0, 219, 221, 3, 34, 17, 0, 220, 208, 1, 0, 0, 0, 220, 209, 1, 0, 0, 0, 220, 210, 1, 0, 0, 0, 220, 211, 1, 0, 0, 0, 220, 212, 1, 0, 0, 0, 220, 213, 1, 0, 0, 0, 220, 214, 1, 0, 0, 0, 220, 215, 1, 0, 0, 0, 220, 216, 1, 0, 0, 0, 220, 217, 1, 0, 0, 0, 220, 218, 1, 0, 0, 0, 220, 219, 1, 0, 0, 0, 221, 11, 1, 0, 0, 0, 222, 224, 5, 72, 0, 0, 223, 225, 3, 4, 2, 0, 224, 223, 1, 0, 0, 0, 224, 225, 1, 0, 0, 0, 225, 227, 1, 0, 0, 0, 226, 228, 5, 150, 0, 0, 227, 226, 1, 0, 0, 0, 227, 228, 1, 0, 0, 0, 228, 13, 1, 0, 0, 0, 229, 231, 5, 84, 0, 0, 230, 232, 3, 4, 2, 0, 231, 230, 1, 0, 0, 0, 231, 232, 1, 0, 0, 0, 232, 234, 1, 0, 0, 0, 233, 235, 5, 150, 0, 0, 234, 233, 1, 0, 0, 0, 234, 235, 1, 0, 0, 0, 235, 15, 1, 0, 0, 0, 236, 245, 5, 14, 0, 0, 237, 238, 5, 130, 0, 0, 238, 241, 3, 160, 80, 0, 239, 240, 5, 115, 0, 0, 240, 242, 3, 160, 80, 0, 241, 239, 1, 0, 0, 0, 241, 242, 1, 0, 0, 0, 242, 243, 1, 0, 0, 0, 243, 244, 5, 149, 0, 0, 244, 246, 1, 0, 0, 0, 245, 237, 1, 0, 0, 0, 245, 246, 1, 0, 0, 0, 246, 247, 1, 0, 0, 0, 247, 248, 3, 36, 18, 0, 248, 17, 1, 0, 0, 0, 249, 250, 5, 93, 0, 0, 250, 254, 3, 36, 18, 0, 251, 253, 3, 16, 8, 0, 252, 251, 1, 0, 0, 0, 253, 256, 1, 0, 0, 0, 254, 252, 1, 0, 0, 0, 254, 255, 1, 0, 0, 0, 255, 259, 1, 0, 0, 0, 256, 254, 1, 0, 0, 0, 257, 258, 5, 29, 0, 0, 258, 260, 3, 36, 18, 0, 259, 257, 1, 0, 0, 0, 259, 260, 1, 0, 0, 0, 260, 19, 1, 0, 0, 0, 261, 262, 5, 40, 0, 0, 262, 263, 5, 130, 0, 0, 263, 264, 3, 4, 2, 0, 264, 265, 5, 149, 0, 0, 265, 268, 3, 10, 5, 0, 266, 267, 5, 25, 0, 0, 267, 269, 3, 10, 5, 0, 268, 266, 1, 0, 0, 0, 268, 269, 1, 0, 0, 0, 269, 21, 1, 0, 0, 0, 270, 271, 5, 100, 0, 0, 271, 272, 5, 130, 0, 0, 272, 273, 3, 4, 2, 0, 273, 274, 5, 149, 0, 0, 274, 276, 3, 10, 5, 0, 275, 277, 5, 150, 0, 0, 276, 275, 1, 0, 0, 0, 276, 277, 1, 0, 0, 0, 277, 23, 1, 0, 0, 0, 278, 279, 5, 33, 0, 0, 279, 283, 5, 130, 0, 0, 280, 284, 3, 6, 3, 0, 281, 284, 3, 30, 15, 0, 282, 284, 3, 4, 2, 0, 283, 280, 1, 0, 0, 0, 283, 281, 1, 0, 0, 0, 283, 282, 1, 0, 0, 0, 283, 284, 1, 0, 0, 0, 284, 285, 1, 0, 0, 0, 285, 287, 5, 150, 0, 0, 286, 288, 3, 4, 2, 0, 287, 286, 1, 0, 0, 0, 287, 288, 1, 0, 0, 0, 288, 289, 1, 0, 0, 0, 289, 293, 5, 150, 0, 0, 290, 294, 3, 6, 3, 0, 291, 294, 3, 30, 15, 0, 292, 294, 3, 4, 2, 0, 293, 290, 1, 0, 0, 0, 293, 291, 1, 0, 0, 0, 293, 292, 1, 0, 0, 0, 293, 294, 1, 0, 0, 0, 294, 295, 1, 0, 0, 0, 295, 296, 5, 149, 0, 0, 296, 298, 3, 10, 5, 0, 297, 299, 5, 150, 0, 0, 298, 297, 1, 0, 0, 0, 298, 299, 1, 0, 0, 0, 299, 25, 1, 0, 0, 0, 300, 301, 5, 33, 0, 0, 301, 302, 5, 130, 0, 0, 302, 303, 5, 52, 0, 0, 303, 306, 3, 160, 80, 0, 304, 305, 5, 116, 0, 0, 305, 307, 3, 160, 80, 0, 306, 304, 1, 0, 0, 0, 306, 307, 1, 0, 0, 0, 307, 308, 1, 0, 0, 0, 308, 309, 5, 42, 0, 0, 309, 310, 3, 4, 2, 0, 310, 311, 5, 149, 0, 0, 311, 313, 3, 10, 5, 0, 312, 314, 5, 150, 0, 0, 313, 312, 1, 0, 0, 0, 313, 314, 1, 0, 0, 0, 314, 27, 1, 0, 0, 0, 315, 316, 5, 31, 0, 0, 316, 317, 3, 160, 80, 0, 317, 319, 5, 130, 0, 0, 318, 320, 3, 8, 4, 0, 319, 318, 1, 0, 0, 0, 319, 320, 1, 0, 0, 0, 320, 321, 1, 0, 0, 0, 321, 322, 5, 149, 0, 0, 322, 323, 3, 36, 18, 0, 323, 29, 1, 0, 0, 0, 324, 325, 3, 4, 2, 0, 325, 326, 5, 115, 0, 0, 326, 327, 5, 122, 0, 0, 327, 328, 3, 4, 2, 0, 328, 31, 1, 0, 0, 0, 329, 331, 3, 4, 2, 0, 330, 332, 5, 150, 0, 0, 331, 330, 1, 0, 0, 0, 331, 332, 1, 0, 0, 0, 332, 33, 1, 0, 0, 0, 333, 334, 5, 150, 0, 0, 334, 35, 1, 0, 0, 0, 335, 339, 5, 128, 0, 0, 336, 338, 3, 2, 1, 0, 337, 336, 1, 0, 0, 0, 338, 341, 1, 0, 0, 0, 339, 337, 1, 0, 0, 0, 339, 340, 1, 0, 0, 0, 340, 342, 1, 0, 0, 0, 341, 339, 1, 0, 0, 0, 342, 343, 5, 147, 0, 0, 343, 37, 1, 0, 0, 0, 344, 345, 3, 4, 2, 0, 345, 346, 5, 115, 0, 0, 346, 347, 3, 4, 2, 0, 347, 39, 1, 0, 0, 0, 348, 353, 3, 38, 19, 0, 349, 350, 5, 116, 0, 0, 350, 352, 3, 38, 19, 0, 351, 349, 1, 0, 0, 0, 352, 355, 1, 0, 0, 0, 353, 351, 1, 0, 0, 0, 353, 354, 1, 0, 0, 0, 354, 357, 1, 0, 0, 0, 355, 353, 1, 0, 0, 0, 356, 358, 5, 116, 0, 0, 357, 356, 1, 0, 0, 0, 357, 358, 1, 0, 0, 0, 358, 41, 1, 0, 0, 0, 359, 363, 3, 44, 22, 0, 360, 363, 3, 48, 24, 0, 361, 363, 3, 124, 62, 0, 362, 359, 1, 0, 0, 0, 362, 360, 1, 0, 0, 0, 362, 361, 1, 0, 0, 0, 363, 364, 1, 0, 0, 0, 364, 365, 5, 0, 0, 1, 365, 43, 1, 0, 0, 0, 366, 372, 3, 46, 23, 0, 367, 368, 5, 95, 0, 0, 368, 369, 5, 1, 0, 0, 369, 371, 3, 46, 23, 0, 370, 367, 1, 0, 0, 0, 371, 374, 1, 0, 0, 0, 372, 370, 1, 0, 0, 0, 372, 373, 1, 0, 0, 0, 373, 45, 1, 0, 0, 0, 374, 372, 1, 0, 0, 0, 375, 382, 3, 48, 24, 0, 376, 377, 5, 130, 0, 0, 377, 378, 3, 44, 22, 0, 378, 379, 5, 149, 0, 0, 379, 382, 1, 0, 0, 0, 380, 382, 3, 164, 82, 0, 381, 375, 1, 0, 0, 0, 381, 376, 1, 0, 0, 0, 381, 380, 1, 0, 0, 0, 382, 47, 1, 0, 0, 0, 383, 385, 3, 50, 25, 0, 384, 383, 1, 0, 0, 0, 384, 385, 1, 0, 0, 0, 385, 386, 1, 0, 0, 0, 386, 388, 5, 79, 0, 0, 387, 389, 5, 24, 0, 0, 388, 387, 1, 0, 0, 0, 388, 389, 1, 0, 0, 0, 389, 391, 1, 0, 0, 0, 390, 392, 3, 52, 26, 0, 391, 390, 1, 0, 0, 0, 391, 392, 1, 0, 0, 0, 392, 393, 1, 0, 0, 0, 393, 395, 3, 114, 57, 0, 394, 396, 3, 54, 27, 0, 395, 394, 1, 0, 0, 0, 395, 396, 1, 0, 0, 0, 396, 398, 1, 0, 0, 0, 397, 399, 3, 56, 28, 0, 398, 397, 1, 0, 0, 0, 398, 399, 1, 0, 0, 0, 399, 401, 1, 0, 0, 0, 400, 402, 3, 60, 30, 0, 401, 400, 1, 0, 0, 0, 401, 402, 1, 0, 0, 0, 402, 404, 1, 0, 0, 0, 403, 405, 3, 62, 31, 0, 404, 403, 1, 0, 0, 0, 404, 405, 1, 0, 0, 0, 405, 407, 1, 0, 0, 0, 406, 408, 3, 64, 32, 0, 407, 406, 1, 0, 0, 0, 407, 408, 1, 0, 0, 0, 408, 411, 1, 0, 0, 0, 409, 410, 5, 102, 0, 0, 410, 412, 7, 0, 0, 0, 411, 409, 1, 0, 0, 0, 411, 412, 1, 0, 0, 0, 412, 415, 1, 0, 0, 0, 413, 414, 5, 102, 0, 0, 414, 416, 5, 89, 0, 0, 415, 413, 1, 0, 0, 0, 415, 416, 1, 0, 0, 0, 416, 418, 1, 0, 0, 0, 417, 419, 3, 66, 33, 0, 418, 417, 1, 0, 0, 0, 418, 419, 1, 0, 0, 0, 419, 421, 1, 0, 0, 0, 420, 422, 3, 58, 29, 0, 421, 420, 1, 0, 0, 0, 421, 422, 1, 0, 0, 0, 422, 424, 1, 0, 0, 0, 423, 425, 3, 68, 34, 0, 424, 423, 1, 0, 0, 0, 424, 425, 1, 0, 0, 0, 425, 428, 1, 0, 0, 0, 426, 429, 3, 72, 36, 0, 427, 429, 3, 74, 37, 0, 428, 426, 1, 0, 0, 0, 428, 427, 1, 0, 0, 0, 428, 429, 1, 0, 0, 0, 429, 431, 1, 0, 0, 0, 430, 432, 3, 76, 38, 0, 431, 430, 1, 0, 0, 0, 431, 432, 1, 0, 0, 0, 432, 49, 1, 0, 0, 0, 433, 434, 5, 102, 0, 0, 434, 435, 3, 128, 64, 0, 435, 51, 1, 0, 0, 0, 436, 437, 5, 88, 0, 0, 437, 440, 5, 108, 0, 0, 438, 439, 5, 102, 0, 0, 439, 441, 5, 85, 0, 0, 440, 438, 1, 0, 0, 0, 440, 441, 1, 0, 0, 0, 441, 53, 1, 0, 0, 0, 442, 443, 5, 34, 0, 0, 443, 444, 3, 78, 39, 0, 444, 55, 1, 0, 0, 0, 445, 447, 7, 1, 0, 0, 446, 445, 1, 0, 0, 0, 446, 447, 1, 0, 0, 0, 447, 448, 1, 0, 0, 0, 448, 449, 5, 5, 0, 0, 449, 450, 5, 47, 0, 0, 450, 451, 3, 114, 57, 0, 451, 57, 1, 0, 0, 0, 452, 453, 5, 101, 0, 0, 453, 454, 3, 160, 80, 0, 454, 455, 5, 6, 0, 0, 455, 456, 5, 130, 0, 0, 456, 457, 3, 98, 49, 0, 457, 467, 5, 149, 0, 0, 458, 459, 5, 116, 0, 0, 459, 460, 3, 160, 80, 0, 460, 461, 5, 6, 0, 0, 461, 462, 5, 130, 0, 0, 462, 463, 3, 98, 49, 0, 463, 464, 5, 149, 0, 0, 464, 466, 1, 0, 0, 0, 465, 458, 1, 0, 0, 0, 466, 469, 1, 0, 0, 0, 467, 465, 1, 0, 0, 0, 467, 468, 1, 0, 0, 0, 468, 59, 1, 0, 0, 0, 469, 467, 1, 0, 0, 0, 470, 471, 5, 69, 0, 0, 471, 472, 3, 116, 58, 0, 472, 61, 1, 0, 0, 0, 473, 474, 5, 99, 0, 0, 474, 475, 3, 116, 58, 0, 475, 63, 1, 0, 0, 0, 476, 477, 5, 36, 0, 0, 477, 484, 5, 11, 0, 0, 478, 479, 7, 0, 0, 0, 479, 480, 5, 130, 0, 0, 480, 481, 3, 114, 57, 0, 481, 482, 5, 149, 0, 0, 482, 485, 1, 0, 0, 0, 483, 485, 3, 114, 57, 0, 484, 478, 1, 0, 0, 0, 484, 483, 1, 0, 0, 0, 485, 65, 1, 0, 0, 0, 486, 487, 5, 37, 0, 0, 487, 488, 3, 116, 58, 0, 488, 67, 1, 0, 0, 0, 489, 490, 5, 64, 0, 0, 490, 491, 5, 11, 0, 0, 491, 492, 3, 88, 44, 0, 492, 69, 1, 0, 0, 0, 493, 494, 5, 64, 0, 0, 494, 495, 5, 11, 0, 0, 495, 496, 3, 114, 57, 0, 496, 71, 1, 0, 0, 0, 497, 498, 5, 54, 0, 0, 498, 501, 3, 116, 58, 0, 499, 500, 5, 116, 0, 0, 500, 502, 3, 116, 58, 0, 501, 499, 1, 0, 0, 0, 501, 502, 1, 0, 0, 0, 502, 507, 1, 0, 0, 0, 503, 504, 5, 102, 0, 0, 504, 508, 5, 85, 0, 0, 505, 506, 5, 11, 0, 0, 506, 508, 3, 114, 57, 0, 507, 503, 1, 0, 0, 0, 507, 505, 1, 0, 0, 0, 507, 508, 1, 0, 0, 0, 508, 527, 1, 0, 0, 0, 509, 510, 5, 54, 0, 0, 510, 513, 3, 116, 58, 0, 511, 512, 5, 102, 0, 0, 512, 514, 5, 85, 0, 0, 513, 511, 1, 0, 0, 0, 513, 514, 1, 0, 0, 0, 514, 515, 1, 0, 0, 0, 515, 516, 5, 61, 0, 0, 516, 517, 3, 116, 58, 0, 517, 527, 1, 0, 0, 0, 518, 519, 5, 54, 0, 0, 519, 520, 3, 116, 58, 0, 520, 521, 5, 61, 0, 0, 521, 524, 3, 116, 58, 0, 522, 523, 5, 11, 0, 0, 523, 525, 3, 114, 57, 0, 524, 522, 1, 0, 0, 0, 524, 525, 1, 0, 0, 0, 525, 527, 1, 0, 0, 0, 526, 497, 1, 0, 0, 0, 526, 509, 1, 0, 0, 0, 526, 518, 1, 0, 0, 0, 527, 73, 1, 0, 0, 0, 528, 529, 5, 61, 0, 0, 529, 530, 3, 116, 58, 0, 530, 75, 1, 0, 0, 0, 531, 532, 5, 81, 0, 0, 532, 533, 3, 94, 47, 0, 533, 77, 1, 0, 0, 0, 534, 535, 6, 39, -1, 0, 535, 537, 3, 136, 68, 0, 536, 538, 5, 28, 0, 0, 537, 536, 1, 0, 0, 0, 537, 538, 1, 0, 0, 0, 538, 540, 1, 0, 0, 0, 539, 541, 3, 86, 43, 0, 540, 539, 1, 0, 0, 0, 540, 541, 1, 0, 0, 0, 541, 547, 1, 0, 0, 0, 542, 543, 5, 130, 0, 0, 543, 544, 3, 78, 39, 0, 544, 545, 5, 149, 0, 0, 545, 547, 1, 0, 0, 0, 546, 534, 1, 0, 0, 0, 546, 542, 1, 0, 0, 0, 547, 562, 1, 0, 0, 0, 548, 549, 10, 3, 0, 0, 549, 550, 3, 82, 41, 0, 550, 551, 3, 78, 39, 4, 551, 561, 1, 0, 0, 0, 552, 554, 10, 4, 0, 0, 553, 555, 3, 80, 40, 0, 554, 553, 1, 0, 0, 0, 554, 555, 1, 0, 0, 0, 555, 556, 1, 0, 0, 0, 556, 557, 5, 47, 0, 0, 557, 558, 3, 78, 39, 0, 558, 559, 3, 84, 42, 0, 559, 561, 1, 0, 0, 0, 560, 548, 1, 0, 0, 0, 560, 552, 1, 0, 0, 0, 561, 564, 1, 0, 0, 0, 562, 560, 1, 0, 0, 0, 562, 563, 1, 0, 0, 0, 563, 79, 1, 0, 0, 0, 564, 562, 1, 0, 0, 0, 565, 567, 7, 2, 0, 0, 566, 565, 1, 0, 0, 0, 566, 567, 1, 0, 0, 0, 567, 568, 1, 0, 0, 0, 568, 575, 5, 44, 0, 0, 569, 571, 5, 44, 0, 0, 570, 572, 7, 2, 0, 0, 571, 570, 1, 0, 0, 0, 571, 572, 1, 0, 0, 0, 572, 575, 1, 0, 0, 0, 573, 575, 7, 2, 0, 0, 574, 566, 1, 0, 0, 0, 574, 569, 1, 0, 0, 0, 574, 573, 1, 0, 0, 0, 575, 609, 1, 0, 0, 0, 576, 578, 7, 3, 0, 0, 577, 576, 1, 0, 0, 0, 577, 578, 1, 0, 0, 0, 578, 579, 1, 0, 0, 0, 579, 581, 7, 4, 0, 0, 580, 582, 5, 65, 0, 0, 581, 580, 1, 0, 0, 0, 581, 582, 1, 0, 0, 0, 582, 591, 1, 0, 0, 0, 583, 585, 7, 4, 0, 0, 584, 586, 5, 65, 0, 0, 585, 584, 1, 0, 0, 0, 585, 586, 1, 0, 0, 0, 586, 588, 1, 0, 0, 0, 587, 589, 7, 3, 0, 0, 588, 587, 1, 0, 0, 0, 588, 589, 1, 0, 0, 0, 589, 591, 1, 0, 0, 0, 590, 577, 1, 0, 0, 0, 590, 583, 1, 0, 0, 0, 591, 609, 1, 0, 0, 0, 592, 594, 7, 5, 0, 0, 593, 592, 1, 0, 0, 0, 593, 594, 1, 0, 0, 0, 594, 595, 1, 0, 0, 0, 595, 597, 5, 35, 0, 0, 596, 598, 5, 65, 0, 0, 597, 596, 1, 0, 0, 0, 597, 598, 1, 0, 0, 0, 598, 607, 1, 0, 0, 0, 599, 601, 5, 35, 0, 0, 600, 602, 5, 65, 0, 0, 601, 600, 1, 0, 0, 0, 601, 602, 1, 0, 0, 0, 602, 604, 1, 0, 0, 0, 603, 605, 7, 5, 0, 0, 604, 603, 1, 0, 0, 0, 604, 605, 1, 0, 0, 0, 605, 607, 1, 0, 0, 0, 606, 593, 1, 0, 0, 0, 606, 599, 1, 0, 0, 0, 607, 609, 1, 0, 0, 0, 608, 574, 1, 0, 0, 0, 608, 590, 1, 0, 0, 0, 608, 606, 1, 0, 0, 0, 609, 81, 1, 0, 0, 0, 610, 611, 5, 17, 0, 0, 611, 614, 5, 47, 0, 0, 612, 614, 5, 116, 0, 0, 613, 610, 1, 0, 0, 0, 613, 612, 1, 0, 0, 0, 614, 83, 1, 0, 0, 0, 615, 616, 5, 62, 0, 0, 616, 625, 3, 114, 57, 0, 617, 618, 5, 96, 0, 0, 618, 619, 5, 130, 0, 0, 619, 620, 3, 114, 57, 0, 620, 621, 5, 149, 0, 0, 621, 625, 1, 0, 0, 0, 622, 623, 5, 96, 0, 0, 623, 625, 3, 114, 57, 0, 624, 615, 1, 0, 0, 0, 624, 617, 1, 0, 0, 0, 624, 622, 1, 0, 0, 0, 625, 85, 1, 0, 0, 0, 626, 627, 5, 77, 0, 0, 627, 630, 3, 92, 46, 0, 628, 629, 5, 61, 0, 0, 629, 631, 3, 92, 46, 0, 630, 628, 1, 0, 0, 0, 630, 631, 1, 0, 0, 0, 631, 87, 1, 0, 0, 0, 632, 637, 3, 90, 45, 0, 633, 634, 5, 116, 0, 0, 634, 636, 3, 90, 45, 0, 635, 633, 1, 0, 0, 0, 636, 639, 1, 0, 0, 0, 637, 635, 1, 0, 0, 0, 637, 638, 1, 0, 0, 0, 638, 89, 1, 0, 0, 0, 639, 637, 1, 0, 0, 0, 640, 642, 3, 116, 58, 0, 641, 643, 7, 6, 0, 0, 642, 641, 1, 0, 0, 0, 642, 643, 1, 0, 0, 0, 643, 646, 1, 0, 0, 0, 644, 645, 5, 60, 0, 0, 645, 647, 7, 7, 0, 0, 646, 644, 1, 0, 0, 0, 646, 647, 1, 0, 0, 0, 647, 650, 1, 0, 0, 0, 648, 649, 5, 16, 0, 0, 649, 651, 5, 110, 0, 0, 650, 648, 1, 0, 0, 0, 650, 651, 1, 0, 0, 0, 651, 91, 1, 0, 0, 0, 652, 659, 3, 164, 82, 0, 653, 656, 3, 148, 74, 0, 654, 655, 5, 151, 0, 0, 655, 657, 3, 148, 74, 0, 656, 654, 1, 0, 0, 0, 656, 657, 1, 0, 0, 0, 657, 659, 1, 0, 0, 0, 658, 652, 1, 0, 0, 0, 658, 653, 1, 0, 0, 0, 659, 93, 1, 0, 0, 0, 660, 665, 3, 96, 48, 0, 661, 662, 5, 116, 0, 0, 662, 664, 3, 96, 48, 0, 663, 661, 1, 0, 0, 0, 664, 667, 1, 0, 0, 0, 665, 663, 1, 0, 0, 0, 665, 666, 1, 0, 0, 0, 666, 95, 1, 0, 0, 0, 667, 665, 1, 0, 0, 0, 668, 669, 3, 160, 80, 0, 669, 670, 5, 122, 0, 0, 670, 671, 3, 150, 75, 0, 671, 97, 1, 0, 0, 0, 672, 674, 3, 100, 50, 0, 673, 672, 1, 0, 0, 0, 673, 674, 1, 0, 0, 0, 674, 676, 1, 0, 0, 0, 675, 677, 3, 102, 51, 0, 676, 675, 1, 0, 0, 0, 676, 677, 1, 0, 0, 0, 677, 679, 1, 0, 0, 0, 678, 680, 3, 104, 52, 0, 679, 678, 1, 0, 0, 0, 679, 680, 1, 0, 0, 0, 680, 99, 1, 0, 0, 0, 681, 682, 5, 67, 0, 0, 682, 683, 5, 11, 0, 0, 683, 684, 3, 114, 57, 0, 684, 101, 1, 0, 0, 0, 685, 686, 5, 64, 0, 0, 686, 687, 5, 11, 0, 0, 687, 688, 3, 88, 44, 0, 688, 103, 1, 0, 0, 0, 689, 690, 7, 8, 0, 0, 690, 691, 3, 106, 53, 0, 691, 105, 1, 0, 0, 0, 692, 699, 3, 108, 54, 0, 693, 694, 5, 9, 0, 0, 694, 695, 3, 108, 54, 0, 695, 696, 5, 2, 0, 0, 696, 697, 3, 108, 54, 0, 697, 699, 1, 0, 0, 0, 698, 692, 1, 0, 0, 0, 698, 693, 1, 0, 0, 0, 699, 107, 1, 0, 0, 0, 700, 701, 5, 19, 0, 0, 701, 713, 5, 75, 0, 0, 702, 703, 5, 94, 0, 0, 703, 713, 5, 68, 0, 0, 704, 705, 5, 94, 0, 0, 705, 713, 5, 32, 0, 0, 706, 707, 3, 148, 74, 0, 707, 708, 5, 68, 0, 0, 708, 713, 1, 0, 0, 0, 709, 710, 3, 148, 74, 0, 710, 711, 5, 32, 0, 0, 711, 713, 1, 0, 0, 0, 712, 700, 1, 0, 0, 0, 712, 702, 1, 0, 0, 0, 712, 704, 1, 0, 0, 0, 712, 706, 1, 0, 0, 0, 712, 709, 1, 0, 0, 0, 713, 109, 1, 0, 0, 0, 714, 715, 3, 116, 58, 0, 715, 716, 5, 0, 0, 1, 716, 111, 1, 0, 0, 0, 717, 774, 3, 160, 80, 0, 718, 719, 3, 160, 80, 0, 719, 720, 5, 130, 0, 0, 720, 721, 3, 160, 80, 0, 721, 728, 3, 112, 56, 0, 722, 723, 5, 116, 0, 0, 723, 724, 3, 160, 80, 0, 724, 725, 3, 112, 56, 0, 725, 727, 1, 0, 0, 0, 726, 722, 1, 0, 0, 0, 727, 730, 1, 0, 0, 0, 728, 726, 1, 0, 0, 0, 728, 729, 1, 0, 0, 0, 729, 732, 1, 0, 0, 0, 730, 728, 1, 0, 0, 0, 731, 733, 5, 116, 0, 0, 732, 731, 1, 0, 0, 0, 732, 733, 1, 0, 0, 0, 733, 734, 1, 0, 0, 0, 734, 735, 5, 149, 0, 0, 735, 774, 1, 0, 0, 0, 736, 737, 3, 160, 80, 0, 737, 738, 5, 130, 0, 0, 738, 743, 3, 162, 81, 0, 739, 740, 5, 116, 0, 0, 740, 742, 3, 162, 81, 0, 741, 739, 1, 0, 0, 0, 742, 745, 1, 0, 0, 0, 743, 741, 1, 0, 0, 0, 743, 744, 1, 0, 0, 0, 744, 747, 1, 0, 0, 0, 745, 743, 1, 0, 0, 0, 746, 748, 5, 116, 0, 0, 747, 746, 1, 0, 0, 0, 747, 748, 1, 0, 0, 0, 748, 749, 1, 0, 0, 0, 749, 750, 5, 149, 0, 0, 750, 774, 1, 0, 0, 0, 751, 752, 3, 160, 80, 0, 752, 753, 5, 130, 0, 0, 753, 758, 3, 112, 56, 0, 754, 755, 5, 116, 0, 0, 755, 757, 3, 112, 56, 0, 756, 754, 1, 0, 0, 0, 757, 760, 1, 0, 0, 0, 758, 756, 1, 0, 0, 0, 758, 759, 1, 0, 0, 0, 759, 762, 1, 0, 0, 0, 760, 758, 1, 0, 0, 0, 761, 763, 5, 116, 0, 0, 762, 761, 1, 0, 0, 0, 762, 763, 1, 0, 0, 0, 763, 764, 1, 0, 0, 0, 764, 765, 5, 149, 0, 0, 765, 774, 1, 0, 0, 0, 766, 767, 3, 160, 80, 0, 767, 769, 5, 130, 0, 0, 768, 770, 3, 114, 57, 0, 769, 768, 1, 0, 0, 0, 769, 770, 1, 0, 0, 0, 770, 771, 1, 0, 0, 0, 771, 772, 5, 149, 0, 0, 772, 774, 1, 0, 0, 0, 773, 717, 1, 0, 0, 0, 773, 718, 1, 0, 0, 0, 773, 736, 1, 0, 0, 0, 773, 751, 1, 0, 0, 0, 773, 766, 1, 0, 0, 0, 774, 113, 1, 0, 0, 0, 775, 780, 3, 116, 58, 0, 776, 777, 5, 116, 0, 0, 777, 779, 3, 116, 58, 0, 778, 776, 1, 0, 0, 0, 779, 782, 1, 0, 0, 0, 780, 778, 1, 0, 0, 0, 780, 781, 1, 0, 0, 0, 781, 784, 1, 0, 0, 0, 782, 780, 1, 0, 0, 0, 783, 785, 5, 116, 0, 0, 784, 783, 1, 0, 0, 0, 784, 785, 1, 0, 0, 0, 785, 115, 1, 0, 0, 0, 786, 787, 6, 58, -1, 0, 787, 789, 5, 12, 0, 0, 788, 790, 3, 116, 58, 0, 789, 788, 1, 0, 0, 0, 789, 790, 1, 0, 0, 0, 790, 796, 1, 0, 0, 0, 791, 792, 5, 98, 0, 0, 792, 793, 3, 116, 58, 0, 793, 794, 5, 83, 0, 0, 794, 795, 3, 116, 58, 0, 795, 797, 1, 0, 0, 0, 796, 791, 1, 0, 0, 0, 797, 798, 1, 0, 0, 0, 798, 796, 1, 0, 0, 0, 798, 799, 1, 0, 0, 0, 799, 802, 1, 0, 0, 0, 800, 801, 5, 25, 0, 0, 801, 803, 3, 116, 58, 0, 802, 800, 1, 0, 0, 0, 802, 803, 1, 0, 0, 0, 803, 804, 1, 0, 0, 0, 804, 805, 5, 26, 0, 0, 805, 936, 1, 0, 0, 0, 806, 807, 5, 13, 0, 0, 807, 808, 5, 130, 0, 0, 808, 809, 3, 116, 58, 0, 809, 810, 5, 6, 0, 0, 810, 811, 3, 112, 56, 0, 811, 812, 5, 149, 0, 0, 812, 936, 1, 0, 0, 0, 813, 814, 5, 20, 0, 0, 814, 936, 5, 110, 0, 0, 815, 816, 5, 45, 0, 0, 816, 817, 3, 116, 58, 0, 817, 818, 3, 152, 76, 0, 818, 936, 1, 0, 0, 0, 819, 820, 5, 82, 0, 0, 820, 821, 5, 130, 0, 0, 821, 822, 3, 116, 58, 0, 822, 823, 5, 34, 0, 0, 823, 826, 3, 116, 58, 0, 824, 825, 5, 33, 0, 0, 825, 827, 3, 116, 58, 0, 826, 824, 1, 0, 0, 0, 826, 827, 1, 0, 0, 0, 827, 828, 1, 0, 0, 0, 828, 829, 5, 149, 0, 0, 829, 936, 1, 0, 0, 0, 830, 831, 5, 86, 0, 0, 831, 936, 5, 110, 0, 0, 832, 833, 5, 91, 0, 0, 833, 834, 5, 130, 0, 0, 834, 835, 7, 9, 0, 0, 835, 836, 3, 166, 83, 0, 836, 837, 5, 34, 0, 0, 837, 838, 3, 116, 58, 0, 838, 839, 5, 149, 0, 0, 839, 936, 1, 0, 0, 0, 840, 841, 3, 160, 80, 0, 841, 843, 5, 130, 0, 0, 842, 844, 3, 114, 57, 0, 843, 842, 1, 0, 0, 0, 843, 844, 1, 0, 0, 0, 844, 845, 1, 0, 0, 0, 845, 846, 5, 149, 0, 0, 846, 855, 1, 0, 0, 0, 847, 849, 5, 130, 0, 0, 848, 850, 5, 24, 0, 0, 849, 848, 1, 0, 0, 0, 849, 850, 1, 0, 0, 0, 850, 852, 1, 0, 0, 0, 851, 853, 3, 118, 59, 0, 852, 851, 1, 0, 0, 0, 852, 853, 1, 0, 0, 0, 853, 854, 1, 0, 0, 0, 854, 856, 5, 149, 0, 0, 855, 847, 1, 0, 0, 0, 855, 856, 1, 0, 0, 0, 856, 857, 1, 0, 0, 0, 857, 858, 5, 66, 0, 0, 858, 859, 5, 130, 0, 0, 859, 860, 3, 98, 49, 0, 860, 861, 5, 149, 0, 0, 861, 936, 1, 0, 0, 0, 862, 863, 3, 160, 80, 0, 863, 865, 5, 130, 0, 0, 864, 866, 3, 114, 57, 0, 865, 864, 1, 0, 0, 0, 865, 866, 1, 0, 0, 0, 866, 867, 1, 0, 0, 0, 867, 868, 5, 149, 0, 0, 868, 877, 1, 0, 0, 0, 869, 871, 5, 130, 0, 0, 870, 872, 5, 24, 0, 0, 871, 870, 1, 0, 0, 0, 871, 872, 1, 0, 0, 0, 872, 874, 1, 0, 0, 0, 873, 875, 3, 118, 59, 0, 874, 873, 1, 0, 0, 0, 874, 875, 1, 0, 0, 0, 875, 876, 1, 0, 0, 0, 876, 878, 5, 149, 0, 0, 877, 869, 1, 0, 0, 0, 877, 878, 1, 0, 0, 0, 878, 879, 1, 0, 0, 0, 879, 880, 5, 66, 0, 0, 880, 881, 3, 160, 80, 0, 881, 936, 1, 0, 0, 0, 882, 888, 3, 160, 80, 0, 883, 885, 5, 130, 0, 0, 884, 886, 3, 114, 57, 0, 885, 884, 1, 0, 0, 0, 885, 886, 1, 0, 0, 0, 886, 887, 1, 0, 0, 0, 887, 889, 5, 149, 0, 0, 888, 883, 1, 0, 0, 0, 888, 889, 1, 0, 0, 0, 889, 890, 1, 0, 0, 0, 890, 892, 5, 130, 0, 0, 891, 893, 5, 24, 0, 0, 892, 891, 1, 0, 0, 0, 892, 893, 1, 0, 0, 0, 893, 895, 1, 0, 0, 0, 894, 896, 3, 118, 59, 0, 895, 894, 1, 0, 0, 0, 895, 896, 1, 0, 0, 0, 896, 897, 1, 0, 0, 0, 897, 898, 5, 149, 0, 0, 898, 936, 1, 0, 0, 0, 899, 936, 3, 124, 62, 0, 900, 936, 3, 168, 84, 0, 901, 936, 3, 150, 75, 0, 902, 903, 5, 118, 0, 0, 903, 936, 3, 116, 58, 19, 904, 905, 5, 58, 0, 0, 905, 936, 3, 116, 58, 13, 906, 907, 3, 140, 70, 0, 907, 908, 5, 120, 0, 0, 908, 910, 1, 0, 0, 0, 909, 906, 1, 0, 0, 0, 909, 910, 1, 0, 0, 0, 910, 911, 1, 0, 0, 0, 911, 936, 5, 112, 0, 0, 912, 913, 5, 130, 0, 0, 913, 914, 3, 44, 22, 0, 914, 915, 5, 149, 0, 0, 915, 936, 1, 0, 0, 0, 916, 917, 5, 130, 0, 0, 917, 918, 3, 116, 58, 0, 918, 919, 5, 149, 0, 0, 919, 936, 1, 0, 0, 0, 920, 921, 5, 130, 0, 0, 921, 922, 3, 114, 57, 0, 922, 923, 5, 149, 0, 0, 923, 936, 1, 0, 0, 0, 924, 926, 5, 129, 0, 0, 925, 927, 3, 114, 57, 0, 926, 925, 1, 0, 0, 0, 926, 927, 1, 0, 0, 0, 927, 928, 1, 0, 0, 0, 928, 936, 5, 148, 0, 0, 929, 931, 5, 128, 0, 0, 930, 932, 3, 40, 20, 0, 931, 930, 1, 0, 0, 0, 931, 932, 1, 0, 0, 0, 932, 933, 1, 0, 0, 0, 933, 936, 5, 147, 0, 0, 934, 936, 3, 132, 66, 0, 935, 786, 1, 0, 0, 0, 935, 806, 1, 0, 0, 0, 935, 813, 1, 0, 0, 0, 935, 815, 1, 0, 0, 0, 935, 819, 1, 0, 0, 0, 935, 830, 1, 0, 0, 0, 935, 832, 1, 0, 0, 0, 935, 840, 1, 0, 0, 0, 935, 862, 1, 0, 0, 0, 935, 882, 1, 0, 0, 0, 935, 899, 1, 0, 0, 0, 935, 900, 1, 0, 0, 0, 935, 901, 1, 0, 0, 0, 935, 902, 1, 0, 0, 0, 935, 904, 1, 0, 0, 0, 935, 909, 1, 0, 0, 0, 935, 912, 1, 0, 0, 0, 935, 916, 1, 0, 0, 0, 935, 920, 1, 0, 0, 0, 935, 924, 1, 0, 0, 0, 935, 929, 1, 0, 0, 0, 935, 934, 1, 0, 0, 0, 936, 1041, 1, 0, 0, 0, 937, 941, 10, 18, 0, 0, 938, 942, 5, 112, 0, 0, 939, 942, 5, 151, 0, 0, 940, 942, 5, 138, 0, 0, 941, 938, 1, 0, 0, 0, 941, 939, 1, 0, 0, 0, 941, 940, 1, 0, 0, 0, 942, 943, 1, 0, 0, 0, 943, 1040, 3, 116, 58, 19, 944, 948, 10, 17, 0, 0, 945, 949, 5, 139, 0, 0, 946, 949, 5, 118, 0, 0, 947, 949, 5, 117, 0, 0, 948, 945, 1, 0, 0, 0, 948, 946, 1, 0, 0, 0, 948, 947, 1, 0, 0, 0, 949, 950, 1, 0, 0, 0, 950, 1040, 3, 116, 58, 18, 951, 976, 10, 16, 0, 0, 952, 977, 5, 121, 0, 0, 953, 977, 5, 122, 0, 0, 954, 977, 5, 133, 0, 0, 955, 977, 5, 131, 0, 0, 956, 977, 5, 132, 0, 0, 957, 977, 5, 123, 0, 0, 958, 977, 5, 124, 0, 0, 959, 961, 5, 58, 0, 0, 960, 959, 1, 0, 0, 0, 960, 961, 1, 0, 0, 0, 961, 962, 1, 0, 0, 0, 962, 964, 5, 42, 0, 0, 963, 965, 5, 15, 0, 0, 964, 963, 1, 0, 0, 0, 964, 965, 1, 0, 0, 0, 965, 977, 1, 0, 0, 0, 966, 968, 5, 58, 0, 0, 967, 966, 1, 0, 0, 0, 967, 968, 1, 0, 0, 0, 968, 969, 1, 0, 0, 0, 969, 977, 7, 10, 0, 0, 970, 977, 5, 145, 0, 0, 971, 977, 5, 146, 0, 0, 972, 977, 5, 135, 0, 0, 973, 977, 5, 126, 0, 0, 974, 977, 5, 127, 0, 0, 975, 977, 5, 134, 0, 0, 976, 952, 1, 0, 0, 0, 976, 953, 1, 0, 0, 0, 976, 954, 1, 0, 0, 0, 976, 955, 1, 0, 0, 0, 976, 956, 1, 0, 0, 0, 976, 957, 1, 0, 0, 0, 976, 958, 1, 0, 0, 0, 976, 960, 1, 0, 0, 0, 976, 967, 1, 0, 0, 0, 976, 970, 1, 0, 0, 0, 976, 971, 1, 0, 0, 0, 976, 972, 1, 0, 0, 0, 976, 973, 1, 0, 0, 0, 976, 974, 1, 0, 0, 0, 976, 975, 1, 0, 0, 0, 977, 978, 1, 0, 0, 0, 978, 1040, 3, 116, 58, 17, 979, 980, 10, 14, 0, 0, 980, 981, 5, 137, 0, 0, 981, 1040, 3, 116, 58, 15, 982, 983, 10, 12, 0, 0, 983, 984, 5, 2, 0, 0, 984, 1040, 3, 116, 58, 13, 985, 986, 10, 11, 0, 0, 986, 987, 5, 63, 0, 0, 987, 1040, 3, 116, 58, 12, 988, 990, 10, 10, 0, 0, 989, 991, 5, 58, 0, 0, 990, 989, 1, 0, 0, 0, 990, 991, 1, 0, 0, 0, 991, 992, 1, 0, 0, 0, 992, 993, 5, 9, 0, 0, 993, 994, 3, 116, 58, 0, 994, 995, 5, 2, 0, 0, 995, 996, 3, 116, 58, 11, 996, 1040, 1, 0, 0, 0, 997, 998, 10, 9, 0, 0, 998, 999, 5, 140, 0, 0, 999, 1000, 3, 116, 58, 0, 1000, 1001, 5, 115, 0, 0, 1001, 1002, 3, 116, 58, 9, 1002, 1040, 1, 0, 0, 0, 1003, 1004, 10, 25, 0, 0, 1004, 1005, 5, 129, 0, 0, 1005, 1006, 3, 116, 58, 0, 1006, 1007, 5, 148, 0, 0, 1007, 1040, 1, 0, 0, 0, 1008, 1009, 10, 24, 0, 0, 1009, 1010, 5, 120, 0, 0, 1010, 1040, 5, 108, 0, 0, 1011, 1012, 10, 23, 0, 0, 1012, 1013, 5, 120, 0, 0, 1013, 1040, 3, 160, 80, 0, 1014, 1015, 10, 22, 0, 0, 1015, 1016, 5, 136, 0, 0, 1016, 1017, 5, 129, 0, 0, 1017, 1018, 3, 116, 58, 0, 1018, 1019, 5, 148, 0, 0, 1019, 1040, 1, 0, 0, 0, 1020, 1021, 10, 21, 0, 0, 1021, 1022, 5, 136, 0, 0, 1022, 1040, 5, 108, 0, 0, 1023, 1024, 10, 20, 0, 0, 1024, 1025, 5, 136, 0, 0, 1025, 1040, 3, 160, 80, 0, 1026, 1027, 10, 15, 0, 0, 1027, 1029, 5, 46, 0, 0, 1028, 1030, 5, 58, 0, 0, 1029, 1028, 1, 0, 0, 0, 1029, 1030, 1, 0, 0, 0, 1030, 1031, 1, 0, 0, 0, 1031, 1040, 5, 59, 0, 0, 1032, 1037, 10, 8, 0, 0, 1033, 1034, 5, 6, 0, 0, 1034, 1038, 3, 160, 80, 0, 1035, 1036, 5, 6, 0, 0, 1036, 1038, 5, 110, 0, 0, 1037, 1033, 1, 0, 0, 0, 1037, 1035, 1, 0, 0, 0, 1038, 1040, 1, 0, 0, 0, 1039, 937, 1, 0, 0, 0, 1039, 944, 1, 0, 0, 0, 1039, 951, 1, 0, 0, 0, 1039, 979, 1, 0, 0, 0, 1039, 982, 1, 0, 0, 0, 1039, 985, 1, 0, 0, 0, 1039, 988, 1, 0, 0, 0, 1039, 997, 1, 0, 0, 0, 1039, 1003, 1, 0, 0, 0, 1039, 1008, 1, 0, 0, 0, 1039, 1011, 1, 0, 0, 0, 1039, 1014, 1, 0, 0, 0, 1039, 1020, 1, 0, 0, 0, 1039, 1023, 1, 0, 0, 0, 1039, 1026, 1, 0, 0, 0, 1039, 1032, 1, 0, 0, 0, 1040, 1043, 1, 0, 0, 0, 1041, 1039, 1, 0, 0, 0, 1041, 1042, 1, 0, 0, 0, 1042, 117, 1, 0, 0, 0, 1043, 1041, 1, 0, 0, 0, 1044, 1049, 3, 120, 60, 0, 1045, 1046, 5, 116, 0, 0, 1046, 1048, 3, 120, 60, 0, 1047, 1045, 1, 0, 0, 0, 1048, 1051, 1, 0, 0, 0, 1049, 1047, 1, 0, 0, 0, 1049, 1050, 1, 0, 0, 0, 1050, 1053, 1, 0, 0, 0, 1051, 1049, 1, 0, 0, 0, 1052, 1054, 5, 116, 0, 0, 1053, 1052, 1, 0, 0, 0, 1053, 1054, 1, 0, 0, 0, 1054, 119, 1, 0, 0, 0, 1055, 1058, 3, 122, 61, 0, 1056, 1058, 3, 116, 58, 0, 1057, 1055, 1, 0, 0, 0, 1057, 1056, 1, 0, 0, 0, 1058, 121, 1, 0, 0, 0, 1059, 1060, 5, 130, 0, 0, 1060, 1065, 3, 160, 80, 0, 1061, 1062, 5, 116, 0, 0, 1062, 1064, 3, 160, 80, 0, 1063, 1061, 1, 0, 0, 0, 1064, 1067, 1, 0, 0, 0, 1065, 1063, 1, 0, 0, 0, 1065, 1066, 1, 0, 0, 0, 1066, 1069, 1, 0, 0, 0, 1067, 1065, 1, 0, 0, 0, 1068, 1070, 5, 116, 0, 0, 1069, 1068, 1, 0, 0, 0, 1069, 1070, 1, 0, 0, 0, 1070, 1071, 1, 0, 0, 0, 1071, 1072, 5, 149, 0, 0, 1072, 1085, 1, 0, 0, 0, 1073, 1078, 3, 160, 80, 0, 1074, 1075, 5, 116, 0, 0, 1075, 1077, 3, 160, 80, 0, 1076, 1074, 1, 0, 0, 0, 1077, 1080, 1, 0, 0, 0, 1078, 1076, 1, 0, 0, 0, 1078, 1079, 1, 0, 0, 0, 1079, 1082, 1, 0, 0, 0, 1080, 1078, 1, 0, 0, 0, 1081, 1083, 5, 116, 0, 0, 1082, 1081, 1, 0, 0, 0, 1082, 1083, 1, 0, 0, 0, 1083, 1085, 1, 0, 0, 0, 1084, 1059, 1, 0, 0, 0, 1084, 1073, 1, 0, 0, 0, 1085, 1086, 1, 0, 0, 0, 1086, 1087, 5, 111, 0, 0, 1087, 1088, 3, 116, 58, 0, 1088, 123, 1, 0, 0, 0, 1089, 1090, 5, 132, 0, 0, 1090, 1094, 3, 160, 80, 0, 1091, 1093, 3, 126, 63, 0, 1092, 1091, 1, 0, 0, 0, 1093, 1096, 1, 0, 0, 0, 1094, 1092, 1, 0, 0, 0, 1094, 1095, 1, 0, 0, 0, 1095, 1097, 1, 0, 0, 0, 1096, 1094, 1, 0, 0, 0, 1097, 1098, 5, 151, 0, 0, 1098, 1099, 5, 124, 0, 0, 1099, 1122, 1, 0, 0, 0, 1100, 1101, 5, 132, 0, 0, 1101, 1105, 3, 160, 80, 0, 1102, 1104, 3, 126, 63, 0, 1103, 1102, 1, 0, 0, 0, 1104, 1107, 1, 0, 0, 0, 1105, 1103, 1, 0, 0, 0, 1105, 1106, 1, 0, 0, 0, 1106, 1108, 1, 0, 0, 0, 1107, 1105, 1, 0, 0, 0, 1108, 1114, 5, 124, 0, 0, 1109, 1115, 3, 124, 62, 0, 1110, 1111, 5, 128, 0, 0, 1111, 1112, 3, 116, 58, 0, 1112, 1113, 5, 147, 0, 0, 1113, 1115, 1, 0, 0, 0, 1114, 1109, 1, 0, 0, 0, 1114, 1110, 1, 0, 0, 0, 1114, 1115, 1, 0, 0, 0, 1115, 1116, 1, 0, 0, 0, 1116, 1117, 5, 132, 0, 0, 1117, 1118, 5, 151, 0, 0, 1118, 1119, 3, 160, 80, 0, 1119, 1120, 5, 124, 0, 0, 1120, 1122, 1, 0, 0, 0, 1121, 1089, 1, 0, 0, 0, 1121, 1100, 1, 0, 0, 0, 1122, 125, 1, 0, 0, 0, 1123, 1124, 3, 160, 80, 0, 1124, 1125, 5, 122, 0, 0, 1125, 1126, 3, 166, 83, 0, 1126, 1135, 1, 0, 0, 0, 1127, 1128, 3, 160, 80, 0, 1128, 1129, 5, 122, 0, 0, 1129, 1130, 5, 128, 0, 0, 1130, 1131, 3, 116, 58, 0, 1131, 1132, 5, 147, 0, 0, 1132, 1135, 1, 0, 0, 0, 1133, 1135, 3, 160, 80, 0, 1134, 1123, 1, 0, 0, 0, 1134, 1127, 1, 0, 0, 0, 1134, 1133, 1, 0, 0, 0, 1135, 127, 1, 0, 0, 0, 1136, 1141, 3, 130, 65, 0, 1137, 1138, 5, 116, 0, 0, 1138, 1140, 3, 130, 65, 0, 1139, 1137, 1, 0, 0, 0, 1140, 1143, 1, 0, 0, 0, 1141, 1139, 1, 0, 0, 0, 1141, 1142, 1, 0, 0, 0, 1142, 1145, 1, 0, 0, 0, 1143, 1141, 1, 0, 0, 0, 1144, 1146, 5, 116, 0, 0, 1145, 1144, 1, 0, 0, 0, 1145, 1146, 1, 0, 0, 0, 1146, 129, 1, 0, 0, 0, 1147, 1148, 3, 160, 80, 0, 1148, 1149, 5, 6, 0, 0, 1149, 1150, 5, 130, 0, 0, 1150, 1151, 3, 44, 22, 0, 1151, 1152, 5, 149, 0, 0, 1152, 1158, 1, 0, 0, 0, 1153, 1154, 3, 116, 58, 0, 1154, 1155, 5, 6, 0, 0, 1155, 1156, 3, 160, 80, 0, 1156, 1158, 1, 0, 0, 0, 1157, 1147, 1, 0, 0, 0, 1157, 1153, 1, 0, 0, 0, 1158, 131, 1, 0, 0, 0, 1159, 1167, 3, 164, 82, 0, 1160, 1161, 3, 140, 70, 0, 1161, 1162, 5, 120, 0, 0, 1162, 1164, 1, 0, 0, 0, 1163, 1160, 1, 0, 0, 0, 1163, 1164, 1, 0, 0, 0, 1164, 1165, 1, 0, 0, 0, 1165, 1167, 3, 134, 67, 0, 1166, 1159, 1, 0, 0, 0, 1166, 1163, 1, 0, 0, 0, 1167, 133, 1, 0, 0, 0, 1168, 1173, 3, 160, 80, 0, 1169, 1170, 5, 120, 0, 0, 1170, 1172, 3, 160, 80, 0, 1171, 1169, 1, 0, 0, 0, 1172, 1175, 1, 0, 0, 0, 1173, 1171, 1, 0, 0, 0, 1173, 1174, 1, 0, 0, 0, 1174, 135, 1, 0, 0, 0, 1175, 1173, 1, 0, 0, 0, 1176, 1177, 6, 68, -1, 0, 1177, 1186, 3, 140, 70, 0, 1178, 1186, 3, 138, 69, 0, 1179, 1180, 5, 130, 0, 0, 1180, 1181, 3, 44, 22, 0, 1181, 1182, 5, 149, 0, 0, 1182, 1186, 1, 0, 0, 0, 1183, 1186, 3, 124, 62, 0, 1184, 1186, 3, 164, 82, 0, 1185, 1176, 1, 0, 0, 0, 1185, 1178, 1, 0, 0, 0, 1185, 1179, 1, 0, 0, 0, 1185, 1183, 1, 0, 0, 0, 1185, 1184, 1, 0, 0, 0, 1186, 1195, 1, 0, 0, 0, 1187, 1191, 10, 3, 0, 0, 1188, 1192, 3, 158, 79, 0, 1189, 1190, 5, 6, 0, 0, 1190, 1192, 3, 160, 80, 0, 1191, 1188, 1, 0, 0, 0, 1191, 1189, 1, 0, 0, 0, 1192, 1194, 1, 0, 0, 0, 1193, 1187, 1, 0, 0, 0, 1194, 1197, 1, 0, 0, 0, 1195, 1193, 1, 0, 0, 0, 1195, 1196, 1, 0, 0, 0, 1196, 137, 1, 0, 0, 0, 1197, 1195, 1, 0, 0, 0, 1198, 1199, 3, 160, 80, 0, 1199, 1201, 5, 130, 0, 0, 1200, 1202, 3, 142, 71, 0, 1201, 1200, 1, 0, 0, 0, 1201, 1202, 1, 0, 0, 0, 1202, 1203, 1, 0, 0, 0, 1203, 1204, 5, 149, 0, 0, 1204, 139, 1, 0, 0, 0, 1205, 1206, 3, 144, 72, 0, 1206, 1207, 5, 120, 0, 0, 1207, 1209, 1, 0, 0, 0, 1208, 1205, 1, 0, 0, 0, 1208, 1209, 1, 0, 0, 0, 1209, 1210, 1, 0, 0, 0, 1210, 1211, 3, 160, 80, 0, 1211, 141, 1, 0, 0, 0, 1212, 1217, 3, 116, 58, 0, 1213, 1214, 5, 116, 0, 0, 1214, 1216, 3, 116, 58, 0, 1215, 1213, 1, 0, 0, 0, 1216, 1219, 1, 0, 0, 0, 1217, 1215, 1, 0, 0, 0, 1217, 1218, 1, 0, 0, 0, 1218, 1221, 1, 0, 0, 0, 1219, 1217, 1, 0, 0, 0, 1220, 1222, 5, 116, 0, 0, 1221, 1220, 1, 0, 0, 0, 1221, 1222, 1, 0, 0, 0, 1222, 143, 1, 0, 0, 0, 1223, 1224, 3, 160, 80, 0, 1224, 145, 1, 0, 0, 0, 1225, 1234, 5, 106, 0, 0, 1226, 1227, 5, 120, 0, 0, 1227, 1234, 7, 11, 0, 0, 1228, 1229, 5, 108, 0, 0, 1229, 1231, 5, 120, 0, 0, 1230, 1232, 7, 11, 0, 0, 1231, 1230, 1, 0, 0, 0, 1231, 1232, 1, 0, 0, 0, 1232, 1234, 1, 0, 0, 0, 1233, 1225, 1, 0, 0, 0, 1233, 1226, 1, 0, 0, 0, 1233, 1228, 1, 0, 0, 0, 1234, 147, 1, 0, 0, 0, 1235, 1237, 7, 12, 0, 0, 1236, 1235, 1, 0, 0, 0, 1236, 1237, 1, 0, 0, 0, 1237, 1244, 1, 0, 0, 0, 1238, 1245, 3, 146, 73, 0, 1239, 1245, 5, 107, 0, 0, 1240, 1245, 5, 108, 0, 0, 1241, 1245, 5, 109, 0, 0, 1242, 1245, 5, 43, 0, 0, 1243, 1245, 5, 57, 0, 0, 1244, 1238, 1, 0, 0, 0, 1244, 1239, 1, 0, 0, 0, 1244, 1240, 1, 0, 0, 0, 1244, 1241, 1, 0, 0, 0, 1244, 1242, 1, 0, 0, 0, 1244, 1243, 1, 0, 0, 0, 1245, 149, 1, 0, 0, 0, 1246, 1250, 3, 148, 74, 0, 1247, 1250, 5, 110, 0, 0, 1248, 1250, 5, 59, 0, 0, 1249, 1246, 1, 0, 0, 0, 1249, 1247, 1, 0, 0, 0, 1249, 1248, 1, 0, 0, 0, 1250, 151, 1, 0, 0, 0, 1251, 1252, 7, 13, 0, 0, 1252, 153, 1, 0, 0, 0, 1253, 1254, 7, 14, 0, 0, 1254, 155, 1, 0, 0, 0, 1255, 1256, 7, 15, 0, 0, 1256, 157, 1, 0, 0, 0, 1257, 1260, 5, 105, 0, 0, 1258, 1260, 3, 156, 78, 0, 1259, 1257, 1, 0, 0, 0, 1259, 1258, 1, 0, 0, 0, 1260, 159, 1, 0, 0, 0, 1261, 1265, 5, 105, 0, 0, 1262, 1265, 3, 152, 76, 0, 1263, 1265, 3, 154, 77, 0, 1264, 1261, 1, 0, 0, 0, 1264, 1262, 1, 0, 0, 0, 1264, 1263, 1, 0, 0, 0, 1265, 161, 1, 0, 0, 0, 1266, 1267, 3, 166, 83, 0, 1267, 1268, 5, 122, 0, 0, 1268, 1269, 3, 148, 74, 0, 1269, 163, 1, 0, 0, 0, 1270, 1271, 5, 128, 0, 0, 1271, 1272, 3, 134, 67, 0, 1272, 1273, 5, 147, 0, 0, 1273, 165, 1, 0, 0, 0, 1274, 1277, 5, 110, 0, 0, 1275, 1277, 3, 168, 84, 0, 1276, 1274, 1, 0, 0, 0, 1276, 1275, 1, 0, 0, 0, 1277, 167, 1, 0, 0, 0, 1278, 1282, 5, 142, 0, 0, 1279, 1281, 3, 170, 85, 0, 1280, 1279, 1, 0, 0, 0, 1281, 1284, 1, 0, 0, 0, 1282, 1280, 1, 0, 0, 0, 1282, 1283, 1, 0, 0, 0, 1283, 1285, 1, 0, 0, 0, 1284, 1282, 1, 0, 0, 0, 1285, 1286, 5, 144, 0, 0, 1286, 169, 1, 0, 0, 0, 1287, 1288, 5, 157, 0, 0, 1288, 1289, 3, 116, 58, 0, 1289, 1290, 5, 147, 0, 0, 1290, 1293, 1, 0, 0, 0, 1291, 1293, 5, 156, 0, 0, 1292, 1287, 1, 0, 0, 0, 1292, 1291, 1, 0, 0, 0, 1293, 171, 1, 0, 0, 0, 1294, 1298, 5, 143, 0, 0, 1295, 1297, 3, 174, 87, 0, 1296, 1295, 1, 0, 0, 0, 1297, 1300, 1, 0, 0, 0, 1298, 1296, 1, 0, 0, 0, 1298, 1299, 1, 0, 0, 0, 1299, 1301, 1, 0, 0, 0, 1300, 1298, 1, 0, 0, 0, 1301, 1302, 5, 0, 0, 1, 1302, 173, 1, 0, 0, 0, 1303, 1304, 5, 159, 0, 0, 1304, 1305, 3, 116, 58, 0, 1305, 1306, 5, 147, 0, 0, 1306, 1309, 1, 0, 0, 0, 1307, 1309, 5, 158, 0, 0, 1308, 1303, 1, 0, 0, 0, 1308, 1307, 1, 0, 0, 0, 1309, 175, 1, 0, 0, 0, 168, 179, 186, 195, 202, 206, 220, 224, 227, 231, 234, 241, 245, 254, 259, 268, 276, 283, 287, 293, 298, 306, 313, 319, 331, 339, 353, 357, 362, 372, 381, 384, 388, 391, 395, 398, 401, 404, 407, 411, 415, 418, 421, 424, 428, 431, 440, 446, 467, 484, 501, 507, 513, 524, 526, 537, 540, 546, 554, 560, 562, 566, 571, 574, 577, 581, 585, 588, 590, 593, 597, 601, 604, 606, 608, 613, 624, 630, 637, 642, 646, 650, 656, 658, 665, 673, 676, 679, 698, 712, 728, 732, 743, 747, 758, 762, 769, 773, 780, 784, 789, 798, 802, 826, 843, 849, 852, 855, 865, 871, 874, 877, 885, 888, 892, 895, 909, 926, 931, 935, 941, 948, 960, 964, 967, 976, 990, 1029, 1037, 1039, 1041, 1049, 1053, 1057, 1065, 1069, 1078, 1082, 1084, 1094, 1105, 1114, 1121, 1134, 1141, 1145, 1157, 1163, 1166, 1173, 1185, 1191, 1195, 1201, 1208, 1217, 1221, 1231, 1233, 1236, 1244, 1249, 1259, 1264, 1276, 1282, 1292, 1298, 1308] \ No newline at end of file +[4, 1, 159, 1303, 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, 1, 0, 5, 0, 174, 8, 0, 10, 0, 12, 0, 177, 9, 0, 1, 0, 1, 0, 1, 1, 1, 1, 3, 1, 183, 8, 1, 1, 2, 1, 2, 1, 3, 1, 3, 1, 3, 1, 3, 1, 3, 3, 3, 192, 8, 3, 1, 4, 1, 4, 1, 4, 5, 4, 197, 8, 4, 10, 4, 12, 4, 200, 9, 4, 1, 4, 3, 4, 203, 8, 4, 1, 5, 1, 5, 1, 5, 1, 5, 1, 5, 1, 5, 1, 5, 1, 5, 1, 5, 1, 5, 1, 5, 1, 5, 3, 5, 217, 8, 5, 1, 6, 1, 6, 3, 6, 221, 8, 6, 1, 6, 3, 6, 224, 8, 6, 1, 7, 1, 7, 3, 7, 228, 8, 7, 1, 7, 3, 7, 231, 8, 7, 1, 8, 1, 8, 1, 8, 1, 8, 1, 8, 3, 8, 238, 8, 8, 1, 8, 1, 8, 3, 8, 242, 8, 8, 1, 8, 1, 8, 1, 9, 1, 9, 1, 9, 5, 9, 249, 8, 9, 10, 9, 12, 9, 252, 9, 9, 1, 9, 1, 9, 3, 9, 256, 8, 9, 1, 10, 1, 10, 1, 10, 1, 10, 1, 10, 1, 10, 1, 10, 3, 10, 265, 8, 10, 1, 11, 1, 11, 1, 11, 1, 11, 1, 11, 1, 11, 3, 11, 273, 8, 11, 1, 12, 1, 12, 1, 12, 1, 12, 1, 12, 3, 12, 280, 8, 12, 1, 12, 1, 12, 3, 12, 284, 8, 12, 1, 12, 1, 12, 1, 12, 1, 12, 3, 12, 290, 8, 12, 1, 12, 1, 12, 1, 12, 3, 12, 295, 8, 12, 1, 13, 1, 13, 1, 13, 1, 13, 1, 13, 1, 13, 3, 13, 303, 8, 13, 1, 13, 1, 13, 1, 13, 1, 13, 1, 13, 3, 13, 310, 8, 13, 1, 14, 1, 14, 1, 14, 1, 14, 3, 14, 316, 8, 14, 1, 14, 1, 14, 1, 14, 1, 15, 1, 15, 1, 15, 1, 15, 1, 15, 1, 16, 1, 16, 3, 16, 328, 8, 16, 1, 17, 1, 17, 1, 18, 1, 18, 5, 18, 334, 8, 18, 10, 18, 12, 18, 337, 9, 18, 1, 18, 1, 18, 1, 19, 1, 19, 1, 19, 1, 19, 1, 20, 1, 20, 1, 20, 5, 20, 348, 8, 20, 10, 20, 12, 20, 351, 9, 20, 1, 20, 3, 20, 354, 8, 20, 1, 21, 1, 21, 1, 21, 3, 21, 359, 8, 21, 1, 21, 1, 21, 1, 22, 1, 22, 1, 22, 1, 22, 5, 22, 367, 8, 22, 10, 22, 12, 22, 370, 9, 22, 1, 23, 1, 23, 1, 23, 1, 23, 1, 23, 1, 23, 3, 23, 378, 8, 23, 1, 24, 3, 24, 381, 8, 24, 1, 24, 1, 24, 3, 24, 385, 8, 24, 1, 24, 3, 24, 388, 8, 24, 1, 24, 1, 24, 3, 24, 392, 8, 24, 1, 24, 3, 24, 395, 8, 24, 1, 24, 3, 24, 398, 8, 24, 1, 24, 3, 24, 401, 8, 24, 1, 24, 3, 24, 404, 8, 24, 1, 24, 1, 24, 3, 24, 408, 8, 24, 1, 24, 1, 24, 3, 24, 412, 8, 24, 1, 24, 3, 24, 415, 8, 24, 1, 24, 3, 24, 418, 8, 24, 1, 24, 3, 24, 421, 8, 24, 1, 24, 1, 24, 3, 24, 425, 8, 24, 1, 24, 3, 24, 428, 8, 24, 1, 25, 1, 25, 1, 25, 1, 26, 1, 26, 1, 26, 1, 26, 3, 26, 437, 8, 26, 1, 27, 1, 27, 1, 27, 1, 28, 3, 28, 443, 8, 28, 1, 28, 1, 28, 1, 28, 1, 28, 1, 29, 1, 29, 1, 29, 1, 29, 1, 29, 1, 29, 1, 29, 1, 29, 1, 29, 1, 29, 1, 29, 1, 29, 1, 29, 5, 29, 462, 8, 29, 10, 29, 12, 29, 465, 9, 29, 1, 30, 1, 30, 1, 30, 1, 31, 1, 31, 1, 31, 1, 32, 1, 32, 1, 32, 1, 32, 1, 32, 1, 32, 1, 32, 1, 32, 3, 32, 481, 8, 32, 1, 33, 1, 33, 1, 33, 1, 34, 1, 34, 1, 34, 1, 34, 1, 35, 1, 35, 1, 35, 1, 35, 1, 36, 1, 36, 1, 36, 1, 36, 3, 36, 498, 8, 36, 1, 36, 1, 36, 1, 36, 1, 36, 3, 36, 504, 8, 36, 1, 36, 1, 36, 1, 36, 1, 36, 3, 36, 510, 8, 36, 1, 36, 1, 36, 1, 36, 1, 36, 1, 36, 1, 36, 1, 36, 1, 36, 1, 36, 3, 36, 521, 8, 36, 3, 36, 523, 8, 36, 1, 37, 1, 37, 1, 37, 1, 38, 1, 38, 1, 38, 1, 39, 1, 39, 1, 39, 3, 39, 534, 8, 39, 1, 39, 3, 39, 537, 8, 39, 1, 39, 1, 39, 1, 39, 1, 39, 3, 39, 543, 8, 39, 1, 39, 1, 39, 1, 39, 1, 39, 1, 39, 1, 39, 3, 39, 551, 8, 39, 1, 39, 1, 39, 1, 39, 1, 39, 5, 39, 557, 8, 39, 10, 39, 12, 39, 560, 9, 39, 1, 40, 3, 40, 563, 8, 40, 1, 40, 1, 40, 1, 40, 3, 40, 568, 8, 40, 1, 40, 3, 40, 571, 8, 40, 1, 40, 3, 40, 574, 8, 40, 1, 40, 1, 40, 3, 40, 578, 8, 40, 1, 40, 1, 40, 3, 40, 582, 8, 40, 1, 40, 3, 40, 585, 8, 40, 3, 40, 587, 8, 40, 1, 40, 3, 40, 590, 8, 40, 1, 40, 1, 40, 3, 40, 594, 8, 40, 1, 40, 1, 40, 3, 40, 598, 8, 40, 1, 40, 3, 40, 601, 8, 40, 3, 40, 603, 8, 40, 3, 40, 605, 8, 40, 1, 41, 1, 41, 1, 41, 3, 41, 610, 8, 41, 1, 42, 1, 42, 1, 42, 1, 42, 1, 42, 1, 42, 1, 42, 1, 42, 1, 42, 3, 42, 621, 8, 42, 1, 43, 1, 43, 1, 43, 1, 43, 3, 43, 627, 8, 43, 1, 44, 1, 44, 1, 44, 5, 44, 632, 8, 44, 10, 44, 12, 44, 635, 9, 44, 1, 45, 1, 45, 3, 45, 639, 8, 45, 1, 45, 1, 45, 3, 45, 643, 8, 45, 1, 45, 1, 45, 3, 45, 647, 8, 45, 1, 46, 1, 46, 1, 46, 1, 46, 3, 46, 653, 8, 46, 3, 46, 655, 8, 46, 1, 47, 1, 47, 1, 47, 5, 47, 660, 8, 47, 10, 47, 12, 47, 663, 9, 47, 1, 48, 1, 48, 1, 48, 1, 48, 1, 49, 3, 49, 670, 8, 49, 1, 49, 3, 49, 673, 8, 49, 1, 49, 3, 49, 676, 8, 49, 1, 50, 1, 50, 1, 50, 1, 50, 1, 51, 1, 51, 1, 51, 1, 51, 1, 52, 1, 52, 1, 52, 1, 53, 1, 53, 1, 53, 1, 53, 1, 53, 1, 53, 3, 53, 695, 8, 53, 1, 54, 1, 54, 1, 54, 1, 54, 1, 54, 1, 54, 1, 54, 1, 54, 1, 54, 1, 54, 1, 54, 1, 54, 3, 54, 709, 8, 54, 1, 55, 1, 55, 1, 55, 1, 56, 1, 56, 1, 56, 1, 56, 1, 56, 1, 56, 1, 56, 1, 56, 1, 56, 5, 56, 723, 8, 56, 10, 56, 12, 56, 726, 9, 56, 1, 56, 3, 56, 729, 8, 56, 1, 56, 1, 56, 1, 56, 1, 56, 1, 56, 1, 56, 1, 56, 5, 56, 738, 8, 56, 10, 56, 12, 56, 741, 9, 56, 1, 56, 3, 56, 744, 8, 56, 1, 56, 1, 56, 1, 56, 1, 56, 1, 56, 1, 56, 1, 56, 5, 56, 753, 8, 56, 10, 56, 12, 56, 756, 9, 56, 1, 56, 3, 56, 759, 8, 56, 1, 56, 1, 56, 1, 56, 1, 56, 1, 56, 3, 56, 766, 8, 56, 1, 56, 1, 56, 3, 56, 770, 8, 56, 1, 57, 1, 57, 1, 57, 5, 57, 775, 8, 57, 10, 57, 12, 57, 778, 9, 57, 1, 57, 3, 57, 781, 8, 57, 1, 58, 1, 58, 1, 58, 3, 58, 786, 8, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 4, 58, 793, 8, 58, 11, 58, 12, 58, 794, 1, 58, 1, 58, 3, 58, 799, 8, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 3, 58, 823, 8, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 3, 58, 840, 8, 58, 1, 58, 1, 58, 1, 58, 1, 58, 3, 58, 846, 8, 58, 1, 58, 3, 58, 849, 8, 58, 1, 58, 3, 58, 852, 8, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 3, 58, 862, 8, 58, 1, 58, 1, 58, 1, 58, 1, 58, 3, 58, 868, 8, 58, 1, 58, 3, 58, 871, 8, 58, 1, 58, 3, 58, 874, 8, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 3, 58, 882, 8, 58, 1, 58, 3, 58, 885, 8, 58, 1, 58, 1, 58, 3, 58, 889, 8, 58, 1, 58, 3, 58, 892, 8, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 3, 58, 906, 8, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 3, 58, 923, 8, 58, 1, 58, 1, 58, 1, 58, 3, 58, 928, 8, 58, 1, 58, 1, 58, 1, 58, 3, 58, 933, 8, 58, 1, 58, 1, 58, 1, 58, 1, 58, 3, 58, 939, 8, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 3, 58, 946, 8, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 3, 58, 958, 8, 58, 1, 58, 1, 58, 3, 58, 962, 8, 58, 1, 58, 3, 58, 965, 8, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 3, 58, 974, 8, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 3, 58, 988, 8, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 3, 58, 1004, 8, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 3, 58, 1033, 8, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 3, 58, 1041, 8, 58, 5, 58, 1043, 8, 58, 10, 58, 12, 58, 1046, 9, 58, 1, 59, 1, 59, 1, 59, 1, 59, 5, 59, 1052, 8, 59, 10, 59, 12, 59, 1055, 9, 59, 1, 59, 3, 59, 1058, 8, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 5, 59, 1065, 8, 59, 10, 59, 12, 59, 1068, 9, 59, 1, 59, 3, 59, 1071, 8, 59, 1, 59, 1, 59, 3, 59, 1075, 8, 59, 1, 59, 1, 59, 1, 59, 3, 59, 1080, 8, 59, 1, 60, 1, 60, 1, 60, 5, 60, 1085, 8, 60, 10, 60, 12, 60, 1088, 9, 60, 1, 60, 1, 60, 1, 60, 1, 60, 1, 60, 1, 60, 5, 60, 1096, 8, 60, 10, 60, 12, 60, 1099, 9, 60, 1, 60, 1, 60, 1, 60, 1, 60, 1, 60, 1, 60, 3, 60, 1107, 8, 60, 1, 60, 1, 60, 1, 60, 1, 60, 1, 60, 3, 60, 1114, 8, 60, 1, 61, 1, 61, 1, 61, 1, 61, 1, 61, 1, 61, 1, 61, 1, 61, 1, 61, 1, 61, 1, 61, 3, 61, 1127, 8, 61, 1, 62, 1, 62, 1, 62, 5, 62, 1132, 8, 62, 10, 62, 12, 62, 1135, 9, 62, 1, 62, 3, 62, 1138, 8, 62, 1, 63, 1, 63, 1, 63, 1, 63, 1, 63, 1, 63, 1, 63, 1, 63, 1, 63, 1, 63, 3, 63, 1150, 8, 63, 1, 64, 1, 64, 1, 64, 1, 64, 3, 64, 1156, 8, 64, 1, 64, 3, 64, 1159, 8, 64, 1, 65, 1, 65, 1, 65, 5, 65, 1164, 8, 65, 10, 65, 12, 65, 1167, 9, 65, 1, 66, 1, 66, 1, 66, 1, 66, 1, 66, 1, 66, 1, 66, 1, 66, 1, 66, 3, 66, 1178, 8, 66, 1, 66, 1, 66, 1, 66, 1, 66, 3, 66, 1184, 8, 66, 5, 66, 1186, 8, 66, 10, 66, 12, 66, 1189, 9, 66, 1, 67, 1, 67, 1, 67, 3, 67, 1194, 8, 67, 1, 67, 1, 67, 1, 68, 1, 68, 1, 68, 3, 68, 1201, 8, 68, 1, 68, 1, 68, 1, 69, 1, 69, 1, 69, 5, 69, 1208, 8, 69, 10, 69, 12, 69, 1211, 9, 69, 1, 69, 3, 69, 1214, 8, 69, 1, 70, 1, 70, 1, 71, 1, 71, 1, 71, 1, 71, 1, 71, 1, 71, 3, 71, 1224, 8, 71, 3, 71, 1226, 8, 71, 1, 72, 3, 72, 1229, 8, 72, 1, 72, 1, 72, 1, 72, 1, 72, 1, 72, 1, 72, 3, 72, 1237, 8, 72, 1, 73, 1, 73, 1, 73, 3, 73, 1242, 8, 73, 1, 74, 1, 74, 1, 75, 1, 75, 1, 76, 1, 76, 1, 77, 1, 77, 3, 77, 1252, 8, 77, 1, 78, 1, 78, 1, 78, 3, 78, 1257, 8, 78, 1, 79, 1, 79, 1, 79, 1, 79, 1, 80, 1, 80, 1, 80, 1, 80, 1, 81, 1, 81, 3, 81, 1269, 8, 81, 1, 82, 1, 82, 5, 82, 1273, 8, 82, 10, 82, 12, 82, 1276, 9, 82, 1, 82, 1, 82, 1, 83, 1, 83, 1, 83, 1, 83, 1, 83, 3, 83, 1285, 8, 83, 1, 84, 1, 84, 5, 84, 1289, 8, 84, 10, 84, 12, 84, 1292, 9, 84, 1, 84, 1, 84, 1, 85, 1, 85, 1, 85, 1, 85, 1, 85, 3, 85, 1301, 8, 85, 1, 85, 0, 3, 78, 116, 132, 86, 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, 0, 16, 2, 0, 18, 18, 74, 74, 2, 0, 44, 44, 51, 51, 3, 0, 1, 1, 4, 4, 8, 8, 4, 0, 1, 1, 3, 4, 8, 8, 80, 80, 2, 0, 51, 51, 73, 73, 2, 0, 1, 1, 4, 4, 2, 0, 7, 7, 22, 23, 2, 0, 30, 30, 49, 49, 2, 0, 71, 71, 76, 76, 3, 0, 10, 10, 50, 50, 90, 90, 2, 0, 41, 41, 53, 53, 1, 0, 107, 108, 2, 0, 118, 118, 139, 139, 7, 0, 21, 21, 38, 38, 55, 56, 70, 70, 78, 78, 97, 97, 103, 103, 16, 0, 1, 13, 15, 20, 22, 28, 30, 30, 32, 37, 39, 42, 44, 51, 53, 54, 58, 58, 60, 69, 71, 77, 79, 83, 85, 92, 94, 96, 98, 99, 101, 102, 4, 0, 20, 20, 30, 30, 39, 39, 48, 48, 1475, 0, 175, 1, 0, 0, 0, 2, 182, 1, 0, 0, 0, 4, 184, 1, 0, 0, 0, 6, 186, 1, 0, 0, 0, 8, 193, 1, 0, 0, 0, 10, 216, 1, 0, 0, 0, 12, 218, 1, 0, 0, 0, 14, 225, 1, 0, 0, 0, 16, 232, 1, 0, 0, 0, 18, 245, 1, 0, 0, 0, 20, 257, 1, 0, 0, 0, 22, 266, 1, 0, 0, 0, 24, 274, 1, 0, 0, 0, 26, 296, 1, 0, 0, 0, 28, 311, 1, 0, 0, 0, 30, 320, 1, 0, 0, 0, 32, 325, 1, 0, 0, 0, 34, 329, 1, 0, 0, 0, 36, 331, 1, 0, 0, 0, 38, 340, 1, 0, 0, 0, 40, 344, 1, 0, 0, 0, 42, 358, 1, 0, 0, 0, 44, 362, 1, 0, 0, 0, 46, 377, 1, 0, 0, 0, 48, 380, 1, 0, 0, 0, 50, 429, 1, 0, 0, 0, 52, 432, 1, 0, 0, 0, 54, 438, 1, 0, 0, 0, 56, 442, 1, 0, 0, 0, 58, 448, 1, 0, 0, 0, 60, 466, 1, 0, 0, 0, 62, 469, 1, 0, 0, 0, 64, 472, 1, 0, 0, 0, 66, 482, 1, 0, 0, 0, 68, 485, 1, 0, 0, 0, 70, 489, 1, 0, 0, 0, 72, 522, 1, 0, 0, 0, 74, 524, 1, 0, 0, 0, 76, 527, 1, 0, 0, 0, 78, 542, 1, 0, 0, 0, 80, 604, 1, 0, 0, 0, 82, 609, 1, 0, 0, 0, 84, 620, 1, 0, 0, 0, 86, 622, 1, 0, 0, 0, 88, 628, 1, 0, 0, 0, 90, 636, 1, 0, 0, 0, 92, 654, 1, 0, 0, 0, 94, 656, 1, 0, 0, 0, 96, 664, 1, 0, 0, 0, 98, 669, 1, 0, 0, 0, 100, 677, 1, 0, 0, 0, 102, 681, 1, 0, 0, 0, 104, 685, 1, 0, 0, 0, 106, 694, 1, 0, 0, 0, 108, 708, 1, 0, 0, 0, 110, 710, 1, 0, 0, 0, 112, 769, 1, 0, 0, 0, 114, 771, 1, 0, 0, 0, 116, 932, 1, 0, 0, 0, 118, 1074, 1, 0, 0, 0, 120, 1113, 1, 0, 0, 0, 122, 1126, 1, 0, 0, 0, 124, 1128, 1, 0, 0, 0, 126, 1149, 1, 0, 0, 0, 128, 1158, 1, 0, 0, 0, 130, 1160, 1, 0, 0, 0, 132, 1177, 1, 0, 0, 0, 134, 1190, 1, 0, 0, 0, 136, 1200, 1, 0, 0, 0, 138, 1204, 1, 0, 0, 0, 140, 1215, 1, 0, 0, 0, 142, 1225, 1, 0, 0, 0, 144, 1228, 1, 0, 0, 0, 146, 1241, 1, 0, 0, 0, 148, 1243, 1, 0, 0, 0, 150, 1245, 1, 0, 0, 0, 152, 1247, 1, 0, 0, 0, 154, 1251, 1, 0, 0, 0, 156, 1256, 1, 0, 0, 0, 158, 1258, 1, 0, 0, 0, 160, 1262, 1, 0, 0, 0, 162, 1268, 1, 0, 0, 0, 164, 1270, 1, 0, 0, 0, 166, 1284, 1, 0, 0, 0, 168, 1286, 1, 0, 0, 0, 170, 1300, 1, 0, 0, 0, 172, 174, 3, 2, 1, 0, 173, 172, 1, 0, 0, 0, 174, 177, 1, 0, 0, 0, 175, 173, 1, 0, 0, 0, 175, 176, 1, 0, 0, 0, 176, 178, 1, 0, 0, 0, 177, 175, 1, 0, 0, 0, 178, 179, 5, 0, 0, 1, 179, 1, 1, 0, 0, 0, 180, 183, 3, 6, 3, 0, 181, 183, 3, 10, 5, 0, 182, 180, 1, 0, 0, 0, 182, 181, 1, 0, 0, 0, 183, 3, 1, 0, 0, 0, 184, 185, 3, 116, 58, 0, 185, 5, 1, 0, 0, 0, 186, 187, 5, 52, 0, 0, 187, 191, 3, 156, 78, 0, 188, 189, 5, 115, 0, 0, 189, 190, 5, 122, 0, 0, 190, 192, 3, 4, 2, 0, 191, 188, 1, 0, 0, 0, 191, 192, 1, 0, 0, 0, 192, 7, 1, 0, 0, 0, 193, 198, 3, 156, 78, 0, 194, 195, 5, 116, 0, 0, 195, 197, 3, 156, 78, 0, 196, 194, 1, 0, 0, 0, 197, 200, 1, 0, 0, 0, 198, 196, 1, 0, 0, 0, 198, 199, 1, 0, 0, 0, 199, 202, 1, 0, 0, 0, 200, 198, 1, 0, 0, 0, 201, 203, 5, 116, 0, 0, 202, 201, 1, 0, 0, 0, 202, 203, 1, 0, 0, 0, 203, 9, 1, 0, 0, 0, 204, 217, 3, 12, 6, 0, 205, 217, 3, 14, 7, 0, 206, 217, 3, 18, 9, 0, 207, 217, 3, 20, 10, 0, 208, 217, 3, 22, 11, 0, 209, 217, 3, 26, 13, 0, 210, 217, 3, 24, 12, 0, 211, 217, 3, 28, 14, 0, 212, 217, 3, 30, 15, 0, 213, 217, 3, 36, 18, 0, 214, 217, 3, 32, 16, 0, 215, 217, 3, 34, 17, 0, 216, 204, 1, 0, 0, 0, 216, 205, 1, 0, 0, 0, 216, 206, 1, 0, 0, 0, 216, 207, 1, 0, 0, 0, 216, 208, 1, 0, 0, 0, 216, 209, 1, 0, 0, 0, 216, 210, 1, 0, 0, 0, 216, 211, 1, 0, 0, 0, 216, 212, 1, 0, 0, 0, 216, 213, 1, 0, 0, 0, 216, 214, 1, 0, 0, 0, 216, 215, 1, 0, 0, 0, 217, 11, 1, 0, 0, 0, 218, 220, 5, 72, 0, 0, 219, 221, 3, 4, 2, 0, 220, 219, 1, 0, 0, 0, 220, 221, 1, 0, 0, 0, 221, 223, 1, 0, 0, 0, 222, 224, 5, 150, 0, 0, 223, 222, 1, 0, 0, 0, 223, 224, 1, 0, 0, 0, 224, 13, 1, 0, 0, 0, 225, 227, 5, 84, 0, 0, 226, 228, 3, 4, 2, 0, 227, 226, 1, 0, 0, 0, 227, 228, 1, 0, 0, 0, 228, 230, 1, 0, 0, 0, 229, 231, 5, 150, 0, 0, 230, 229, 1, 0, 0, 0, 230, 231, 1, 0, 0, 0, 231, 15, 1, 0, 0, 0, 232, 241, 5, 14, 0, 0, 233, 234, 5, 130, 0, 0, 234, 237, 3, 156, 78, 0, 235, 236, 5, 115, 0, 0, 236, 238, 3, 156, 78, 0, 237, 235, 1, 0, 0, 0, 237, 238, 1, 0, 0, 0, 238, 239, 1, 0, 0, 0, 239, 240, 5, 149, 0, 0, 240, 242, 1, 0, 0, 0, 241, 233, 1, 0, 0, 0, 241, 242, 1, 0, 0, 0, 242, 243, 1, 0, 0, 0, 243, 244, 3, 36, 18, 0, 244, 17, 1, 0, 0, 0, 245, 246, 5, 93, 0, 0, 246, 250, 3, 36, 18, 0, 247, 249, 3, 16, 8, 0, 248, 247, 1, 0, 0, 0, 249, 252, 1, 0, 0, 0, 250, 248, 1, 0, 0, 0, 250, 251, 1, 0, 0, 0, 251, 255, 1, 0, 0, 0, 252, 250, 1, 0, 0, 0, 253, 254, 5, 29, 0, 0, 254, 256, 3, 36, 18, 0, 255, 253, 1, 0, 0, 0, 255, 256, 1, 0, 0, 0, 256, 19, 1, 0, 0, 0, 257, 258, 5, 40, 0, 0, 258, 259, 5, 130, 0, 0, 259, 260, 3, 4, 2, 0, 260, 261, 5, 149, 0, 0, 261, 264, 3, 10, 5, 0, 262, 263, 5, 25, 0, 0, 263, 265, 3, 10, 5, 0, 264, 262, 1, 0, 0, 0, 264, 265, 1, 0, 0, 0, 265, 21, 1, 0, 0, 0, 266, 267, 5, 100, 0, 0, 267, 268, 5, 130, 0, 0, 268, 269, 3, 4, 2, 0, 269, 270, 5, 149, 0, 0, 270, 272, 3, 10, 5, 0, 271, 273, 5, 150, 0, 0, 272, 271, 1, 0, 0, 0, 272, 273, 1, 0, 0, 0, 273, 23, 1, 0, 0, 0, 274, 275, 5, 33, 0, 0, 275, 279, 5, 130, 0, 0, 276, 280, 3, 6, 3, 0, 277, 280, 3, 30, 15, 0, 278, 280, 3, 4, 2, 0, 279, 276, 1, 0, 0, 0, 279, 277, 1, 0, 0, 0, 279, 278, 1, 0, 0, 0, 279, 280, 1, 0, 0, 0, 280, 281, 1, 0, 0, 0, 281, 283, 5, 150, 0, 0, 282, 284, 3, 4, 2, 0, 283, 282, 1, 0, 0, 0, 283, 284, 1, 0, 0, 0, 284, 285, 1, 0, 0, 0, 285, 289, 5, 150, 0, 0, 286, 290, 3, 6, 3, 0, 287, 290, 3, 30, 15, 0, 288, 290, 3, 4, 2, 0, 289, 286, 1, 0, 0, 0, 289, 287, 1, 0, 0, 0, 289, 288, 1, 0, 0, 0, 289, 290, 1, 0, 0, 0, 290, 291, 1, 0, 0, 0, 291, 292, 5, 149, 0, 0, 292, 294, 3, 10, 5, 0, 293, 295, 5, 150, 0, 0, 294, 293, 1, 0, 0, 0, 294, 295, 1, 0, 0, 0, 295, 25, 1, 0, 0, 0, 296, 297, 5, 33, 0, 0, 297, 298, 5, 130, 0, 0, 298, 299, 5, 52, 0, 0, 299, 302, 3, 156, 78, 0, 300, 301, 5, 116, 0, 0, 301, 303, 3, 156, 78, 0, 302, 300, 1, 0, 0, 0, 302, 303, 1, 0, 0, 0, 303, 304, 1, 0, 0, 0, 304, 305, 5, 42, 0, 0, 305, 306, 3, 4, 2, 0, 306, 307, 5, 149, 0, 0, 307, 309, 3, 10, 5, 0, 308, 310, 5, 150, 0, 0, 309, 308, 1, 0, 0, 0, 309, 310, 1, 0, 0, 0, 310, 27, 1, 0, 0, 0, 311, 312, 5, 31, 0, 0, 312, 313, 3, 156, 78, 0, 313, 315, 5, 130, 0, 0, 314, 316, 3, 8, 4, 0, 315, 314, 1, 0, 0, 0, 315, 316, 1, 0, 0, 0, 316, 317, 1, 0, 0, 0, 317, 318, 5, 149, 0, 0, 318, 319, 3, 36, 18, 0, 319, 29, 1, 0, 0, 0, 320, 321, 3, 4, 2, 0, 321, 322, 5, 115, 0, 0, 322, 323, 5, 122, 0, 0, 323, 324, 3, 4, 2, 0, 324, 31, 1, 0, 0, 0, 325, 327, 3, 4, 2, 0, 326, 328, 5, 150, 0, 0, 327, 326, 1, 0, 0, 0, 327, 328, 1, 0, 0, 0, 328, 33, 1, 0, 0, 0, 329, 330, 5, 150, 0, 0, 330, 35, 1, 0, 0, 0, 331, 335, 5, 128, 0, 0, 332, 334, 3, 2, 1, 0, 333, 332, 1, 0, 0, 0, 334, 337, 1, 0, 0, 0, 335, 333, 1, 0, 0, 0, 335, 336, 1, 0, 0, 0, 336, 338, 1, 0, 0, 0, 337, 335, 1, 0, 0, 0, 338, 339, 5, 147, 0, 0, 339, 37, 1, 0, 0, 0, 340, 341, 3, 4, 2, 0, 341, 342, 5, 115, 0, 0, 342, 343, 3, 4, 2, 0, 343, 39, 1, 0, 0, 0, 344, 349, 3, 38, 19, 0, 345, 346, 5, 116, 0, 0, 346, 348, 3, 38, 19, 0, 347, 345, 1, 0, 0, 0, 348, 351, 1, 0, 0, 0, 349, 347, 1, 0, 0, 0, 349, 350, 1, 0, 0, 0, 350, 353, 1, 0, 0, 0, 351, 349, 1, 0, 0, 0, 352, 354, 5, 116, 0, 0, 353, 352, 1, 0, 0, 0, 353, 354, 1, 0, 0, 0, 354, 41, 1, 0, 0, 0, 355, 359, 3, 44, 22, 0, 356, 359, 3, 48, 24, 0, 357, 359, 3, 120, 60, 0, 358, 355, 1, 0, 0, 0, 358, 356, 1, 0, 0, 0, 358, 357, 1, 0, 0, 0, 359, 360, 1, 0, 0, 0, 360, 361, 5, 0, 0, 1, 361, 43, 1, 0, 0, 0, 362, 368, 3, 46, 23, 0, 363, 364, 5, 95, 0, 0, 364, 365, 5, 1, 0, 0, 365, 367, 3, 46, 23, 0, 366, 363, 1, 0, 0, 0, 367, 370, 1, 0, 0, 0, 368, 366, 1, 0, 0, 0, 368, 369, 1, 0, 0, 0, 369, 45, 1, 0, 0, 0, 370, 368, 1, 0, 0, 0, 371, 378, 3, 48, 24, 0, 372, 373, 5, 130, 0, 0, 373, 374, 3, 44, 22, 0, 374, 375, 5, 149, 0, 0, 375, 378, 1, 0, 0, 0, 376, 378, 3, 160, 80, 0, 377, 371, 1, 0, 0, 0, 377, 372, 1, 0, 0, 0, 377, 376, 1, 0, 0, 0, 378, 47, 1, 0, 0, 0, 379, 381, 3, 50, 25, 0, 380, 379, 1, 0, 0, 0, 380, 381, 1, 0, 0, 0, 381, 382, 1, 0, 0, 0, 382, 384, 5, 79, 0, 0, 383, 385, 5, 24, 0, 0, 384, 383, 1, 0, 0, 0, 384, 385, 1, 0, 0, 0, 385, 387, 1, 0, 0, 0, 386, 388, 3, 52, 26, 0, 387, 386, 1, 0, 0, 0, 387, 388, 1, 0, 0, 0, 388, 389, 1, 0, 0, 0, 389, 391, 3, 114, 57, 0, 390, 392, 3, 54, 27, 0, 391, 390, 1, 0, 0, 0, 391, 392, 1, 0, 0, 0, 392, 394, 1, 0, 0, 0, 393, 395, 3, 56, 28, 0, 394, 393, 1, 0, 0, 0, 394, 395, 1, 0, 0, 0, 395, 397, 1, 0, 0, 0, 396, 398, 3, 60, 30, 0, 397, 396, 1, 0, 0, 0, 397, 398, 1, 0, 0, 0, 398, 400, 1, 0, 0, 0, 399, 401, 3, 62, 31, 0, 400, 399, 1, 0, 0, 0, 400, 401, 1, 0, 0, 0, 401, 403, 1, 0, 0, 0, 402, 404, 3, 64, 32, 0, 403, 402, 1, 0, 0, 0, 403, 404, 1, 0, 0, 0, 404, 407, 1, 0, 0, 0, 405, 406, 5, 102, 0, 0, 406, 408, 7, 0, 0, 0, 407, 405, 1, 0, 0, 0, 407, 408, 1, 0, 0, 0, 408, 411, 1, 0, 0, 0, 409, 410, 5, 102, 0, 0, 410, 412, 5, 89, 0, 0, 411, 409, 1, 0, 0, 0, 411, 412, 1, 0, 0, 0, 412, 414, 1, 0, 0, 0, 413, 415, 3, 66, 33, 0, 414, 413, 1, 0, 0, 0, 414, 415, 1, 0, 0, 0, 415, 417, 1, 0, 0, 0, 416, 418, 3, 58, 29, 0, 417, 416, 1, 0, 0, 0, 417, 418, 1, 0, 0, 0, 418, 420, 1, 0, 0, 0, 419, 421, 3, 68, 34, 0, 420, 419, 1, 0, 0, 0, 420, 421, 1, 0, 0, 0, 421, 424, 1, 0, 0, 0, 422, 425, 3, 72, 36, 0, 423, 425, 3, 74, 37, 0, 424, 422, 1, 0, 0, 0, 424, 423, 1, 0, 0, 0, 424, 425, 1, 0, 0, 0, 425, 427, 1, 0, 0, 0, 426, 428, 3, 76, 38, 0, 427, 426, 1, 0, 0, 0, 427, 428, 1, 0, 0, 0, 428, 49, 1, 0, 0, 0, 429, 430, 5, 102, 0, 0, 430, 431, 3, 124, 62, 0, 431, 51, 1, 0, 0, 0, 432, 433, 5, 88, 0, 0, 433, 436, 5, 108, 0, 0, 434, 435, 5, 102, 0, 0, 435, 437, 5, 85, 0, 0, 436, 434, 1, 0, 0, 0, 436, 437, 1, 0, 0, 0, 437, 53, 1, 0, 0, 0, 438, 439, 5, 34, 0, 0, 439, 440, 3, 78, 39, 0, 440, 55, 1, 0, 0, 0, 441, 443, 7, 1, 0, 0, 442, 441, 1, 0, 0, 0, 442, 443, 1, 0, 0, 0, 443, 444, 1, 0, 0, 0, 444, 445, 5, 5, 0, 0, 445, 446, 5, 47, 0, 0, 446, 447, 3, 114, 57, 0, 447, 57, 1, 0, 0, 0, 448, 449, 5, 101, 0, 0, 449, 450, 3, 156, 78, 0, 450, 451, 5, 6, 0, 0, 451, 452, 5, 130, 0, 0, 452, 453, 3, 98, 49, 0, 453, 463, 5, 149, 0, 0, 454, 455, 5, 116, 0, 0, 455, 456, 3, 156, 78, 0, 456, 457, 5, 6, 0, 0, 457, 458, 5, 130, 0, 0, 458, 459, 3, 98, 49, 0, 459, 460, 5, 149, 0, 0, 460, 462, 1, 0, 0, 0, 461, 454, 1, 0, 0, 0, 462, 465, 1, 0, 0, 0, 463, 461, 1, 0, 0, 0, 463, 464, 1, 0, 0, 0, 464, 59, 1, 0, 0, 0, 465, 463, 1, 0, 0, 0, 466, 467, 5, 69, 0, 0, 467, 468, 3, 116, 58, 0, 468, 61, 1, 0, 0, 0, 469, 470, 5, 99, 0, 0, 470, 471, 3, 116, 58, 0, 471, 63, 1, 0, 0, 0, 472, 473, 5, 36, 0, 0, 473, 480, 5, 11, 0, 0, 474, 475, 7, 0, 0, 0, 475, 476, 5, 130, 0, 0, 476, 477, 3, 114, 57, 0, 477, 478, 5, 149, 0, 0, 478, 481, 1, 0, 0, 0, 479, 481, 3, 114, 57, 0, 480, 474, 1, 0, 0, 0, 480, 479, 1, 0, 0, 0, 481, 65, 1, 0, 0, 0, 482, 483, 5, 37, 0, 0, 483, 484, 3, 116, 58, 0, 484, 67, 1, 0, 0, 0, 485, 486, 5, 64, 0, 0, 486, 487, 5, 11, 0, 0, 487, 488, 3, 88, 44, 0, 488, 69, 1, 0, 0, 0, 489, 490, 5, 64, 0, 0, 490, 491, 5, 11, 0, 0, 491, 492, 3, 114, 57, 0, 492, 71, 1, 0, 0, 0, 493, 494, 5, 54, 0, 0, 494, 497, 3, 116, 58, 0, 495, 496, 5, 116, 0, 0, 496, 498, 3, 116, 58, 0, 497, 495, 1, 0, 0, 0, 497, 498, 1, 0, 0, 0, 498, 503, 1, 0, 0, 0, 499, 500, 5, 102, 0, 0, 500, 504, 5, 85, 0, 0, 501, 502, 5, 11, 0, 0, 502, 504, 3, 114, 57, 0, 503, 499, 1, 0, 0, 0, 503, 501, 1, 0, 0, 0, 503, 504, 1, 0, 0, 0, 504, 523, 1, 0, 0, 0, 505, 506, 5, 54, 0, 0, 506, 509, 3, 116, 58, 0, 507, 508, 5, 102, 0, 0, 508, 510, 5, 85, 0, 0, 509, 507, 1, 0, 0, 0, 509, 510, 1, 0, 0, 0, 510, 511, 1, 0, 0, 0, 511, 512, 5, 61, 0, 0, 512, 513, 3, 116, 58, 0, 513, 523, 1, 0, 0, 0, 514, 515, 5, 54, 0, 0, 515, 516, 3, 116, 58, 0, 516, 517, 5, 61, 0, 0, 517, 520, 3, 116, 58, 0, 518, 519, 5, 11, 0, 0, 519, 521, 3, 114, 57, 0, 520, 518, 1, 0, 0, 0, 520, 521, 1, 0, 0, 0, 521, 523, 1, 0, 0, 0, 522, 493, 1, 0, 0, 0, 522, 505, 1, 0, 0, 0, 522, 514, 1, 0, 0, 0, 523, 73, 1, 0, 0, 0, 524, 525, 5, 61, 0, 0, 525, 526, 3, 116, 58, 0, 526, 75, 1, 0, 0, 0, 527, 528, 5, 81, 0, 0, 528, 529, 3, 94, 47, 0, 529, 77, 1, 0, 0, 0, 530, 531, 6, 39, -1, 0, 531, 533, 3, 132, 66, 0, 532, 534, 5, 28, 0, 0, 533, 532, 1, 0, 0, 0, 533, 534, 1, 0, 0, 0, 534, 536, 1, 0, 0, 0, 535, 537, 3, 86, 43, 0, 536, 535, 1, 0, 0, 0, 536, 537, 1, 0, 0, 0, 537, 543, 1, 0, 0, 0, 538, 539, 5, 130, 0, 0, 539, 540, 3, 78, 39, 0, 540, 541, 5, 149, 0, 0, 541, 543, 1, 0, 0, 0, 542, 530, 1, 0, 0, 0, 542, 538, 1, 0, 0, 0, 543, 558, 1, 0, 0, 0, 544, 545, 10, 3, 0, 0, 545, 546, 3, 82, 41, 0, 546, 547, 3, 78, 39, 4, 547, 557, 1, 0, 0, 0, 548, 550, 10, 4, 0, 0, 549, 551, 3, 80, 40, 0, 550, 549, 1, 0, 0, 0, 550, 551, 1, 0, 0, 0, 551, 552, 1, 0, 0, 0, 552, 553, 5, 47, 0, 0, 553, 554, 3, 78, 39, 0, 554, 555, 3, 84, 42, 0, 555, 557, 1, 0, 0, 0, 556, 544, 1, 0, 0, 0, 556, 548, 1, 0, 0, 0, 557, 560, 1, 0, 0, 0, 558, 556, 1, 0, 0, 0, 558, 559, 1, 0, 0, 0, 559, 79, 1, 0, 0, 0, 560, 558, 1, 0, 0, 0, 561, 563, 7, 2, 0, 0, 562, 561, 1, 0, 0, 0, 562, 563, 1, 0, 0, 0, 563, 564, 1, 0, 0, 0, 564, 571, 5, 44, 0, 0, 565, 567, 5, 44, 0, 0, 566, 568, 7, 2, 0, 0, 567, 566, 1, 0, 0, 0, 567, 568, 1, 0, 0, 0, 568, 571, 1, 0, 0, 0, 569, 571, 7, 2, 0, 0, 570, 562, 1, 0, 0, 0, 570, 565, 1, 0, 0, 0, 570, 569, 1, 0, 0, 0, 571, 605, 1, 0, 0, 0, 572, 574, 7, 3, 0, 0, 573, 572, 1, 0, 0, 0, 573, 574, 1, 0, 0, 0, 574, 575, 1, 0, 0, 0, 575, 577, 7, 4, 0, 0, 576, 578, 5, 65, 0, 0, 577, 576, 1, 0, 0, 0, 577, 578, 1, 0, 0, 0, 578, 587, 1, 0, 0, 0, 579, 581, 7, 4, 0, 0, 580, 582, 5, 65, 0, 0, 581, 580, 1, 0, 0, 0, 581, 582, 1, 0, 0, 0, 582, 584, 1, 0, 0, 0, 583, 585, 7, 3, 0, 0, 584, 583, 1, 0, 0, 0, 584, 585, 1, 0, 0, 0, 585, 587, 1, 0, 0, 0, 586, 573, 1, 0, 0, 0, 586, 579, 1, 0, 0, 0, 587, 605, 1, 0, 0, 0, 588, 590, 7, 5, 0, 0, 589, 588, 1, 0, 0, 0, 589, 590, 1, 0, 0, 0, 590, 591, 1, 0, 0, 0, 591, 593, 5, 35, 0, 0, 592, 594, 5, 65, 0, 0, 593, 592, 1, 0, 0, 0, 593, 594, 1, 0, 0, 0, 594, 603, 1, 0, 0, 0, 595, 597, 5, 35, 0, 0, 596, 598, 5, 65, 0, 0, 597, 596, 1, 0, 0, 0, 597, 598, 1, 0, 0, 0, 598, 600, 1, 0, 0, 0, 599, 601, 7, 5, 0, 0, 600, 599, 1, 0, 0, 0, 600, 601, 1, 0, 0, 0, 601, 603, 1, 0, 0, 0, 602, 589, 1, 0, 0, 0, 602, 595, 1, 0, 0, 0, 603, 605, 1, 0, 0, 0, 604, 570, 1, 0, 0, 0, 604, 586, 1, 0, 0, 0, 604, 602, 1, 0, 0, 0, 605, 81, 1, 0, 0, 0, 606, 607, 5, 17, 0, 0, 607, 610, 5, 47, 0, 0, 608, 610, 5, 116, 0, 0, 609, 606, 1, 0, 0, 0, 609, 608, 1, 0, 0, 0, 610, 83, 1, 0, 0, 0, 611, 612, 5, 62, 0, 0, 612, 621, 3, 114, 57, 0, 613, 614, 5, 96, 0, 0, 614, 615, 5, 130, 0, 0, 615, 616, 3, 114, 57, 0, 616, 617, 5, 149, 0, 0, 617, 621, 1, 0, 0, 0, 618, 619, 5, 96, 0, 0, 619, 621, 3, 114, 57, 0, 620, 611, 1, 0, 0, 0, 620, 613, 1, 0, 0, 0, 620, 618, 1, 0, 0, 0, 621, 85, 1, 0, 0, 0, 622, 623, 5, 77, 0, 0, 623, 626, 3, 92, 46, 0, 624, 625, 5, 61, 0, 0, 625, 627, 3, 92, 46, 0, 626, 624, 1, 0, 0, 0, 626, 627, 1, 0, 0, 0, 627, 87, 1, 0, 0, 0, 628, 633, 3, 90, 45, 0, 629, 630, 5, 116, 0, 0, 630, 632, 3, 90, 45, 0, 631, 629, 1, 0, 0, 0, 632, 635, 1, 0, 0, 0, 633, 631, 1, 0, 0, 0, 633, 634, 1, 0, 0, 0, 634, 89, 1, 0, 0, 0, 635, 633, 1, 0, 0, 0, 636, 638, 3, 116, 58, 0, 637, 639, 7, 6, 0, 0, 638, 637, 1, 0, 0, 0, 638, 639, 1, 0, 0, 0, 639, 642, 1, 0, 0, 0, 640, 641, 5, 60, 0, 0, 641, 643, 7, 7, 0, 0, 642, 640, 1, 0, 0, 0, 642, 643, 1, 0, 0, 0, 643, 646, 1, 0, 0, 0, 644, 645, 5, 16, 0, 0, 645, 647, 5, 110, 0, 0, 646, 644, 1, 0, 0, 0, 646, 647, 1, 0, 0, 0, 647, 91, 1, 0, 0, 0, 648, 655, 3, 160, 80, 0, 649, 652, 3, 144, 72, 0, 650, 651, 5, 151, 0, 0, 651, 653, 3, 144, 72, 0, 652, 650, 1, 0, 0, 0, 652, 653, 1, 0, 0, 0, 653, 655, 1, 0, 0, 0, 654, 648, 1, 0, 0, 0, 654, 649, 1, 0, 0, 0, 655, 93, 1, 0, 0, 0, 656, 661, 3, 96, 48, 0, 657, 658, 5, 116, 0, 0, 658, 660, 3, 96, 48, 0, 659, 657, 1, 0, 0, 0, 660, 663, 1, 0, 0, 0, 661, 659, 1, 0, 0, 0, 661, 662, 1, 0, 0, 0, 662, 95, 1, 0, 0, 0, 663, 661, 1, 0, 0, 0, 664, 665, 3, 156, 78, 0, 665, 666, 5, 122, 0, 0, 666, 667, 3, 146, 73, 0, 667, 97, 1, 0, 0, 0, 668, 670, 3, 100, 50, 0, 669, 668, 1, 0, 0, 0, 669, 670, 1, 0, 0, 0, 670, 672, 1, 0, 0, 0, 671, 673, 3, 102, 51, 0, 672, 671, 1, 0, 0, 0, 672, 673, 1, 0, 0, 0, 673, 675, 1, 0, 0, 0, 674, 676, 3, 104, 52, 0, 675, 674, 1, 0, 0, 0, 675, 676, 1, 0, 0, 0, 676, 99, 1, 0, 0, 0, 677, 678, 5, 67, 0, 0, 678, 679, 5, 11, 0, 0, 679, 680, 3, 114, 57, 0, 680, 101, 1, 0, 0, 0, 681, 682, 5, 64, 0, 0, 682, 683, 5, 11, 0, 0, 683, 684, 3, 88, 44, 0, 684, 103, 1, 0, 0, 0, 685, 686, 7, 8, 0, 0, 686, 687, 3, 106, 53, 0, 687, 105, 1, 0, 0, 0, 688, 695, 3, 108, 54, 0, 689, 690, 5, 9, 0, 0, 690, 691, 3, 108, 54, 0, 691, 692, 5, 2, 0, 0, 692, 693, 3, 108, 54, 0, 693, 695, 1, 0, 0, 0, 694, 688, 1, 0, 0, 0, 694, 689, 1, 0, 0, 0, 695, 107, 1, 0, 0, 0, 696, 697, 5, 19, 0, 0, 697, 709, 5, 75, 0, 0, 698, 699, 5, 94, 0, 0, 699, 709, 5, 68, 0, 0, 700, 701, 5, 94, 0, 0, 701, 709, 5, 32, 0, 0, 702, 703, 3, 144, 72, 0, 703, 704, 5, 68, 0, 0, 704, 709, 1, 0, 0, 0, 705, 706, 3, 144, 72, 0, 706, 707, 5, 32, 0, 0, 707, 709, 1, 0, 0, 0, 708, 696, 1, 0, 0, 0, 708, 698, 1, 0, 0, 0, 708, 700, 1, 0, 0, 0, 708, 702, 1, 0, 0, 0, 708, 705, 1, 0, 0, 0, 709, 109, 1, 0, 0, 0, 710, 711, 3, 116, 58, 0, 711, 712, 5, 0, 0, 1, 712, 111, 1, 0, 0, 0, 713, 770, 3, 156, 78, 0, 714, 715, 3, 156, 78, 0, 715, 716, 5, 130, 0, 0, 716, 717, 3, 156, 78, 0, 717, 724, 3, 112, 56, 0, 718, 719, 5, 116, 0, 0, 719, 720, 3, 156, 78, 0, 720, 721, 3, 112, 56, 0, 721, 723, 1, 0, 0, 0, 722, 718, 1, 0, 0, 0, 723, 726, 1, 0, 0, 0, 724, 722, 1, 0, 0, 0, 724, 725, 1, 0, 0, 0, 725, 728, 1, 0, 0, 0, 726, 724, 1, 0, 0, 0, 727, 729, 5, 116, 0, 0, 728, 727, 1, 0, 0, 0, 728, 729, 1, 0, 0, 0, 729, 730, 1, 0, 0, 0, 730, 731, 5, 149, 0, 0, 731, 770, 1, 0, 0, 0, 732, 733, 3, 156, 78, 0, 733, 734, 5, 130, 0, 0, 734, 739, 3, 158, 79, 0, 735, 736, 5, 116, 0, 0, 736, 738, 3, 158, 79, 0, 737, 735, 1, 0, 0, 0, 738, 741, 1, 0, 0, 0, 739, 737, 1, 0, 0, 0, 739, 740, 1, 0, 0, 0, 740, 743, 1, 0, 0, 0, 741, 739, 1, 0, 0, 0, 742, 744, 5, 116, 0, 0, 743, 742, 1, 0, 0, 0, 743, 744, 1, 0, 0, 0, 744, 745, 1, 0, 0, 0, 745, 746, 5, 149, 0, 0, 746, 770, 1, 0, 0, 0, 747, 748, 3, 156, 78, 0, 748, 749, 5, 130, 0, 0, 749, 754, 3, 112, 56, 0, 750, 751, 5, 116, 0, 0, 751, 753, 3, 112, 56, 0, 752, 750, 1, 0, 0, 0, 753, 756, 1, 0, 0, 0, 754, 752, 1, 0, 0, 0, 754, 755, 1, 0, 0, 0, 755, 758, 1, 0, 0, 0, 756, 754, 1, 0, 0, 0, 757, 759, 5, 116, 0, 0, 758, 757, 1, 0, 0, 0, 758, 759, 1, 0, 0, 0, 759, 760, 1, 0, 0, 0, 760, 761, 5, 149, 0, 0, 761, 770, 1, 0, 0, 0, 762, 763, 3, 156, 78, 0, 763, 765, 5, 130, 0, 0, 764, 766, 3, 114, 57, 0, 765, 764, 1, 0, 0, 0, 765, 766, 1, 0, 0, 0, 766, 767, 1, 0, 0, 0, 767, 768, 5, 149, 0, 0, 768, 770, 1, 0, 0, 0, 769, 713, 1, 0, 0, 0, 769, 714, 1, 0, 0, 0, 769, 732, 1, 0, 0, 0, 769, 747, 1, 0, 0, 0, 769, 762, 1, 0, 0, 0, 770, 113, 1, 0, 0, 0, 771, 776, 3, 116, 58, 0, 772, 773, 5, 116, 0, 0, 773, 775, 3, 116, 58, 0, 774, 772, 1, 0, 0, 0, 775, 778, 1, 0, 0, 0, 776, 774, 1, 0, 0, 0, 776, 777, 1, 0, 0, 0, 777, 780, 1, 0, 0, 0, 778, 776, 1, 0, 0, 0, 779, 781, 5, 116, 0, 0, 780, 779, 1, 0, 0, 0, 780, 781, 1, 0, 0, 0, 781, 115, 1, 0, 0, 0, 782, 783, 6, 58, -1, 0, 783, 785, 5, 12, 0, 0, 784, 786, 3, 116, 58, 0, 785, 784, 1, 0, 0, 0, 785, 786, 1, 0, 0, 0, 786, 792, 1, 0, 0, 0, 787, 788, 5, 98, 0, 0, 788, 789, 3, 116, 58, 0, 789, 790, 5, 83, 0, 0, 790, 791, 3, 116, 58, 0, 791, 793, 1, 0, 0, 0, 792, 787, 1, 0, 0, 0, 793, 794, 1, 0, 0, 0, 794, 792, 1, 0, 0, 0, 794, 795, 1, 0, 0, 0, 795, 798, 1, 0, 0, 0, 796, 797, 5, 25, 0, 0, 797, 799, 3, 116, 58, 0, 798, 796, 1, 0, 0, 0, 798, 799, 1, 0, 0, 0, 799, 800, 1, 0, 0, 0, 800, 801, 5, 26, 0, 0, 801, 933, 1, 0, 0, 0, 802, 803, 5, 13, 0, 0, 803, 804, 5, 130, 0, 0, 804, 805, 3, 116, 58, 0, 805, 806, 5, 6, 0, 0, 806, 807, 3, 112, 56, 0, 807, 808, 5, 149, 0, 0, 808, 933, 1, 0, 0, 0, 809, 810, 5, 20, 0, 0, 810, 933, 5, 110, 0, 0, 811, 812, 5, 45, 0, 0, 812, 813, 3, 116, 58, 0, 813, 814, 3, 148, 74, 0, 814, 933, 1, 0, 0, 0, 815, 816, 5, 82, 0, 0, 816, 817, 5, 130, 0, 0, 817, 818, 3, 116, 58, 0, 818, 819, 5, 34, 0, 0, 819, 822, 3, 116, 58, 0, 820, 821, 5, 33, 0, 0, 821, 823, 3, 116, 58, 0, 822, 820, 1, 0, 0, 0, 822, 823, 1, 0, 0, 0, 823, 824, 1, 0, 0, 0, 824, 825, 5, 149, 0, 0, 825, 933, 1, 0, 0, 0, 826, 827, 5, 86, 0, 0, 827, 933, 5, 110, 0, 0, 828, 829, 5, 91, 0, 0, 829, 830, 5, 130, 0, 0, 830, 831, 7, 9, 0, 0, 831, 832, 3, 162, 81, 0, 832, 833, 5, 34, 0, 0, 833, 834, 3, 116, 58, 0, 834, 835, 5, 149, 0, 0, 835, 933, 1, 0, 0, 0, 836, 837, 3, 156, 78, 0, 837, 839, 5, 130, 0, 0, 838, 840, 3, 114, 57, 0, 839, 838, 1, 0, 0, 0, 839, 840, 1, 0, 0, 0, 840, 841, 1, 0, 0, 0, 841, 842, 5, 149, 0, 0, 842, 851, 1, 0, 0, 0, 843, 845, 5, 130, 0, 0, 844, 846, 5, 24, 0, 0, 845, 844, 1, 0, 0, 0, 845, 846, 1, 0, 0, 0, 846, 848, 1, 0, 0, 0, 847, 849, 3, 114, 57, 0, 848, 847, 1, 0, 0, 0, 848, 849, 1, 0, 0, 0, 849, 850, 1, 0, 0, 0, 850, 852, 5, 149, 0, 0, 851, 843, 1, 0, 0, 0, 851, 852, 1, 0, 0, 0, 852, 853, 1, 0, 0, 0, 853, 854, 5, 66, 0, 0, 854, 855, 5, 130, 0, 0, 855, 856, 3, 98, 49, 0, 856, 857, 5, 149, 0, 0, 857, 933, 1, 0, 0, 0, 858, 859, 3, 156, 78, 0, 859, 861, 5, 130, 0, 0, 860, 862, 3, 114, 57, 0, 861, 860, 1, 0, 0, 0, 861, 862, 1, 0, 0, 0, 862, 863, 1, 0, 0, 0, 863, 864, 5, 149, 0, 0, 864, 873, 1, 0, 0, 0, 865, 867, 5, 130, 0, 0, 866, 868, 5, 24, 0, 0, 867, 866, 1, 0, 0, 0, 867, 868, 1, 0, 0, 0, 868, 870, 1, 0, 0, 0, 869, 871, 3, 114, 57, 0, 870, 869, 1, 0, 0, 0, 870, 871, 1, 0, 0, 0, 871, 872, 1, 0, 0, 0, 872, 874, 5, 149, 0, 0, 873, 865, 1, 0, 0, 0, 873, 874, 1, 0, 0, 0, 874, 875, 1, 0, 0, 0, 875, 876, 5, 66, 0, 0, 876, 877, 3, 156, 78, 0, 877, 933, 1, 0, 0, 0, 878, 884, 3, 156, 78, 0, 879, 881, 5, 130, 0, 0, 880, 882, 3, 114, 57, 0, 881, 880, 1, 0, 0, 0, 881, 882, 1, 0, 0, 0, 882, 883, 1, 0, 0, 0, 883, 885, 5, 149, 0, 0, 884, 879, 1, 0, 0, 0, 884, 885, 1, 0, 0, 0, 885, 886, 1, 0, 0, 0, 886, 888, 5, 130, 0, 0, 887, 889, 5, 24, 0, 0, 888, 887, 1, 0, 0, 0, 888, 889, 1, 0, 0, 0, 889, 891, 1, 0, 0, 0, 890, 892, 3, 114, 57, 0, 891, 890, 1, 0, 0, 0, 891, 892, 1, 0, 0, 0, 892, 893, 1, 0, 0, 0, 893, 894, 5, 149, 0, 0, 894, 933, 1, 0, 0, 0, 895, 933, 3, 120, 60, 0, 896, 933, 3, 164, 82, 0, 897, 933, 3, 146, 73, 0, 898, 899, 5, 118, 0, 0, 899, 933, 3, 116, 58, 20, 900, 901, 5, 58, 0, 0, 901, 933, 3, 116, 58, 14, 902, 903, 3, 136, 68, 0, 903, 904, 5, 120, 0, 0, 904, 906, 1, 0, 0, 0, 905, 902, 1, 0, 0, 0, 905, 906, 1, 0, 0, 0, 906, 907, 1, 0, 0, 0, 907, 933, 5, 112, 0, 0, 908, 909, 5, 130, 0, 0, 909, 910, 3, 44, 22, 0, 910, 911, 5, 149, 0, 0, 911, 933, 1, 0, 0, 0, 912, 913, 5, 130, 0, 0, 913, 914, 3, 116, 58, 0, 914, 915, 5, 149, 0, 0, 915, 933, 1, 0, 0, 0, 916, 917, 5, 130, 0, 0, 917, 918, 3, 114, 57, 0, 918, 919, 5, 149, 0, 0, 919, 933, 1, 0, 0, 0, 920, 922, 5, 129, 0, 0, 921, 923, 3, 114, 57, 0, 922, 921, 1, 0, 0, 0, 922, 923, 1, 0, 0, 0, 923, 924, 1, 0, 0, 0, 924, 933, 5, 148, 0, 0, 925, 927, 5, 128, 0, 0, 926, 928, 3, 40, 20, 0, 927, 926, 1, 0, 0, 0, 927, 928, 1, 0, 0, 0, 928, 929, 1, 0, 0, 0, 929, 933, 5, 147, 0, 0, 930, 933, 3, 118, 59, 0, 931, 933, 3, 128, 64, 0, 932, 782, 1, 0, 0, 0, 932, 802, 1, 0, 0, 0, 932, 809, 1, 0, 0, 0, 932, 811, 1, 0, 0, 0, 932, 815, 1, 0, 0, 0, 932, 826, 1, 0, 0, 0, 932, 828, 1, 0, 0, 0, 932, 836, 1, 0, 0, 0, 932, 858, 1, 0, 0, 0, 932, 878, 1, 0, 0, 0, 932, 895, 1, 0, 0, 0, 932, 896, 1, 0, 0, 0, 932, 897, 1, 0, 0, 0, 932, 898, 1, 0, 0, 0, 932, 900, 1, 0, 0, 0, 932, 905, 1, 0, 0, 0, 932, 908, 1, 0, 0, 0, 932, 912, 1, 0, 0, 0, 932, 916, 1, 0, 0, 0, 932, 920, 1, 0, 0, 0, 932, 925, 1, 0, 0, 0, 932, 930, 1, 0, 0, 0, 932, 931, 1, 0, 0, 0, 933, 1044, 1, 0, 0, 0, 934, 938, 10, 19, 0, 0, 935, 939, 5, 112, 0, 0, 936, 939, 5, 151, 0, 0, 937, 939, 5, 138, 0, 0, 938, 935, 1, 0, 0, 0, 938, 936, 1, 0, 0, 0, 938, 937, 1, 0, 0, 0, 939, 940, 1, 0, 0, 0, 940, 1043, 3, 116, 58, 20, 941, 945, 10, 18, 0, 0, 942, 946, 5, 139, 0, 0, 943, 946, 5, 118, 0, 0, 944, 946, 5, 117, 0, 0, 945, 942, 1, 0, 0, 0, 945, 943, 1, 0, 0, 0, 945, 944, 1, 0, 0, 0, 946, 947, 1, 0, 0, 0, 947, 1043, 3, 116, 58, 19, 948, 973, 10, 17, 0, 0, 949, 974, 5, 121, 0, 0, 950, 974, 5, 122, 0, 0, 951, 974, 5, 133, 0, 0, 952, 974, 5, 131, 0, 0, 953, 974, 5, 132, 0, 0, 954, 974, 5, 123, 0, 0, 955, 974, 5, 124, 0, 0, 956, 958, 5, 58, 0, 0, 957, 956, 1, 0, 0, 0, 957, 958, 1, 0, 0, 0, 958, 959, 1, 0, 0, 0, 959, 961, 5, 42, 0, 0, 960, 962, 5, 15, 0, 0, 961, 960, 1, 0, 0, 0, 961, 962, 1, 0, 0, 0, 962, 974, 1, 0, 0, 0, 963, 965, 5, 58, 0, 0, 964, 963, 1, 0, 0, 0, 964, 965, 1, 0, 0, 0, 965, 966, 1, 0, 0, 0, 966, 974, 7, 10, 0, 0, 967, 974, 5, 145, 0, 0, 968, 974, 5, 146, 0, 0, 969, 974, 5, 135, 0, 0, 970, 974, 5, 126, 0, 0, 971, 974, 5, 127, 0, 0, 972, 974, 5, 134, 0, 0, 973, 949, 1, 0, 0, 0, 973, 950, 1, 0, 0, 0, 973, 951, 1, 0, 0, 0, 973, 952, 1, 0, 0, 0, 973, 953, 1, 0, 0, 0, 973, 954, 1, 0, 0, 0, 973, 955, 1, 0, 0, 0, 973, 957, 1, 0, 0, 0, 973, 964, 1, 0, 0, 0, 973, 967, 1, 0, 0, 0, 973, 968, 1, 0, 0, 0, 973, 969, 1, 0, 0, 0, 973, 970, 1, 0, 0, 0, 973, 971, 1, 0, 0, 0, 973, 972, 1, 0, 0, 0, 974, 975, 1, 0, 0, 0, 975, 1043, 3, 116, 58, 18, 976, 977, 10, 15, 0, 0, 977, 978, 5, 137, 0, 0, 978, 1043, 3, 116, 58, 16, 979, 980, 10, 13, 0, 0, 980, 981, 5, 2, 0, 0, 981, 1043, 3, 116, 58, 14, 982, 983, 10, 12, 0, 0, 983, 984, 5, 63, 0, 0, 984, 1043, 3, 116, 58, 13, 985, 987, 10, 11, 0, 0, 986, 988, 5, 58, 0, 0, 987, 986, 1, 0, 0, 0, 987, 988, 1, 0, 0, 0, 988, 989, 1, 0, 0, 0, 989, 990, 5, 9, 0, 0, 990, 991, 3, 116, 58, 0, 991, 992, 5, 2, 0, 0, 992, 993, 3, 116, 58, 12, 993, 1043, 1, 0, 0, 0, 994, 995, 10, 10, 0, 0, 995, 996, 5, 140, 0, 0, 996, 997, 3, 116, 58, 0, 997, 998, 5, 115, 0, 0, 998, 999, 3, 116, 58, 10, 999, 1043, 1, 0, 0, 0, 1000, 1001, 10, 30, 0, 0, 1001, 1003, 5, 130, 0, 0, 1002, 1004, 3, 114, 57, 0, 1003, 1002, 1, 0, 0, 0, 1003, 1004, 1, 0, 0, 0, 1004, 1005, 1, 0, 0, 0, 1005, 1043, 5, 149, 0, 0, 1006, 1007, 10, 26, 0, 0, 1007, 1008, 5, 129, 0, 0, 1008, 1009, 3, 116, 58, 0, 1009, 1010, 5, 148, 0, 0, 1010, 1043, 1, 0, 0, 0, 1011, 1012, 10, 25, 0, 0, 1012, 1013, 5, 120, 0, 0, 1013, 1043, 5, 108, 0, 0, 1014, 1015, 10, 24, 0, 0, 1015, 1016, 5, 120, 0, 0, 1016, 1043, 3, 156, 78, 0, 1017, 1018, 10, 23, 0, 0, 1018, 1019, 5, 136, 0, 0, 1019, 1020, 5, 129, 0, 0, 1020, 1021, 3, 116, 58, 0, 1021, 1022, 5, 148, 0, 0, 1022, 1043, 1, 0, 0, 0, 1023, 1024, 10, 22, 0, 0, 1024, 1025, 5, 136, 0, 0, 1025, 1043, 5, 108, 0, 0, 1026, 1027, 10, 21, 0, 0, 1027, 1028, 5, 136, 0, 0, 1028, 1043, 3, 156, 78, 0, 1029, 1030, 10, 16, 0, 0, 1030, 1032, 5, 46, 0, 0, 1031, 1033, 5, 58, 0, 0, 1032, 1031, 1, 0, 0, 0, 1032, 1033, 1, 0, 0, 0, 1033, 1034, 1, 0, 0, 0, 1034, 1043, 5, 59, 0, 0, 1035, 1040, 10, 9, 0, 0, 1036, 1037, 5, 6, 0, 0, 1037, 1041, 3, 156, 78, 0, 1038, 1039, 5, 6, 0, 0, 1039, 1041, 5, 110, 0, 0, 1040, 1036, 1, 0, 0, 0, 1040, 1038, 1, 0, 0, 0, 1041, 1043, 1, 0, 0, 0, 1042, 934, 1, 0, 0, 0, 1042, 941, 1, 0, 0, 0, 1042, 948, 1, 0, 0, 0, 1042, 976, 1, 0, 0, 0, 1042, 979, 1, 0, 0, 0, 1042, 982, 1, 0, 0, 0, 1042, 985, 1, 0, 0, 0, 1042, 994, 1, 0, 0, 0, 1042, 1000, 1, 0, 0, 0, 1042, 1006, 1, 0, 0, 0, 1042, 1011, 1, 0, 0, 0, 1042, 1014, 1, 0, 0, 0, 1042, 1017, 1, 0, 0, 0, 1042, 1023, 1, 0, 0, 0, 1042, 1026, 1, 0, 0, 0, 1042, 1029, 1, 0, 0, 0, 1042, 1035, 1, 0, 0, 0, 1043, 1046, 1, 0, 0, 0, 1044, 1042, 1, 0, 0, 0, 1044, 1045, 1, 0, 0, 0, 1045, 117, 1, 0, 0, 0, 1046, 1044, 1, 0, 0, 0, 1047, 1048, 5, 130, 0, 0, 1048, 1053, 3, 156, 78, 0, 1049, 1050, 5, 116, 0, 0, 1050, 1052, 3, 156, 78, 0, 1051, 1049, 1, 0, 0, 0, 1052, 1055, 1, 0, 0, 0, 1053, 1051, 1, 0, 0, 0, 1053, 1054, 1, 0, 0, 0, 1054, 1057, 1, 0, 0, 0, 1055, 1053, 1, 0, 0, 0, 1056, 1058, 5, 116, 0, 0, 1057, 1056, 1, 0, 0, 0, 1057, 1058, 1, 0, 0, 0, 1058, 1059, 1, 0, 0, 0, 1059, 1060, 5, 149, 0, 0, 1060, 1075, 1, 0, 0, 0, 1061, 1066, 3, 156, 78, 0, 1062, 1063, 5, 116, 0, 0, 1063, 1065, 3, 156, 78, 0, 1064, 1062, 1, 0, 0, 0, 1065, 1068, 1, 0, 0, 0, 1066, 1064, 1, 0, 0, 0, 1066, 1067, 1, 0, 0, 0, 1067, 1070, 1, 0, 0, 0, 1068, 1066, 1, 0, 0, 0, 1069, 1071, 5, 116, 0, 0, 1070, 1069, 1, 0, 0, 0, 1070, 1071, 1, 0, 0, 0, 1071, 1075, 1, 0, 0, 0, 1072, 1073, 5, 130, 0, 0, 1073, 1075, 5, 149, 0, 0, 1074, 1047, 1, 0, 0, 0, 1074, 1061, 1, 0, 0, 0, 1074, 1072, 1, 0, 0, 0, 1075, 1076, 1, 0, 0, 0, 1076, 1079, 5, 111, 0, 0, 1077, 1080, 3, 116, 58, 0, 1078, 1080, 3, 36, 18, 0, 1079, 1077, 1, 0, 0, 0, 1079, 1078, 1, 0, 0, 0, 1080, 119, 1, 0, 0, 0, 1081, 1082, 5, 132, 0, 0, 1082, 1086, 3, 156, 78, 0, 1083, 1085, 3, 122, 61, 0, 1084, 1083, 1, 0, 0, 0, 1085, 1088, 1, 0, 0, 0, 1086, 1084, 1, 0, 0, 0, 1086, 1087, 1, 0, 0, 0, 1087, 1089, 1, 0, 0, 0, 1088, 1086, 1, 0, 0, 0, 1089, 1090, 5, 151, 0, 0, 1090, 1091, 5, 124, 0, 0, 1091, 1114, 1, 0, 0, 0, 1092, 1093, 5, 132, 0, 0, 1093, 1097, 3, 156, 78, 0, 1094, 1096, 3, 122, 61, 0, 1095, 1094, 1, 0, 0, 0, 1096, 1099, 1, 0, 0, 0, 1097, 1095, 1, 0, 0, 0, 1097, 1098, 1, 0, 0, 0, 1098, 1100, 1, 0, 0, 0, 1099, 1097, 1, 0, 0, 0, 1100, 1106, 5, 124, 0, 0, 1101, 1107, 3, 120, 60, 0, 1102, 1103, 5, 128, 0, 0, 1103, 1104, 3, 116, 58, 0, 1104, 1105, 5, 147, 0, 0, 1105, 1107, 1, 0, 0, 0, 1106, 1101, 1, 0, 0, 0, 1106, 1102, 1, 0, 0, 0, 1106, 1107, 1, 0, 0, 0, 1107, 1108, 1, 0, 0, 0, 1108, 1109, 5, 132, 0, 0, 1109, 1110, 5, 151, 0, 0, 1110, 1111, 3, 156, 78, 0, 1111, 1112, 5, 124, 0, 0, 1112, 1114, 1, 0, 0, 0, 1113, 1081, 1, 0, 0, 0, 1113, 1092, 1, 0, 0, 0, 1114, 121, 1, 0, 0, 0, 1115, 1116, 3, 156, 78, 0, 1116, 1117, 5, 122, 0, 0, 1117, 1118, 3, 162, 81, 0, 1118, 1127, 1, 0, 0, 0, 1119, 1120, 3, 156, 78, 0, 1120, 1121, 5, 122, 0, 0, 1121, 1122, 5, 128, 0, 0, 1122, 1123, 3, 116, 58, 0, 1123, 1124, 5, 147, 0, 0, 1124, 1127, 1, 0, 0, 0, 1125, 1127, 3, 156, 78, 0, 1126, 1115, 1, 0, 0, 0, 1126, 1119, 1, 0, 0, 0, 1126, 1125, 1, 0, 0, 0, 1127, 123, 1, 0, 0, 0, 1128, 1133, 3, 126, 63, 0, 1129, 1130, 5, 116, 0, 0, 1130, 1132, 3, 126, 63, 0, 1131, 1129, 1, 0, 0, 0, 1132, 1135, 1, 0, 0, 0, 1133, 1131, 1, 0, 0, 0, 1133, 1134, 1, 0, 0, 0, 1134, 1137, 1, 0, 0, 0, 1135, 1133, 1, 0, 0, 0, 1136, 1138, 5, 116, 0, 0, 1137, 1136, 1, 0, 0, 0, 1137, 1138, 1, 0, 0, 0, 1138, 125, 1, 0, 0, 0, 1139, 1140, 3, 156, 78, 0, 1140, 1141, 5, 6, 0, 0, 1141, 1142, 5, 130, 0, 0, 1142, 1143, 3, 44, 22, 0, 1143, 1144, 5, 149, 0, 0, 1144, 1150, 1, 0, 0, 0, 1145, 1146, 3, 116, 58, 0, 1146, 1147, 5, 6, 0, 0, 1147, 1148, 3, 156, 78, 0, 1148, 1150, 1, 0, 0, 0, 1149, 1139, 1, 0, 0, 0, 1149, 1145, 1, 0, 0, 0, 1150, 127, 1, 0, 0, 0, 1151, 1159, 3, 160, 80, 0, 1152, 1153, 3, 136, 68, 0, 1153, 1154, 5, 120, 0, 0, 1154, 1156, 1, 0, 0, 0, 1155, 1152, 1, 0, 0, 0, 1155, 1156, 1, 0, 0, 0, 1156, 1157, 1, 0, 0, 0, 1157, 1159, 3, 130, 65, 0, 1158, 1151, 1, 0, 0, 0, 1158, 1155, 1, 0, 0, 0, 1159, 129, 1, 0, 0, 0, 1160, 1165, 3, 156, 78, 0, 1161, 1162, 5, 120, 0, 0, 1162, 1164, 3, 156, 78, 0, 1163, 1161, 1, 0, 0, 0, 1164, 1167, 1, 0, 0, 0, 1165, 1163, 1, 0, 0, 0, 1165, 1166, 1, 0, 0, 0, 1166, 131, 1, 0, 0, 0, 1167, 1165, 1, 0, 0, 0, 1168, 1169, 6, 66, -1, 0, 1169, 1178, 3, 136, 68, 0, 1170, 1178, 3, 134, 67, 0, 1171, 1172, 5, 130, 0, 0, 1172, 1173, 3, 44, 22, 0, 1173, 1174, 5, 149, 0, 0, 1174, 1178, 1, 0, 0, 0, 1175, 1178, 3, 120, 60, 0, 1176, 1178, 3, 160, 80, 0, 1177, 1168, 1, 0, 0, 0, 1177, 1170, 1, 0, 0, 0, 1177, 1171, 1, 0, 0, 0, 1177, 1175, 1, 0, 0, 0, 1177, 1176, 1, 0, 0, 0, 1178, 1187, 1, 0, 0, 0, 1179, 1183, 10, 3, 0, 0, 1180, 1184, 3, 154, 77, 0, 1181, 1182, 5, 6, 0, 0, 1182, 1184, 3, 156, 78, 0, 1183, 1180, 1, 0, 0, 0, 1183, 1181, 1, 0, 0, 0, 1184, 1186, 1, 0, 0, 0, 1185, 1179, 1, 0, 0, 0, 1186, 1189, 1, 0, 0, 0, 1187, 1185, 1, 0, 0, 0, 1187, 1188, 1, 0, 0, 0, 1188, 133, 1, 0, 0, 0, 1189, 1187, 1, 0, 0, 0, 1190, 1191, 3, 156, 78, 0, 1191, 1193, 5, 130, 0, 0, 1192, 1194, 3, 138, 69, 0, 1193, 1192, 1, 0, 0, 0, 1193, 1194, 1, 0, 0, 0, 1194, 1195, 1, 0, 0, 0, 1195, 1196, 5, 149, 0, 0, 1196, 135, 1, 0, 0, 0, 1197, 1198, 3, 140, 70, 0, 1198, 1199, 5, 120, 0, 0, 1199, 1201, 1, 0, 0, 0, 1200, 1197, 1, 0, 0, 0, 1200, 1201, 1, 0, 0, 0, 1201, 1202, 1, 0, 0, 0, 1202, 1203, 3, 156, 78, 0, 1203, 137, 1, 0, 0, 0, 1204, 1209, 3, 116, 58, 0, 1205, 1206, 5, 116, 0, 0, 1206, 1208, 3, 116, 58, 0, 1207, 1205, 1, 0, 0, 0, 1208, 1211, 1, 0, 0, 0, 1209, 1207, 1, 0, 0, 0, 1209, 1210, 1, 0, 0, 0, 1210, 1213, 1, 0, 0, 0, 1211, 1209, 1, 0, 0, 0, 1212, 1214, 5, 116, 0, 0, 1213, 1212, 1, 0, 0, 0, 1213, 1214, 1, 0, 0, 0, 1214, 139, 1, 0, 0, 0, 1215, 1216, 3, 156, 78, 0, 1216, 141, 1, 0, 0, 0, 1217, 1226, 5, 106, 0, 0, 1218, 1219, 5, 120, 0, 0, 1219, 1226, 7, 11, 0, 0, 1220, 1221, 5, 108, 0, 0, 1221, 1223, 5, 120, 0, 0, 1222, 1224, 7, 11, 0, 0, 1223, 1222, 1, 0, 0, 0, 1223, 1224, 1, 0, 0, 0, 1224, 1226, 1, 0, 0, 0, 1225, 1217, 1, 0, 0, 0, 1225, 1218, 1, 0, 0, 0, 1225, 1220, 1, 0, 0, 0, 1226, 143, 1, 0, 0, 0, 1227, 1229, 7, 12, 0, 0, 1228, 1227, 1, 0, 0, 0, 1228, 1229, 1, 0, 0, 0, 1229, 1236, 1, 0, 0, 0, 1230, 1237, 3, 142, 71, 0, 1231, 1237, 5, 107, 0, 0, 1232, 1237, 5, 108, 0, 0, 1233, 1237, 5, 109, 0, 0, 1234, 1237, 5, 43, 0, 0, 1235, 1237, 5, 57, 0, 0, 1236, 1230, 1, 0, 0, 0, 1236, 1231, 1, 0, 0, 0, 1236, 1232, 1, 0, 0, 0, 1236, 1233, 1, 0, 0, 0, 1236, 1234, 1, 0, 0, 0, 1236, 1235, 1, 0, 0, 0, 1237, 145, 1, 0, 0, 0, 1238, 1242, 3, 144, 72, 0, 1239, 1242, 5, 110, 0, 0, 1240, 1242, 5, 59, 0, 0, 1241, 1238, 1, 0, 0, 0, 1241, 1239, 1, 0, 0, 0, 1241, 1240, 1, 0, 0, 0, 1242, 147, 1, 0, 0, 0, 1243, 1244, 7, 13, 0, 0, 1244, 149, 1, 0, 0, 0, 1245, 1246, 7, 14, 0, 0, 1246, 151, 1, 0, 0, 0, 1247, 1248, 7, 15, 0, 0, 1248, 153, 1, 0, 0, 0, 1249, 1252, 5, 105, 0, 0, 1250, 1252, 3, 152, 76, 0, 1251, 1249, 1, 0, 0, 0, 1251, 1250, 1, 0, 0, 0, 1252, 155, 1, 0, 0, 0, 1253, 1257, 5, 105, 0, 0, 1254, 1257, 3, 148, 74, 0, 1255, 1257, 3, 150, 75, 0, 1256, 1253, 1, 0, 0, 0, 1256, 1254, 1, 0, 0, 0, 1256, 1255, 1, 0, 0, 0, 1257, 157, 1, 0, 0, 0, 1258, 1259, 3, 162, 81, 0, 1259, 1260, 5, 122, 0, 0, 1260, 1261, 3, 144, 72, 0, 1261, 159, 1, 0, 0, 0, 1262, 1263, 5, 128, 0, 0, 1263, 1264, 3, 130, 65, 0, 1264, 1265, 5, 147, 0, 0, 1265, 161, 1, 0, 0, 0, 1266, 1269, 5, 110, 0, 0, 1267, 1269, 3, 164, 82, 0, 1268, 1266, 1, 0, 0, 0, 1268, 1267, 1, 0, 0, 0, 1269, 163, 1, 0, 0, 0, 1270, 1274, 5, 142, 0, 0, 1271, 1273, 3, 166, 83, 0, 1272, 1271, 1, 0, 0, 0, 1273, 1276, 1, 0, 0, 0, 1274, 1272, 1, 0, 0, 0, 1274, 1275, 1, 0, 0, 0, 1275, 1277, 1, 0, 0, 0, 1276, 1274, 1, 0, 0, 0, 1277, 1278, 5, 144, 0, 0, 1278, 165, 1, 0, 0, 0, 1279, 1280, 5, 157, 0, 0, 1280, 1281, 3, 116, 58, 0, 1281, 1282, 5, 147, 0, 0, 1282, 1285, 1, 0, 0, 0, 1283, 1285, 5, 156, 0, 0, 1284, 1279, 1, 0, 0, 0, 1284, 1283, 1, 0, 0, 0, 1285, 167, 1, 0, 0, 0, 1286, 1290, 5, 143, 0, 0, 1287, 1289, 3, 170, 85, 0, 1288, 1287, 1, 0, 0, 0, 1289, 1292, 1, 0, 0, 0, 1290, 1288, 1, 0, 0, 0, 1290, 1291, 1, 0, 0, 0, 1291, 1293, 1, 0, 0, 0, 1292, 1290, 1, 0, 0, 0, 1293, 1294, 5, 0, 0, 1, 1294, 169, 1, 0, 0, 0, 1295, 1296, 5, 159, 0, 0, 1296, 1297, 3, 116, 58, 0, 1297, 1298, 5, 147, 0, 0, 1298, 1301, 1, 0, 0, 0, 1299, 1301, 5, 158, 0, 0, 1300, 1295, 1, 0, 0, 0, 1300, 1299, 1, 0, 0, 0, 1301, 171, 1, 0, 0, 0, 167, 175, 182, 191, 198, 202, 216, 220, 223, 227, 230, 237, 241, 250, 255, 264, 272, 279, 283, 289, 294, 302, 309, 315, 327, 335, 349, 353, 358, 368, 377, 380, 384, 387, 391, 394, 397, 400, 403, 407, 411, 414, 417, 420, 424, 427, 436, 442, 463, 480, 497, 503, 509, 520, 522, 533, 536, 542, 550, 556, 558, 562, 567, 570, 573, 577, 581, 584, 586, 589, 593, 597, 600, 602, 604, 609, 620, 626, 633, 638, 642, 646, 652, 654, 661, 669, 672, 675, 694, 708, 724, 728, 739, 743, 754, 758, 765, 769, 776, 780, 785, 794, 798, 822, 839, 845, 848, 851, 861, 867, 870, 873, 881, 884, 888, 891, 905, 922, 927, 932, 938, 945, 957, 961, 964, 973, 987, 1003, 1032, 1040, 1042, 1044, 1053, 1057, 1066, 1070, 1074, 1079, 1086, 1097, 1106, 1113, 1126, 1133, 1137, 1149, 1155, 1158, 1165, 1177, 1183, 1187, 1193, 1200, 1209, 1213, 1223, 1225, 1228, 1236, 1241, 1251, 1256, 1268, 1274, 1284, 1290, 1300] \ No newline at end of file diff --git a/posthog/hogql/grammar/HogQLParser.py b/posthog/hogql/grammar/HogQLParser.py index f3a1844f404d3..e983a673610fb 100644 --- a/posthog/hogql/grammar/HogQLParser.py +++ b/posthog/hogql/grammar/HogQLParser.py @@ -1,4 +1,4 @@ -# Generated from HogQLParser.g4 by ANTLR 4.13.1 +# Generated from HogQLParser.g4 by ANTLR 4.13.2 # encoding: utf-8 from antlr4 import * from io import StringIO @@ -10,7 +10,7 @@ def serializedATN(): return [ - 4,1,159,1311,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, + 4,1,159,1303,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, @@ -23,520 +23,519 @@ def serializedATN(): 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,1,0,5,0,178,8,0,10,0,12,0,181,9,0,1, - 0,1,0,1,1,1,1,3,1,187,8,1,1,2,1,2,1,3,1,3,1,3,1,3,1,3,3,3,196,8, - 3,1,4,1,4,1,4,5,4,201,8,4,10,4,12,4,204,9,4,1,4,3,4,207,8,4,1,5, - 1,5,1,5,1,5,1,5,1,5,1,5,1,5,1,5,1,5,1,5,1,5,3,5,221,8,5,1,6,1,6, - 3,6,225,8,6,1,6,3,6,228,8,6,1,7,1,7,3,7,232,8,7,1,7,3,7,235,8,7, - 1,8,1,8,1,8,1,8,1,8,3,8,242,8,8,1,8,1,8,3,8,246,8,8,1,8,1,8,1,9, - 1,9,1,9,5,9,253,8,9,10,9,12,9,256,9,9,1,9,1,9,3,9,260,8,9,1,10,1, - 10,1,10,1,10,1,10,1,10,1,10,3,10,269,8,10,1,11,1,11,1,11,1,11,1, - 11,1,11,3,11,277,8,11,1,12,1,12,1,12,1,12,1,12,3,12,284,8,12,1,12, - 1,12,3,12,288,8,12,1,12,1,12,1,12,1,12,3,12,294,8,12,1,12,1,12,1, - 12,3,12,299,8,12,1,13,1,13,1,13,1,13,1,13,1,13,3,13,307,8,13,1,13, - 1,13,1,13,1,13,1,13,3,13,314,8,13,1,14,1,14,1,14,1,14,3,14,320,8, - 14,1,14,1,14,1,14,1,15,1,15,1,15,1,15,1,15,1,16,1,16,3,16,332,8, - 16,1,17,1,17,1,18,1,18,5,18,338,8,18,10,18,12,18,341,9,18,1,18,1, - 18,1,19,1,19,1,19,1,19,1,20,1,20,1,20,5,20,352,8,20,10,20,12,20, - 355,9,20,1,20,3,20,358,8,20,1,21,1,21,1,21,3,21,363,8,21,1,21,1, - 21,1,22,1,22,1,22,1,22,5,22,371,8,22,10,22,12,22,374,9,22,1,23,1, - 23,1,23,1,23,1,23,1,23,3,23,382,8,23,1,24,3,24,385,8,24,1,24,1,24, - 3,24,389,8,24,1,24,3,24,392,8,24,1,24,1,24,3,24,396,8,24,1,24,3, - 24,399,8,24,1,24,3,24,402,8,24,1,24,3,24,405,8,24,1,24,3,24,408, - 8,24,1,24,1,24,3,24,412,8,24,1,24,1,24,3,24,416,8,24,1,24,3,24,419, - 8,24,1,24,3,24,422,8,24,1,24,3,24,425,8,24,1,24,1,24,3,24,429,8, - 24,1,24,3,24,432,8,24,1,25,1,25,1,25,1,26,1,26,1,26,1,26,3,26,441, - 8,26,1,27,1,27,1,27,1,28,3,28,447,8,28,1,28,1,28,1,28,1,28,1,29, - 1,29,1,29,1,29,1,29,1,29,1,29,1,29,1,29,1,29,1,29,1,29,1,29,5,29, - 466,8,29,10,29,12,29,469,9,29,1,30,1,30,1,30,1,31,1,31,1,31,1,32, - 1,32,1,32,1,32,1,32,1,32,1,32,1,32,3,32,485,8,32,1,33,1,33,1,33, - 1,34,1,34,1,34,1,34,1,35,1,35,1,35,1,35,1,36,1,36,1,36,1,36,3,36, - 502,8,36,1,36,1,36,1,36,1,36,3,36,508,8,36,1,36,1,36,1,36,1,36,3, - 36,514,8,36,1,36,1,36,1,36,1,36,1,36,1,36,1,36,1,36,1,36,3,36,525, - 8,36,3,36,527,8,36,1,37,1,37,1,37,1,38,1,38,1,38,1,39,1,39,1,39, - 3,39,538,8,39,1,39,3,39,541,8,39,1,39,1,39,1,39,1,39,3,39,547,8, - 39,1,39,1,39,1,39,1,39,1,39,1,39,3,39,555,8,39,1,39,1,39,1,39,1, - 39,5,39,561,8,39,10,39,12,39,564,9,39,1,40,3,40,567,8,40,1,40,1, - 40,1,40,3,40,572,8,40,1,40,3,40,575,8,40,1,40,3,40,578,8,40,1,40, - 1,40,3,40,582,8,40,1,40,1,40,3,40,586,8,40,1,40,3,40,589,8,40,3, - 40,591,8,40,1,40,3,40,594,8,40,1,40,1,40,3,40,598,8,40,1,40,1,40, - 3,40,602,8,40,1,40,3,40,605,8,40,3,40,607,8,40,3,40,609,8,40,1,41, - 1,41,1,41,3,41,614,8,41,1,42,1,42,1,42,1,42,1,42,1,42,1,42,1,42, - 1,42,3,42,625,8,42,1,43,1,43,1,43,1,43,3,43,631,8,43,1,44,1,44,1, - 44,5,44,636,8,44,10,44,12,44,639,9,44,1,45,1,45,3,45,643,8,45,1, - 45,1,45,3,45,647,8,45,1,45,1,45,3,45,651,8,45,1,46,1,46,1,46,1,46, - 3,46,657,8,46,3,46,659,8,46,1,47,1,47,1,47,5,47,664,8,47,10,47,12, - 47,667,9,47,1,48,1,48,1,48,1,48,1,49,3,49,674,8,49,1,49,3,49,677, - 8,49,1,49,3,49,680,8,49,1,50,1,50,1,50,1,50,1,51,1,51,1,51,1,51, - 1,52,1,52,1,52,1,53,1,53,1,53,1,53,1,53,1,53,3,53,699,8,53,1,54, - 1,54,1,54,1,54,1,54,1,54,1,54,1,54,1,54,1,54,1,54,1,54,3,54,713, - 8,54,1,55,1,55,1,55,1,56,1,56,1,56,1,56,1,56,1,56,1,56,1,56,1,56, - 5,56,727,8,56,10,56,12,56,730,9,56,1,56,3,56,733,8,56,1,56,1,56, - 1,56,1,56,1,56,1,56,1,56,5,56,742,8,56,10,56,12,56,745,9,56,1,56, - 3,56,748,8,56,1,56,1,56,1,56,1,56,1,56,1,56,1,56,5,56,757,8,56,10, - 56,12,56,760,9,56,1,56,3,56,763,8,56,1,56,1,56,1,56,1,56,1,56,3, - 56,770,8,56,1,56,1,56,3,56,774,8,56,1,57,1,57,1,57,5,57,779,8,57, - 10,57,12,57,782,9,57,1,57,3,57,785,8,57,1,58,1,58,1,58,3,58,790, - 8,58,1,58,1,58,1,58,1,58,1,58,4,58,797,8,58,11,58,12,58,798,1,58, - 1,58,3,58,803,8,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58, + 85,7,85,1,0,5,0,174,8,0,10,0,12,0,177,9,0,1,0,1,0,1,1,1,1,3,1,183, + 8,1,1,2,1,2,1,3,1,3,1,3,1,3,1,3,3,3,192,8,3,1,4,1,4,1,4,5,4,197, + 8,4,10,4,12,4,200,9,4,1,4,3,4,203,8,4,1,5,1,5,1,5,1,5,1,5,1,5,1, + 5,1,5,1,5,1,5,1,5,1,5,3,5,217,8,5,1,6,1,6,3,6,221,8,6,1,6,3,6,224, + 8,6,1,7,1,7,3,7,228,8,7,1,7,3,7,231,8,7,1,8,1,8,1,8,1,8,1,8,3,8, + 238,8,8,1,8,1,8,3,8,242,8,8,1,8,1,8,1,9,1,9,1,9,5,9,249,8,9,10,9, + 12,9,252,9,9,1,9,1,9,3,9,256,8,9,1,10,1,10,1,10,1,10,1,10,1,10,1, + 10,3,10,265,8,10,1,11,1,11,1,11,1,11,1,11,1,11,3,11,273,8,11,1,12, + 1,12,1,12,1,12,1,12,3,12,280,8,12,1,12,1,12,3,12,284,8,12,1,12,1, + 12,1,12,1,12,3,12,290,8,12,1,12,1,12,1,12,3,12,295,8,12,1,13,1,13, + 1,13,1,13,1,13,1,13,3,13,303,8,13,1,13,1,13,1,13,1,13,1,13,3,13, + 310,8,13,1,14,1,14,1,14,1,14,3,14,316,8,14,1,14,1,14,1,14,1,15,1, + 15,1,15,1,15,1,15,1,16,1,16,3,16,328,8,16,1,17,1,17,1,18,1,18,5, + 18,334,8,18,10,18,12,18,337,9,18,1,18,1,18,1,19,1,19,1,19,1,19,1, + 20,1,20,1,20,5,20,348,8,20,10,20,12,20,351,9,20,1,20,3,20,354,8, + 20,1,21,1,21,1,21,3,21,359,8,21,1,21,1,21,1,22,1,22,1,22,1,22,5, + 22,367,8,22,10,22,12,22,370,9,22,1,23,1,23,1,23,1,23,1,23,1,23,3, + 23,378,8,23,1,24,3,24,381,8,24,1,24,1,24,3,24,385,8,24,1,24,3,24, + 388,8,24,1,24,1,24,3,24,392,8,24,1,24,3,24,395,8,24,1,24,3,24,398, + 8,24,1,24,3,24,401,8,24,1,24,3,24,404,8,24,1,24,1,24,3,24,408,8, + 24,1,24,1,24,3,24,412,8,24,1,24,3,24,415,8,24,1,24,3,24,418,8,24, + 1,24,3,24,421,8,24,1,24,1,24,3,24,425,8,24,1,24,3,24,428,8,24,1, + 25,1,25,1,25,1,26,1,26,1,26,1,26,3,26,437,8,26,1,27,1,27,1,27,1, + 28,3,28,443,8,28,1,28,1,28,1,28,1,28,1,29,1,29,1,29,1,29,1,29,1, + 29,1,29,1,29,1,29,1,29,1,29,1,29,1,29,5,29,462,8,29,10,29,12,29, + 465,9,29,1,30,1,30,1,30,1,31,1,31,1,31,1,32,1,32,1,32,1,32,1,32, + 1,32,1,32,1,32,3,32,481,8,32,1,33,1,33,1,33,1,34,1,34,1,34,1,34, + 1,35,1,35,1,35,1,35,1,36,1,36,1,36,1,36,3,36,498,8,36,1,36,1,36, + 1,36,1,36,3,36,504,8,36,1,36,1,36,1,36,1,36,3,36,510,8,36,1,36,1, + 36,1,36,1,36,1,36,1,36,1,36,1,36,1,36,3,36,521,8,36,3,36,523,8,36, + 1,37,1,37,1,37,1,38,1,38,1,38,1,39,1,39,1,39,3,39,534,8,39,1,39, + 3,39,537,8,39,1,39,1,39,1,39,1,39,3,39,543,8,39,1,39,1,39,1,39,1, + 39,1,39,1,39,3,39,551,8,39,1,39,1,39,1,39,1,39,5,39,557,8,39,10, + 39,12,39,560,9,39,1,40,3,40,563,8,40,1,40,1,40,1,40,3,40,568,8,40, + 1,40,3,40,571,8,40,1,40,3,40,574,8,40,1,40,1,40,3,40,578,8,40,1, + 40,1,40,3,40,582,8,40,1,40,3,40,585,8,40,3,40,587,8,40,1,40,3,40, + 590,8,40,1,40,1,40,3,40,594,8,40,1,40,1,40,3,40,598,8,40,1,40,3, + 40,601,8,40,3,40,603,8,40,3,40,605,8,40,1,41,1,41,1,41,3,41,610, + 8,41,1,42,1,42,1,42,1,42,1,42,1,42,1,42,1,42,1,42,3,42,621,8,42, + 1,43,1,43,1,43,1,43,3,43,627,8,43,1,44,1,44,1,44,5,44,632,8,44,10, + 44,12,44,635,9,44,1,45,1,45,3,45,639,8,45,1,45,1,45,3,45,643,8,45, + 1,45,1,45,3,45,647,8,45,1,46,1,46,1,46,1,46,3,46,653,8,46,3,46,655, + 8,46,1,47,1,47,1,47,5,47,660,8,47,10,47,12,47,663,9,47,1,48,1,48, + 1,48,1,48,1,49,3,49,670,8,49,1,49,3,49,673,8,49,1,49,3,49,676,8, + 49,1,50,1,50,1,50,1,50,1,51,1,51,1,51,1,51,1,52,1,52,1,52,1,53,1, + 53,1,53,1,53,1,53,1,53,3,53,695,8,53,1,54,1,54,1,54,1,54,1,54,1, + 54,1,54,1,54,1,54,1,54,1,54,1,54,3,54,709,8,54,1,55,1,55,1,55,1, + 56,1,56,1,56,1,56,1,56,1,56,1,56,1,56,1,56,5,56,723,8,56,10,56,12, + 56,726,9,56,1,56,3,56,729,8,56,1,56,1,56,1,56,1,56,1,56,1,56,1,56, + 5,56,738,8,56,10,56,12,56,741,9,56,1,56,3,56,744,8,56,1,56,1,56, + 1,56,1,56,1,56,1,56,1,56,5,56,753,8,56,10,56,12,56,756,9,56,1,56, + 3,56,759,8,56,1,56,1,56,1,56,1,56,1,56,3,56,766,8,56,1,56,1,56,3, + 56,770,8,56,1,57,1,57,1,57,5,57,775,8,57,10,57,12,57,778,9,57,1, + 57,3,57,781,8,57,1,58,1,58,1,58,3,58,786,8,58,1,58,1,58,1,58,1,58, + 1,58,4,58,793,8,58,11,58,12,58,794,1,58,1,58,3,58,799,8,58,1,58, 1,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58, - 3,58,827,8,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58, - 1,58,1,58,1,58,1,58,1,58,3,58,844,8,58,1,58,1,58,1,58,1,58,3,58, - 850,8,58,1,58,3,58,853,8,58,1,58,3,58,856,8,58,1,58,1,58,1,58,1, - 58,1,58,1,58,1,58,1,58,3,58,866,8,58,1,58,1,58,1,58,1,58,3,58,872, - 8,58,1,58,3,58,875,8,58,1,58,3,58,878,8,58,1,58,1,58,1,58,1,58,1, - 58,1,58,3,58,886,8,58,1,58,3,58,889,8,58,1,58,1,58,3,58,893,8,58, - 1,58,3,58,896,8,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58, - 1,58,1,58,1,58,3,58,910,8,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58, - 1,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,3,58,927,8,58,1,58,1,58, - 1,58,3,58,932,8,58,1,58,1,58,3,58,936,8,58,1,58,1,58,1,58,1,58,3, - 58,942,8,58,1,58,1,58,1,58,1,58,1,58,3,58,949,8,58,1,58,1,58,1,58, - 1,58,1,58,1,58,1,58,1,58,1,58,1,58,3,58,961,8,58,1,58,1,58,3,58, - 965,8,58,1,58,3,58,968,8,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,3, - 58,977,8,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,1, - 58,1,58,3,58,991,8,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,1, - 58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,1, - 58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,1, - 58,1,58,1,58,3,58,1030,8,58,1,58,1,58,1,58,1,58,1,58,1,58,3,58,1038, - 8,58,5,58,1040,8,58,10,58,12,58,1043,9,58,1,59,1,59,1,59,5,59,1048, - 8,59,10,59,12,59,1051,9,59,1,59,3,59,1054,8,59,1,60,1,60,3,60,1058, - 8,60,1,61,1,61,1,61,1,61,5,61,1064,8,61,10,61,12,61,1067,9,61,1, - 61,3,61,1070,8,61,1,61,1,61,1,61,1,61,1,61,5,61,1077,8,61,10,61, - 12,61,1080,9,61,1,61,3,61,1083,8,61,3,61,1085,8,61,1,61,1,61,1,61, - 1,62,1,62,1,62,5,62,1093,8,62,10,62,12,62,1096,9,62,1,62,1,62,1, - 62,1,62,1,62,1,62,5,62,1104,8,62,10,62,12,62,1107,9,62,1,62,1,62, - 1,62,1,62,1,62,1,62,3,62,1115,8,62,1,62,1,62,1,62,1,62,1,62,3,62, - 1122,8,62,1,63,1,63,1,63,1,63,1,63,1,63,1,63,1,63,1,63,1,63,1,63, - 3,63,1135,8,63,1,64,1,64,1,64,5,64,1140,8,64,10,64,12,64,1143,9, - 64,1,64,3,64,1146,8,64,1,65,1,65,1,65,1,65,1,65,1,65,1,65,1,65,1, - 65,1,65,3,65,1158,8,65,1,66,1,66,1,66,1,66,3,66,1164,8,66,1,66,3, - 66,1167,8,66,1,67,1,67,1,67,5,67,1172,8,67,10,67,12,67,1175,9,67, - 1,68,1,68,1,68,1,68,1,68,1,68,1,68,1,68,1,68,3,68,1186,8,68,1,68, - 1,68,1,68,1,68,3,68,1192,8,68,5,68,1194,8,68,10,68,12,68,1197,9, - 68,1,69,1,69,1,69,3,69,1202,8,69,1,69,1,69,1,70,1,70,1,70,3,70,1209, - 8,70,1,70,1,70,1,71,1,71,1,71,5,71,1216,8,71,10,71,12,71,1219,9, - 71,1,71,3,71,1222,8,71,1,72,1,72,1,73,1,73,1,73,1,73,1,73,1,73,3, - 73,1232,8,73,3,73,1234,8,73,1,74,3,74,1237,8,74,1,74,1,74,1,74,1, - 74,1,74,1,74,3,74,1245,8,74,1,75,1,75,1,75,3,75,1250,8,75,1,76,1, - 76,1,77,1,77,1,78,1,78,1,79,1,79,3,79,1260,8,79,1,80,1,80,1,80,3, - 80,1265,8,80,1,81,1,81,1,81,1,81,1,82,1,82,1,82,1,82,1,83,1,83,3, - 83,1277,8,83,1,84,1,84,5,84,1281,8,84,10,84,12,84,1284,9,84,1,84, - 1,84,1,85,1,85,1,85,1,85,1,85,3,85,1293,8,85,1,86,1,86,5,86,1297, - 8,86,10,86,12,86,1300,9,86,1,86,1,86,1,87,1,87,1,87,1,87,1,87,3, - 87,1309,8,87,1,87,0,3,78,116,136,88,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,0,16,2,0,18,18,74,74,2,0,44,44,51,51,3,0,1,1,4,4,8,8,4,0, - 1,1,3,4,8,8,80,80,2,0,51,51,73,73,2,0,1,1,4,4,2,0,7,7,22,23,2,0, - 30,30,49,49,2,0,71,71,76,76,3,0,10,10,50,50,90,90,2,0,41,41,53,53, - 1,0,107,108,2,0,118,118,139,139,7,0,21,21,38,38,55,56,70,70,78,78, - 97,97,103,103,16,0,1,13,15,20,22,28,30,30,32,37,39,42,44,51,53,54, - 58,58,60,69,71,77,79,83,85,92,94,96,98,99,101,102,4,0,20,20,30,30, - 39,39,48,48,1479,0,179,1,0,0,0,2,186,1,0,0,0,4,188,1,0,0,0,6,190, - 1,0,0,0,8,197,1,0,0,0,10,220,1,0,0,0,12,222,1,0,0,0,14,229,1,0,0, - 0,16,236,1,0,0,0,18,249,1,0,0,0,20,261,1,0,0,0,22,270,1,0,0,0,24, - 278,1,0,0,0,26,300,1,0,0,0,28,315,1,0,0,0,30,324,1,0,0,0,32,329, - 1,0,0,0,34,333,1,0,0,0,36,335,1,0,0,0,38,344,1,0,0,0,40,348,1,0, - 0,0,42,362,1,0,0,0,44,366,1,0,0,0,46,381,1,0,0,0,48,384,1,0,0,0, - 50,433,1,0,0,0,52,436,1,0,0,0,54,442,1,0,0,0,56,446,1,0,0,0,58,452, - 1,0,0,0,60,470,1,0,0,0,62,473,1,0,0,0,64,476,1,0,0,0,66,486,1,0, - 0,0,68,489,1,0,0,0,70,493,1,0,0,0,72,526,1,0,0,0,74,528,1,0,0,0, - 76,531,1,0,0,0,78,546,1,0,0,0,80,608,1,0,0,0,82,613,1,0,0,0,84,624, - 1,0,0,0,86,626,1,0,0,0,88,632,1,0,0,0,90,640,1,0,0,0,92,658,1,0, - 0,0,94,660,1,0,0,0,96,668,1,0,0,0,98,673,1,0,0,0,100,681,1,0,0,0, - 102,685,1,0,0,0,104,689,1,0,0,0,106,698,1,0,0,0,108,712,1,0,0,0, - 110,714,1,0,0,0,112,773,1,0,0,0,114,775,1,0,0,0,116,935,1,0,0,0, - 118,1044,1,0,0,0,120,1057,1,0,0,0,122,1084,1,0,0,0,124,1121,1,0, - 0,0,126,1134,1,0,0,0,128,1136,1,0,0,0,130,1157,1,0,0,0,132,1166, - 1,0,0,0,134,1168,1,0,0,0,136,1185,1,0,0,0,138,1198,1,0,0,0,140,1208, - 1,0,0,0,142,1212,1,0,0,0,144,1223,1,0,0,0,146,1233,1,0,0,0,148,1236, - 1,0,0,0,150,1249,1,0,0,0,152,1251,1,0,0,0,154,1253,1,0,0,0,156,1255, - 1,0,0,0,158,1259,1,0,0,0,160,1264,1,0,0,0,162,1266,1,0,0,0,164,1270, - 1,0,0,0,166,1276,1,0,0,0,168,1278,1,0,0,0,170,1292,1,0,0,0,172,1294, - 1,0,0,0,174,1308,1,0,0,0,176,178,3,2,1,0,177,176,1,0,0,0,178,181, - 1,0,0,0,179,177,1,0,0,0,179,180,1,0,0,0,180,182,1,0,0,0,181,179, - 1,0,0,0,182,183,5,0,0,1,183,1,1,0,0,0,184,187,3,6,3,0,185,187,3, - 10,5,0,186,184,1,0,0,0,186,185,1,0,0,0,187,3,1,0,0,0,188,189,3,116, - 58,0,189,5,1,0,0,0,190,191,5,52,0,0,191,195,3,160,80,0,192,193,5, - 115,0,0,193,194,5,122,0,0,194,196,3,4,2,0,195,192,1,0,0,0,195,196, - 1,0,0,0,196,7,1,0,0,0,197,202,3,160,80,0,198,199,5,116,0,0,199,201, - 3,160,80,0,200,198,1,0,0,0,201,204,1,0,0,0,202,200,1,0,0,0,202,203, - 1,0,0,0,203,206,1,0,0,0,204,202,1,0,0,0,205,207,5,116,0,0,206,205, - 1,0,0,0,206,207,1,0,0,0,207,9,1,0,0,0,208,221,3,12,6,0,209,221,3, - 14,7,0,210,221,3,18,9,0,211,221,3,20,10,0,212,221,3,22,11,0,213, - 221,3,26,13,0,214,221,3,24,12,0,215,221,3,28,14,0,216,221,3,30,15, - 0,217,221,3,36,18,0,218,221,3,32,16,0,219,221,3,34,17,0,220,208, - 1,0,0,0,220,209,1,0,0,0,220,210,1,0,0,0,220,211,1,0,0,0,220,212, - 1,0,0,0,220,213,1,0,0,0,220,214,1,0,0,0,220,215,1,0,0,0,220,216, - 1,0,0,0,220,217,1,0,0,0,220,218,1,0,0,0,220,219,1,0,0,0,221,11,1, - 0,0,0,222,224,5,72,0,0,223,225,3,4,2,0,224,223,1,0,0,0,224,225,1, - 0,0,0,225,227,1,0,0,0,226,228,5,150,0,0,227,226,1,0,0,0,227,228, - 1,0,0,0,228,13,1,0,0,0,229,231,5,84,0,0,230,232,3,4,2,0,231,230, - 1,0,0,0,231,232,1,0,0,0,232,234,1,0,0,0,233,235,5,150,0,0,234,233, - 1,0,0,0,234,235,1,0,0,0,235,15,1,0,0,0,236,245,5,14,0,0,237,238, - 5,130,0,0,238,241,3,160,80,0,239,240,5,115,0,0,240,242,3,160,80, - 0,241,239,1,0,0,0,241,242,1,0,0,0,242,243,1,0,0,0,243,244,5,149, - 0,0,244,246,1,0,0,0,245,237,1,0,0,0,245,246,1,0,0,0,246,247,1,0, - 0,0,247,248,3,36,18,0,248,17,1,0,0,0,249,250,5,93,0,0,250,254,3, - 36,18,0,251,253,3,16,8,0,252,251,1,0,0,0,253,256,1,0,0,0,254,252, - 1,0,0,0,254,255,1,0,0,0,255,259,1,0,0,0,256,254,1,0,0,0,257,258, - 5,29,0,0,258,260,3,36,18,0,259,257,1,0,0,0,259,260,1,0,0,0,260,19, - 1,0,0,0,261,262,5,40,0,0,262,263,5,130,0,0,263,264,3,4,2,0,264,265, - 5,149,0,0,265,268,3,10,5,0,266,267,5,25,0,0,267,269,3,10,5,0,268, - 266,1,0,0,0,268,269,1,0,0,0,269,21,1,0,0,0,270,271,5,100,0,0,271, - 272,5,130,0,0,272,273,3,4,2,0,273,274,5,149,0,0,274,276,3,10,5,0, - 275,277,5,150,0,0,276,275,1,0,0,0,276,277,1,0,0,0,277,23,1,0,0,0, - 278,279,5,33,0,0,279,283,5,130,0,0,280,284,3,6,3,0,281,284,3,30, - 15,0,282,284,3,4,2,0,283,280,1,0,0,0,283,281,1,0,0,0,283,282,1,0, - 0,0,283,284,1,0,0,0,284,285,1,0,0,0,285,287,5,150,0,0,286,288,3, - 4,2,0,287,286,1,0,0,0,287,288,1,0,0,0,288,289,1,0,0,0,289,293,5, - 150,0,0,290,294,3,6,3,0,291,294,3,30,15,0,292,294,3,4,2,0,293,290, - 1,0,0,0,293,291,1,0,0,0,293,292,1,0,0,0,293,294,1,0,0,0,294,295, - 1,0,0,0,295,296,5,149,0,0,296,298,3,10,5,0,297,299,5,150,0,0,298, - 297,1,0,0,0,298,299,1,0,0,0,299,25,1,0,0,0,300,301,5,33,0,0,301, - 302,5,130,0,0,302,303,5,52,0,0,303,306,3,160,80,0,304,305,5,116, - 0,0,305,307,3,160,80,0,306,304,1,0,0,0,306,307,1,0,0,0,307,308,1, - 0,0,0,308,309,5,42,0,0,309,310,3,4,2,0,310,311,5,149,0,0,311,313, - 3,10,5,0,312,314,5,150,0,0,313,312,1,0,0,0,313,314,1,0,0,0,314,27, - 1,0,0,0,315,316,5,31,0,0,316,317,3,160,80,0,317,319,5,130,0,0,318, - 320,3,8,4,0,319,318,1,0,0,0,319,320,1,0,0,0,320,321,1,0,0,0,321, - 322,5,149,0,0,322,323,3,36,18,0,323,29,1,0,0,0,324,325,3,4,2,0,325, - 326,5,115,0,0,326,327,5,122,0,0,327,328,3,4,2,0,328,31,1,0,0,0,329, - 331,3,4,2,0,330,332,5,150,0,0,331,330,1,0,0,0,331,332,1,0,0,0,332, - 33,1,0,0,0,333,334,5,150,0,0,334,35,1,0,0,0,335,339,5,128,0,0,336, - 338,3,2,1,0,337,336,1,0,0,0,338,341,1,0,0,0,339,337,1,0,0,0,339, - 340,1,0,0,0,340,342,1,0,0,0,341,339,1,0,0,0,342,343,5,147,0,0,343, - 37,1,0,0,0,344,345,3,4,2,0,345,346,5,115,0,0,346,347,3,4,2,0,347, - 39,1,0,0,0,348,353,3,38,19,0,349,350,5,116,0,0,350,352,3,38,19,0, - 351,349,1,0,0,0,352,355,1,0,0,0,353,351,1,0,0,0,353,354,1,0,0,0, - 354,357,1,0,0,0,355,353,1,0,0,0,356,358,5,116,0,0,357,356,1,0,0, - 0,357,358,1,0,0,0,358,41,1,0,0,0,359,363,3,44,22,0,360,363,3,48, - 24,0,361,363,3,124,62,0,362,359,1,0,0,0,362,360,1,0,0,0,362,361, - 1,0,0,0,363,364,1,0,0,0,364,365,5,0,0,1,365,43,1,0,0,0,366,372,3, - 46,23,0,367,368,5,95,0,0,368,369,5,1,0,0,369,371,3,46,23,0,370,367, - 1,0,0,0,371,374,1,0,0,0,372,370,1,0,0,0,372,373,1,0,0,0,373,45,1, - 0,0,0,374,372,1,0,0,0,375,382,3,48,24,0,376,377,5,130,0,0,377,378, - 3,44,22,0,378,379,5,149,0,0,379,382,1,0,0,0,380,382,3,164,82,0,381, - 375,1,0,0,0,381,376,1,0,0,0,381,380,1,0,0,0,382,47,1,0,0,0,383,385, - 3,50,25,0,384,383,1,0,0,0,384,385,1,0,0,0,385,386,1,0,0,0,386,388, - 5,79,0,0,387,389,5,24,0,0,388,387,1,0,0,0,388,389,1,0,0,0,389,391, - 1,0,0,0,390,392,3,52,26,0,391,390,1,0,0,0,391,392,1,0,0,0,392,393, - 1,0,0,0,393,395,3,114,57,0,394,396,3,54,27,0,395,394,1,0,0,0,395, - 396,1,0,0,0,396,398,1,0,0,0,397,399,3,56,28,0,398,397,1,0,0,0,398, - 399,1,0,0,0,399,401,1,0,0,0,400,402,3,60,30,0,401,400,1,0,0,0,401, - 402,1,0,0,0,402,404,1,0,0,0,403,405,3,62,31,0,404,403,1,0,0,0,404, - 405,1,0,0,0,405,407,1,0,0,0,406,408,3,64,32,0,407,406,1,0,0,0,407, - 408,1,0,0,0,408,411,1,0,0,0,409,410,5,102,0,0,410,412,7,0,0,0,411, - 409,1,0,0,0,411,412,1,0,0,0,412,415,1,0,0,0,413,414,5,102,0,0,414, - 416,5,89,0,0,415,413,1,0,0,0,415,416,1,0,0,0,416,418,1,0,0,0,417, - 419,3,66,33,0,418,417,1,0,0,0,418,419,1,0,0,0,419,421,1,0,0,0,420, - 422,3,58,29,0,421,420,1,0,0,0,421,422,1,0,0,0,422,424,1,0,0,0,423, - 425,3,68,34,0,424,423,1,0,0,0,424,425,1,0,0,0,425,428,1,0,0,0,426, - 429,3,72,36,0,427,429,3,74,37,0,428,426,1,0,0,0,428,427,1,0,0,0, - 428,429,1,0,0,0,429,431,1,0,0,0,430,432,3,76,38,0,431,430,1,0,0, - 0,431,432,1,0,0,0,432,49,1,0,0,0,433,434,5,102,0,0,434,435,3,128, - 64,0,435,51,1,0,0,0,436,437,5,88,0,0,437,440,5,108,0,0,438,439,5, - 102,0,0,439,441,5,85,0,0,440,438,1,0,0,0,440,441,1,0,0,0,441,53, - 1,0,0,0,442,443,5,34,0,0,443,444,3,78,39,0,444,55,1,0,0,0,445,447, - 7,1,0,0,446,445,1,0,0,0,446,447,1,0,0,0,447,448,1,0,0,0,448,449, - 5,5,0,0,449,450,5,47,0,0,450,451,3,114,57,0,451,57,1,0,0,0,452,453, - 5,101,0,0,453,454,3,160,80,0,454,455,5,6,0,0,455,456,5,130,0,0,456, - 457,3,98,49,0,457,467,5,149,0,0,458,459,5,116,0,0,459,460,3,160, - 80,0,460,461,5,6,0,0,461,462,5,130,0,0,462,463,3,98,49,0,463,464, - 5,149,0,0,464,466,1,0,0,0,465,458,1,0,0,0,466,469,1,0,0,0,467,465, - 1,0,0,0,467,468,1,0,0,0,468,59,1,0,0,0,469,467,1,0,0,0,470,471,5, - 69,0,0,471,472,3,116,58,0,472,61,1,0,0,0,473,474,5,99,0,0,474,475, - 3,116,58,0,475,63,1,0,0,0,476,477,5,36,0,0,477,484,5,11,0,0,478, - 479,7,0,0,0,479,480,5,130,0,0,480,481,3,114,57,0,481,482,5,149,0, - 0,482,485,1,0,0,0,483,485,3,114,57,0,484,478,1,0,0,0,484,483,1,0, - 0,0,485,65,1,0,0,0,486,487,5,37,0,0,487,488,3,116,58,0,488,67,1, - 0,0,0,489,490,5,64,0,0,490,491,5,11,0,0,491,492,3,88,44,0,492,69, - 1,0,0,0,493,494,5,64,0,0,494,495,5,11,0,0,495,496,3,114,57,0,496, - 71,1,0,0,0,497,498,5,54,0,0,498,501,3,116,58,0,499,500,5,116,0,0, - 500,502,3,116,58,0,501,499,1,0,0,0,501,502,1,0,0,0,502,507,1,0,0, - 0,503,504,5,102,0,0,504,508,5,85,0,0,505,506,5,11,0,0,506,508,3, - 114,57,0,507,503,1,0,0,0,507,505,1,0,0,0,507,508,1,0,0,0,508,527, - 1,0,0,0,509,510,5,54,0,0,510,513,3,116,58,0,511,512,5,102,0,0,512, - 514,5,85,0,0,513,511,1,0,0,0,513,514,1,0,0,0,514,515,1,0,0,0,515, - 516,5,61,0,0,516,517,3,116,58,0,517,527,1,0,0,0,518,519,5,54,0,0, - 519,520,3,116,58,0,520,521,5,61,0,0,521,524,3,116,58,0,522,523,5, - 11,0,0,523,525,3,114,57,0,524,522,1,0,0,0,524,525,1,0,0,0,525,527, - 1,0,0,0,526,497,1,0,0,0,526,509,1,0,0,0,526,518,1,0,0,0,527,73,1, - 0,0,0,528,529,5,61,0,0,529,530,3,116,58,0,530,75,1,0,0,0,531,532, - 5,81,0,0,532,533,3,94,47,0,533,77,1,0,0,0,534,535,6,39,-1,0,535, - 537,3,136,68,0,536,538,5,28,0,0,537,536,1,0,0,0,537,538,1,0,0,0, - 538,540,1,0,0,0,539,541,3,86,43,0,540,539,1,0,0,0,540,541,1,0,0, - 0,541,547,1,0,0,0,542,543,5,130,0,0,543,544,3,78,39,0,544,545,5, - 149,0,0,545,547,1,0,0,0,546,534,1,0,0,0,546,542,1,0,0,0,547,562, - 1,0,0,0,548,549,10,3,0,0,549,550,3,82,41,0,550,551,3,78,39,4,551, - 561,1,0,0,0,552,554,10,4,0,0,553,555,3,80,40,0,554,553,1,0,0,0,554, - 555,1,0,0,0,555,556,1,0,0,0,556,557,5,47,0,0,557,558,3,78,39,0,558, - 559,3,84,42,0,559,561,1,0,0,0,560,548,1,0,0,0,560,552,1,0,0,0,561, - 564,1,0,0,0,562,560,1,0,0,0,562,563,1,0,0,0,563,79,1,0,0,0,564,562, - 1,0,0,0,565,567,7,2,0,0,566,565,1,0,0,0,566,567,1,0,0,0,567,568, - 1,0,0,0,568,575,5,44,0,0,569,571,5,44,0,0,570,572,7,2,0,0,571,570, - 1,0,0,0,571,572,1,0,0,0,572,575,1,0,0,0,573,575,7,2,0,0,574,566, - 1,0,0,0,574,569,1,0,0,0,574,573,1,0,0,0,575,609,1,0,0,0,576,578, - 7,3,0,0,577,576,1,0,0,0,577,578,1,0,0,0,578,579,1,0,0,0,579,581, - 7,4,0,0,580,582,5,65,0,0,581,580,1,0,0,0,581,582,1,0,0,0,582,591, - 1,0,0,0,583,585,7,4,0,0,584,586,5,65,0,0,585,584,1,0,0,0,585,586, - 1,0,0,0,586,588,1,0,0,0,587,589,7,3,0,0,588,587,1,0,0,0,588,589, - 1,0,0,0,589,591,1,0,0,0,590,577,1,0,0,0,590,583,1,0,0,0,591,609, - 1,0,0,0,592,594,7,5,0,0,593,592,1,0,0,0,593,594,1,0,0,0,594,595, + 1,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,3,58,823,8,58,1,58,1,58, + 1,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58, + 3,58,840,8,58,1,58,1,58,1,58,1,58,3,58,846,8,58,1,58,3,58,849,8, + 58,1,58,3,58,852,8,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,3, + 58,862,8,58,1,58,1,58,1,58,1,58,3,58,868,8,58,1,58,3,58,871,8,58, + 1,58,3,58,874,8,58,1,58,1,58,1,58,1,58,1,58,1,58,3,58,882,8,58,1, + 58,3,58,885,8,58,1,58,1,58,3,58,889,8,58,1,58,3,58,892,8,58,1,58, + 1,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,3,58,906, + 8,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58, + 1,58,1,58,1,58,3,58,923,8,58,1,58,1,58,1,58,3,58,928,8,58,1,58,1, + 58,1,58,3,58,933,8,58,1,58,1,58,1,58,1,58,3,58,939,8,58,1,58,1,58, + 1,58,1,58,1,58,3,58,946,8,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58, + 1,58,1,58,1,58,3,58,958,8,58,1,58,1,58,3,58,962,8,58,1,58,3,58,965, + 8,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,3,58,974,8,58,1,58,1,58, + 1,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,3,58,988,8,58, + 1,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58, + 1,58,3,58,1004,8,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58, + 1,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58,1,58, + 1,58,1,58,1,58,1,58,1,58,3,58,1033,8,58,1,58,1,58,1,58,1,58,1,58, + 1,58,3,58,1041,8,58,5,58,1043,8,58,10,58,12,58,1046,9,58,1,59,1, + 59,1,59,1,59,5,59,1052,8,59,10,59,12,59,1055,9,59,1,59,3,59,1058, + 8,59,1,59,1,59,1,59,1,59,1,59,5,59,1065,8,59,10,59,12,59,1068,9, + 59,1,59,3,59,1071,8,59,1,59,1,59,3,59,1075,8,59,1,59,1,59,1,59,3, + 59,1080,8,59,1,60,1,60,1,60,5,60,1085,8,60,10,60,12,60,1088,9,60, + 1,60,1,60,1,60,1,60,1,60,1,60,5,60,1096,8,60,10,60,12,60,1099,9, + 60,1,60,1,60,1,60,1,60,1,60,1,60,3,60,1107,8,60,1,60,1,60,1,60,1, + 60,1,60,3,60,1114,8,60,1,61,1,61,1,61,1,61,1,61,1,61,1,61,1,61,1, + 61,1,61,1,61,3,61,1127,8,61,1,62,1,62,1,62,5,62,1132,8,62,10,62, + 12,62,1135,9,62,1,62,3,62,1138,8,62,1,63,1,63,1,63,1,63,1,63,1,63, + 1,63,1,63,1,63,1,63,3,63,1150,8,63,1,64,1,64,1,64,1,64,3,64,1156, + 8,64,1,64,3,64,1159,8,64,1,65,1,65,1,65,5,65,1164,8,65,10,65,12, + 65,1167,9,65,1,66,1,66,1,66,1,66,1,66,1,66,1,66,1,66,1,66,3,66,1178, + 8,66,1,66,1,66,1,66,1,66,3,66,1184,8,66,5,66,1186,8,66,10,66,12, + 66,1189,9,66,1,67,1,67,1,67,3,67,1194,8,67,1,67,1,67,1,68,1,68,1, + 68,3,68,1201,8,68,1,68,1,68,1,69,1,69,1,69,5,69,1208,8,69,10,69, + 12,69,1211,9,69,1,69,3,69,1214,8,69,1,70,1,70,1,71,1,71,1,71,1,71, + 1,71,1,71,3,71,1224,8,71,3,71,1226,8,71,1,72,3,72,1229,8,72,1,72, + 1,72,1,72,1,72,1,72,1,72,3,72,1237,8,72,1,73,1,73,1,73,3,73,1242, + 8,73,1,74,1,74,1,75,1,75,1,76,1,76,1,77,1,77,3,77,1252,8,77,1,78, + 1,78,1,78,3,78,1257,8,78,1,79,1,79,1,79,1,79,1,80,1,80,1,80,1,80, + 1,81,1,81,3,81,1269,8,81,1,82,1,82,5,82,1273,8,82,10,82,12,82,1276, + 9,82,1,82,1,82,1,83,1,83,1,83,1,83,1,83,3,83,1285,8,83,1,84,1,84, + 5,84,1289,8,84,10,84,12,84,1292,9,84,1,84,1,84,1,85,1,85,1,85,1, + 85,1,85,3,85,1301,8,85,1,85,0,3,78,116,132,86,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,0,16,2,0,18,18,74,74,2,0,44,44,51,51,3,0,1,1,4,4,8,8, + 4,0,1,1,3,4,8,8,80,80,2,0,51,51,73,73,2,0,1,1,4,4,2,0,7,7,22,23, + 2,0,30,30,49,49,2,0,71,71,76,76,3,0,10,10,50,50,90,90,2,0,41,41, + 53,53,1,0,107,108,2,0,118,118,139,139,7,0,21,21,38,38,55,56,70,70, + 78,78,97,97,103,103,16,0,1,13,15,20,22,28,30,30,32,37,39,42,44,51, + 53,54,58,58,60,69,71,77,79,83,85,92,94,96,98,99,101,102,4,0,20,20, + 30,30,39,39,48,48,1475,0,175,1,0,0,0,2,182,1,0,0,0,4,184,1,0,0,0, + 6,186,1,0,0,0,8,193,1,0,0,0,10,216,1,0,0,0,12,218,1,0,0,0,14,225, + 1,0,0,0,16,232,1,0,0,0,18,245,1,0,0,0,20,257,1,0,0,0,22,266,1,0, + 0,0,24,274,1,0,0,0,26,296,1,0,0,0,28,311,1,0,0,0,30,320,1,0,0,0, + 32,325,1,0,0,0,34,329,1,0,0,0,36,331,1,0,0,0,38,340,1,0,0,0,40,344, + 1,0,0,0,42,358,1,0,0,0,44,362,1,0,0,0,46,377,1,0,0,0,48,380,1,0, + 0,0,50,429,1,0,0,0,52,432,1,0,0,0,54,438,1,0,0,0,56,442,1,0,0,0, + 58,448,1,0,0,0,60,466,1,0,0,0,62,469,1,0,0,0,64,472,1,0,0,0,66,482, + 1,0,0,0,68,485,1,0,0,0,70,489,1,0,0,0,72,522,1,0,0,0,74,524,1,0, + 0,0,76,527,1,0,0,0,78,542,1,0,0,0,80,604,1,0,0,0,82,609,1,0,0,0, + 84,620,1,0,0,0,86,622,1,0,0,0,88,628,1,0,0,0,90,636,1,0,0,0,92,654, + 1,0,0,0,94,656,1,0,0,0,96,664,1,0,0,0,98,669,1,0,0,0,100,677,1,0, + 0,0,102,681,1,0,0,0,104,685,1,0,0,0,106,694,1,0,0,0,108,708,1,0, + 0,0,110,710,1,0,0,0,112,769,1,0,0,0,114,771,1,0,0,0,116,932,1,0, + 0,0,118,1074,1,0,0,0,120,1113,1,0,0,0,122,1126,1,0,0,0,124,1128, + 1,0,0,0,126,1149,1,0,0,0,128,1158,1,0,0,0,130,1160,1,0,0,0,132,1177, + 1,0,0,0,134,1190,1,0,0,0,136,1200,1,0,0,0,138,1204,1,0,0,0,140,1215, + 1,0,0,0,142,1225,1,0,0,0,144,1228,1,0,0,0,146,1241,1,0,0,0,148,1243, + 1,0,0,0,150,1245,1,0,0,0,152,1247,1,0,0,0,154,1251,1,0,0,0,156,1256, + 1,0,0,0,158,1258,1,0,0,0,160,1262,1,0,0,0,162,1268,1,0,0,0,164,1270, + 1,0,0,0,166,1284,1,0,0,0,168,1286,1,0,0,0,170,1300,1,0,0,0,172,174, + 3,2,1,0,173,172,1,0,0,0,174,177,1,0,0,0,175,173,1,0,0,0,175,176, + 1,0,0,0,176,178,1,0,0,0,177,175,1,0,0,0,178,179,5,0,0,1,179,1,1, + 0,0,0,180,183,3,6,3,0,181,183,3,10,5,0,182,180,1,0,0,0,182,181,1, + 0,0,0,183,3,1,0,0,0,184,185,3,116,58,0,185,5,1,0,0,0,186,187,5,52, + 0,0,187,191,3,156,78,0,188,189,5,115,0,0,189,190,5,122,0,0,190,192, + 3,4,2,0,191,188,1,0,0,0,191,192,1,0,0,0,192,7,1,0,0,0,193,198,3, + 156,78,0,194,195,5,116,0,0,195,197,3,156,78,0,196,194,1,0,0,0,197, + 200,1,0,0,0,198,196,1,0,0,0,198,199,1,0,0,0,199,202,1,0,0,0,200, + 198,1,0,0,0,201,203,5,116,0,0,202,201,1,0,0,0,202,203,1,0,0,0,203, + 9,1,0,0,0,204,217,3,12,6,0,205,217,3,14,7,0,206,217,3,18,9,0,207, + 217,3,20,10,0,208,217,3,22,11,0,209,217,3,26,13,0,210,217,3,24,12, + 0,211,217,3,28,14,0,212,217,3,30,15,0,213,217,3,36,18,0,214,217, + 3,32,16,0,215,217,3,34,17,0,216,204,1,0,0,0,216,205,1,0,0,0,216, + 206,1,0,0,0,216,207,1,0,0,0,216,208,1,0,0,0,216,209,1,0,0,0,216, + 210,1,0,0,0,216,211,1,0,0,0,216,212,1,0,0,0,216,213,1,0,0,0,216, + 214,1,0,0,0,216,215,1,0,0,0,217,11,1,0,0,0,218,220,5,72,0,0,219, + 221,3,4,2,0,220,219,1,0,0,0,220,221,1,0,0,0,221,223,1,0,0,0,222, + 224,5,150,0,0,223,222,1,0,0,0,223,224,1,0,0,0,224,13,1,0,0,0,225, + 227,5,84,0,0,226,228,3,4,2,0,227,226,1,0,0,0,227,228,1,0,0,0,228, + 230,1,0,0,0,229,231,5,150,0,0,230,229,1,0,0,0,230,231,1,0,0,0,231, + 15,1,0,0,0,232,241,5,14,0,0,233,234,5,130,0,0,234,237,3,156,78,0, + 235,236,5,115,0,0,236,238,3,156,78,0,237,235,1,0,0,0,237,238,1,0, + 0,0,238,239,1,0,0,0,239,240,5,149,0,0,240,242,1,0,0,0,241,233,1, + 0,0,0,241,242,1,0,0,0,242,243,1,0,0,0,243,244,3,36,18,0,244,17,1, + 0,0,0,245,246,5,93,0,0,246,250,3,36,18,0,247,249,3,16,8,0,248,247, + 1,0,0,0,249,252,1,0,0,0,250,248,1,0,0,0,250,251,1,0,0,0,251,255, + 1,0,0,0,252,250,1,0,0,0,253,254,5,29,0,0,254,256,3,36,18,0,255,253, + 1,0,0,0,255,256,1,0,0,0,256,19,1,0,0,0,257,258,5,40,0,0,258,259, + 5,130,0,0,259,260,3,4,2,0,260,261,5,149,0,0,261,264,3,10,5,0,262, + 263,5,25,0,0,263,265,3,10,5,0,264,262,1,0,0,0,264,265,1,0,0,0,265, + 21,1,0,0,0,266,267,5,100,0,0,267,268,5,130,0,0,268,269,3,4,2,0,269, + 270,5,149,0,0,270,272,3,10,5,0,271,273,5,150,0,0,272,271,1,0,0,0, + 272,273,1,0,0,0,273,23,1,0,0,0,274,275,5,33,0,0,275,279,5,130,0, + 0,276,280,3,6,3,0,277,280,3,30,15,0,278,280,3,4,2,0,279,276,1,0, + 0,0,279,277,1,0,0,0,279,278,1,0,0,0,279,280,1,0,0,0,280,281,1,0, + 0,0,281,283,5,150,0,0,282,284,3,4,2,0,283,282,1,0,0,0,283,284,1, + 0,0,0,284,285,1,0,0,0,285,289,5,150,0,0,286,290,3,6,3,0,287,290, + 3,30,15,0,288,290,3,4,2,0,289,286,1,0,0,0,289,287,1,0,0,0,289,288, + 1,0,0,0,289,290,1,0,0,0,290,291,1,0,0,0,291,292,5,149,0,0,292,294, + 3,10,5,0,293,295,5,150,0,0,294,293,1,0,0,0,294,295,1,0,0,0,295,25, + 1,0,0,0,296,297,5,33,0,0,297,298,5,130,0,0,298,299,5,52,0,0,299, + 302,3,156,78,0,300,301,5,116,0,0,301,303,3,156,78,0,302,300,1,0, + 0,0,302,303,1,0,0,0,303,304,1,0,0,0,304,305,5,42,0,0,305,306,3,4, + 2,0,306,307,5,149,0,0,307,309,3,10,5,0,308,310,5,150,0,0,309,308, + 1,0,0,0,309,310,1,0,0,0,310,27,1,0,0,0,311,312,5,31,0,0,312,313, + 3,156,78,0,313,315,5,130,0,0,314,316,3,8,4,0,315,314,1,0,0,0,315, + 316,1,0,0,0,316,317,1,0,0,0,317,318,5,149,0,0,318,319,3,36,18,0, + 319,29,1,0,0,0,320,321,3,4,2,0,321,322,5,115,0,0,322,323,5,122,0, + 0,323,324,3,4,2,0,324,31,1,0,0,0,325,327,3,4,2,0,326,328,5,150,0, + 0,327,326,1,0,0,0,327,328,1,0,0,0,328,33,1,0,0,0,329,330,5,150,0, + 0,330,35,1,0,0,0,331,335,5,128,0,0,332,334,3,2,1,0,333,332,1,0,0, + 0,334,337,1,0,0,0,335,333,1,0,0,0,335,336,1,0,0,0,336,338,1,0,0, + 0,337,335,1,0,0,0,338,339,5,147,0,0,339,37,1,0,0,0,340,341,3,4,2, + 0,341,342,5,115,0,0,342,343,3,4,2,0,343,39,1,0,0,0,344,349,3,38, + 19,0,345,346,5,116,0,0,346,348,3,38,19,0,347,345,1,0,0,0,348,351, + 1,0,0,0,349,347,1,0,0,0,349,350,1,0,0,0,350,353,1,0,0,0,351,349, + 1,0,0,0,352,354,5,116,0,0,353,352,1,0,0,0,353,354,1,0,0,0,354,41, + 1,0,0,0,355,359,3,44,22,0,356,359,3,48,24,0,357,359,3,120,60,0,358, + 355,1,0,0,0,358,356,1,0,0,0,358,357,1,0,0,0,359,360,1,0,0,0,360, + 361,5,0,0,1,361,43,1,0,0,0,362,368,3,46,23,0,363,364,5,95,0,0,364, + 365,5,1,0,0,365,367,3,46,23,0,366,363,1,0,0,0,367,370,1,0,0,0,368, + 366,1,0,0,0,368,369,1,0,0,0,369,45,1,0,0,0,370,368,1,0,0,0,371,378, + 3,48,24,0,372,373,5,130,0,0,373,374,3,44,22,0,374,375,5,149,0,0, + 375,378,1,0,0,0,376,378,3,160,80,0,377,371,1,0,0,0,377,372,1,0,0, + 0,377,376,1,0,0,0,378,47,1,0,0,0,379,381,3,50,25,0,380,379,1,0,0, + 0,380,381,1,0,0,0,381,382,1,0,0,0,382,384,5,79,0,0,383,385,5,24, + 0,0,384,383,1,0,0,0,384,385,1,0,0,0,385,387,1,0,0,0,386,388,3,52, + 26,0,387,386,1,0,0,0,387,388,1,0,0,0,388,389,1,0,0,0,389,391,3,114, + 57,0,390,392,3,54,27,0,391,390,1,0,0,0,391,392,1,0,0,0,392,394,1, + 0,0,0,393,395,3,56,28,0,394,393,1,0,0,0,394,395,1,0,0,0,395,397, + 1,0,0,0,396,398,3,60,30,0,397,396,1,0,0,0,397,398,1,0,0,0,398,400, + 1,0,0,0,399,401,3,62,31,0,400,399,1,0,0,0,400,401,1,0,0,0,401,403, + 1,0,0,0,402,404,3,64,32,0,403,402,1,0,0,0,403,404,1,0,0,0,404,407, + 1,0,0,0,405,406,5,102,0,0,406,408,7,0,0,0,407,405,1,0,0,0,407,408, + 1,0,0,0,408,411,1,0,0,0,409,410,5,102,0,0,410,412,5,89,0,0,411,409, + 1,0,0,0,411,412,1,0,0,0,412,414,1,0,0,0,413,415,3,66,33,0,414,413, + 1,0,0,0,414,415,1,0,0,0,415,417,1,0,0,0,416,418,3,58,29,0,417,416, + 1,0,0,0,417,418,1,0,0,0,418,420,1,0,0,0,419,421,3,68,34,0,420,419, + 1,0,0,0,420,421,1,0,0,0,421,424,1,0,0,0,422,425,3,72,36,0,423,425, + 3,74,37,0,424,422,1,0,0,0,424,423,1,0,0,0,424,425,1,0,0,0,425,427, + 1,0,0,0,426,428,3,76,38,0,427,426,1,0,0,0,427,428,1,0,0,0,428,49, + 1,0,0,0,429,430,5,102,0,0,430,431,3,124,62,0,431,51,1,0,0,0,432, + 433,5,88,0,0,433,436,5,108,0,0,434,435,5,102,0,0,435,437,5,85,0, + 0,436,434,1,0,0,0,436,437,1,0,0,0,437,53,1,0,0,0,438,439,5,34,0, + 0,439,440,3,78,39,0,440,55,1,0,0,0,441,443,7,1,0,0,442,441,1,0,0, + 0,442,443,1,0,0,0,443,444,1,0,0,0,444,445,5,5,0,0,445,446,5,47,0, + 0,446,447,3,114,57,0,447,57,1,0,0,0,448,449,5,101,0,0,449,450,3, + 156,78,0,450,451,5,6,0,0,451,452,5,130,0,0,452,453,3,98,49,0,453, + 463,5,149,0,0,454,455,5,116,0,0,455,456,3,156,78,0,456,457,5,6,0, + 0,457,458,5,130,0,0,458,459,3,98,49,0,459,460,5,149,0,0,460,462, + 1,0,0,0,461,454,1,0,0,0,462,465,1,0,0,0,463,461,1,0,0,0,463,464, + 1,0,0,0,464,59,1,0,0,0,465,463,1,0,0,0,466,467,5,69,0,0,467,468, + 3,116,58,0,468,61,1,0,0,0,469,470,5,99,0,0,470,471,3,116,58,0,471, + 63,1,0,0,0,472,473,5,36,0,0,473,480,5,11,0,0,474,475,7,0,0,0,475, + 476,5,130,0,0,476,477,3,114,57,0,477,478,5,149,0,0,478,481,1,0,0, + 0,479,481,3,114,57,0,480,474,1,0,0,0,480,479,1,0,0,0,481,65,1,0, + 0,0,482,483,5,37,0,0,483,484,3,116,58,0,484,67,1,0,0,0,485,486,5, + 64,0,0,486,487,5,11,0,0,487,488,3,88,44,0,488,69,1,0,0,0,489,490, + 5,64,0,0,490,491,5,11,0,0,491,492,3,114,57,0,492,71,1,0,0,0,493, + 494,5,54,0,0,494,497,3,116,58,0,495,496,5,116,0,0,496,498,3,116, + 58,0,497,495,1,0,0,0,497,498,1,0,0,0,498,503,1,0,0,0,499,500,5,102, + 0,0,500,504,5,85,0,0,501,502,5,11,0,0,502,504,3,114,57,0,503,499, + 1,0,0,0,503,501,1,0,0,0,503,504,1,0,0,0,504,523,1,0,0,0,505,506, + 5,54,0,0,506,509,3,116,58,0,507,508,5,102,0,0,508,510,5,85,0,0,509, + 507,1,0,0,0,509,510,1,0,0,0,510,511,1,0,0,0,511,512,5,61,0,0,512, + 513,3,116,58,0,513,523,1,0,0,0,514,515,5,54,0,0,515,516,3,116,58, + 0,516,517,5,61,0,0,517,520,3,116,58,0,518,519,5,11,0,0,519,521,3, + 114,57,0,520,518,1,0,0,0,520,521,1,0,0,0,521,523,1,0,0,0,522,493, + 1,0,0,0,522,505,1,0,0,0,522,514,1,0,0,0,523,73,1,0,0,0,524,525,5, + 61,0,0,525,526,3,116,58,0,526,75,1,0,0,0,527,528,5,81,0,0,528,529, + 3,94,47,0,529,77,1,0,0,0,530,531,6,39,-1,0,531,533,3,132,66,0,532, + 534,5,28,0,0,533,532,1,0,0,0,533,534,1,0,0,0,534,536,1,0,0,0,535, + 537,3,86,43,0,536,535,1,0,0,0,536,537,1,0,0,0,537,543,1,0,0,0,538, + 539,5,130,0,0,539,540,3,78,39,0,540,541,5,149,0,0,541,543,1,0,0, + 0,542,530,1,0,0,0,542,538,1,0,0,0,543,558,1,0,0,0,544,545,10,3,0, + 0,545,546,3,82,41,0,546,547,3,78,39,4,547,557,1,0,0,0,548,550,10, + 4,0,0,549,551,3,80,40,0,550,549,1,0,0,0,550,551,1,0,0,0,551,552, + 1,0,0,0,552,553,5,47,0,0,553,554,3,78,39,0,554,555,3,84,42,0,555, + 557,1,0,0,0,556,544,1,0,0,0,556,548,1,0,0,0,557,560,1,0,0,0,558, + 556,1,0,0,0,558,559,1,0,0,0,559,79,1,0,0,0,560,558,1,0,0,0,561,563, + 7,2,0,0,562,561,1,0,0,0,562,563,1,0,0,0,563,564,1,0,0,0,564,571, + 5,44,0,0,565,567,5,44,0,0,566,568,7,2,0,0,567,566,1,0,0,0,567,568, + 1,0,0,0,568,571,1,0,0,0,569,571,7,2,0,0,570,562,1,0,0,0,570,565, + 1,0,0,0,570,569,1,0,0,0,571,605,1,0,0,0,572,574,7,3,0,0,573,572, + 1,0,0,0,573,574,1,0,0,0,574,575,1,0,0,0,575,577,7,4,0,0,576,578, + 5,65,0,0,577,576,1,0,0,0,577,578,1,0,0,0,578,587,1,0,0,0,579,581, + 7,4,0,0,580,582,5,65,0,0,581,580,1,0,0,0,581,582,1,0,0,0,582,584, + 1,0,0,0,583,585,7,3,0,0,584,583,1,0,0,0,584,585,1,0,0,0,585,587, + 1,0,0,0,586,573,1,0,0,0,586,579,1,0,0,0,587,605,1,0,0,0,588,590, + 7,5,0,0,589,588,1,0,0,0,589,590,1,0,0,0,590,591,1,0,0,0,591,593, + 5,35,0,0,592,594,5,65,0,0,593,592,1,0,0,0,593,594,1,0,0,0,594,603, 1,0,0,0,595,597,5,35,0,0,596,598,5,65,0,0,597,596,1,0,0,0,597,598, - 1,0,0,0,598,607,1,0,0,0,599,601,5,35,0,0,600,602,5,65,0,0,601,600, - 1,0,0,0,601,602,1,0,0,0,602,604,1,0,0,0,603,605,7,5,0,0,604,603, - 1,0,0,0,604,605,1,0,0,0,605,607,1,0,0,0,606,593,1,0,0,0,606,599, - 1,0,0,0,607,609,1,0,0,0,608,574,1,0,0,0,608,590,1,0,0,0,608,606, - 1,0,0,0,609,81,1,0,0,0,610,611,5,17,0,0,611,614,5,47,0,0,612,614, - 5,116,0,0,613,610,1,0,0,0,613,612,1,0,0,0,614,83,1,0,0,0,615,616, - 5,62,0,0,616,625,3,114,57,0,617,618,5,96,0,0,618,619,5,130,0,0,619, - 620,3,114,57,0,620,621,5,149,0,0,621,625,1,0,0,0,622,623,5,96,0, - 0,623,625,3,114,57,0,624,615,1,0,0,0,624,617,1,0,0,0,624,622,1,0, - 0,0,625,85,1,0,0,0,626,627,5,77,0,0,627,630,3,92,46,0,628,629,5, - 61,0,0,629,631,3,92,46,0,630,628,1,0,0,0,630,631,1,0,0,0,631,87, - 1,0,0,0,632,637,3,90,45,0,633,634,5,116,0,0,634,636,3,90,45,0,635, - 633,1,0,0,0,636,639,1,0,0,0,637,635,1,0,0,0,637,638,1,0,0,0,638, - 89,1,0,0,0,639,637,1,0,0,0,640,642,3,116,58,0,641,643,7,6,0,0,642, - 641,1,0,0,0,642,643,1,0,0,0,643,646,1,0,0,0,644,645,5,60,0,0,645, - 647,7,7,0,0,646,644,1,0,0,0,646,647,1,0,0,0,647,650,1,0,0,0,648, - 649,5,16,0,0,649,651,5,110,0,0,650,648,1,0,0,0,650,651,1,0,0,0,651, - 91,1,0,0,0,652,659,3,164,82,0,653,656,3,148,74,0,654,655,5,151,0, - 0,655,657,3,148,74,0,656,654,1,0,0,0,656,657,1,0,0,0,657,659,1,0, - 0,0,658,652,1,0,0,0,658,653,1,0,0,0,659,93,1,0,0,0,660,665,3,96, - 48,0,661,662,5,116,0,0,662,664,3,96,48,0,663,661,1,0,0,0,664,667, - 1,0,0,0,665,663,1,0,0,0,665,666,1,0,0,0,666,95,1,0,0,0,667,665,1, - 0,0,0,668,669,3,160,80,0,669,670,5,122,0,0,670,671,3,150,75,0,671, - 97,1,0,0,0,672,674,3,100,50,0,673,672,1,0,0,0,673,674,1,0,0,0,674, - 676,1,0,0,0,675,677,3,102,51,0,676,675,1,0,0,0,676,677,1,0,0,0,677, - 679,1,0,0,0,678,680,3,104,52,0,679,678,1,0,0,0,679,680,1,0,0,0,680, - 99,1,0,0,0,681,682,5,67,0,0,682,683,5,11,0,0,683,684,3,114,57,0, - 684,101,1,0,0,0,685,686,5,64,0,0,686,687,5,11,0,0,687,688,3,88,44, - 0,688,103,1,0,0,0,689,690,7,8,0,0,690,691,3,106,53,0,691,105,1,0, - 0,0,692,699,3,108,54,0,693,694,5,9,0,0,694,695,3,108,54,0,695,696, - 5,2,0,0,696,697,3,108,54,0,697,699,1,0,0,0,698,692,1,0,0,0,698,693, - 1,0,0,0,699,107,1,0,0,0,700,701,5,19,0,0,701,713,5,75,0,0,702,703, - 5,94,0,0,703,713,5,68,0,0,704,705,5,94,0,0,705,713,5,32,0,0,706, - 707,3,148,74,0,707,708,5,68,0,0,708,713,1,0,0,0,709,710,3,148,74, - 0,710,711,5,32,0,0,711,713,1,0,0,0,712,700,1,0,0,0,712,702,1,0,0, - 0,712,704,1,0,0,0,712,706,1,0,0,0,712,709,1,0,0,0,713,109,1,0,0, - 0,714,715,3,116,58,0,715,716,5,0,0,1,716,111,1,0,0,0,717,774,3,160, - 80,0,718,719,3,160,80,0,719,720,5,130,0,0,720,721,3,160,80,0,721, - 728,3,112,56,0,722,723,5,116,0,0,723,724,3,160,80,0,724,725,3,112, - 56,0,725,727,1,0,0,0,726,722,1,0,0,0,727,730,1,0,0,0,728,726,1,0, - 0,0,728,729,1,0,0,0,729,732,1,0,0,0,730,728,1,0,0,0,731,733,5,116, - 0,0,732,731,1,0,0,0,732,733,1,0,0,0,733,734,1,0,0,0,734,735,5,149, - 0,0,735,774,1,0,0,0,736,737,3,160,80,0,737,738,5,130,0,0,738,743, - 3,162,81,0,739,740,5,116,0,0,740,742,3,162,81,0,741,739,1,0,0,0, - 742,745,1,0,0,0,743,741,1,0,0,0,743,744,1,0,0,0,744,747,1,0,0,0, - 745,743,1,0,0,0,746,748,5,116,0,0,747,746,1,0,0,0,747,748,1,0,0, - 0,748,749,1,0,0,0,749,750,5,149,0,0,750,774,1,0,0,0,751,752,3,160, - 80,0,752,753,5,130,0,0,753,758,3,112,56,0,754,755,5,116,0,0,755, - 757,3,112,56,0,756,754,1,0,0,0,757,760,1,0,0,0,758,756,1,0,0,0,758, - 759,1,0,0,0,759,762,1,0,0,0,760,758,1,0,0,0,761,763,5,116,0,0,762, - 761,1,0,0,0,762,763,1,0,0,0,763,764,1,0,0,0,764,765,5,149,0,0,765, - 774,1,0,0,0,766,767,3,160,80,0,767,769,5,130,0,0,768,770,3,114,57, - 0,769,768,1,0,0,0,769,770,1,0,0,0,770,771,1,0,0,0,771,772,5,149, - 0,0,772,774,1,0,0,0,773,717,1,0,0,0,773,718,1,0,0,0,773,736,1,0, - 0,0,773,751,1,0,0,0,773,766,1,0,0,0,774,113,1,0,0,0,775,780,3,116, - 58,0,776,777,5,116,0,0,777,779,3,116,58,0,778,776,1,0,0,0,779,782, - 1,0,0,0,780,778,1,0,0,0,780,781,1,0,0,0,781,784,1,0,0,0,782,780, - 1,0,0,0,783,785,5,116,0,0,784,783,1,0,0,0,784,785,1,0,0,0,785,115, - 1,0,0,0,786,787,6,58,-1,0,787,789,5,12,0,0,788,790,3,116,58,0,789, - 788,1,0,0,0,789,790,1,0,0,0,790,796,1,0,0,0,791,792,5,98,0,0,792, - 793,3,116,58,0,793,794,5,83,0,0,794,795,3,116,58,0,795,797,1,0,0, - 0,796,791,1,0,0,0,797,798,1,0,0,0,798,796,1,0,0,0,798,799,1,0,0, - 0,799,802,1,0,0,0,800,801,5,25,0,0,801,803,3,116,58,0,802,800,1, - 0,0,0,802,803,1,0,0,0,803,804,1,0,0,0,804,805,5,26,0,0,805,936,1, - 0,0,0,806,807,5,13,0,0,807,808,5,130,0,0,808,809,3,116,58,0,809, - 810,5,6,0,0,810,811,3,112,56,0,811,812,5,149,0,0,812,936,1,0,0,0, - 813,814,5,20,0,0,814,936,5,110,0,0,815,816,5,45,0,0,816,817,3,116, - 58,0,817,818,3,152,76,0,818,936,1,0,0,0,819,820,5,82,0,0,820,821, - 5,130,0,0,821,822,3,116,58,0,822,823,5,34,0,0,823,826,3,116,58,0, - 824,825,5,33,0,0,825,827,3,116,58,0,826,824,1,0,0,0,826,827,1,0, - 0,0,827,828,1,0,0,0,828,829,5,149,0,0,829,936,1,0,0,0,830,831,5, - 86,0,0,831,936,5,110,0,0,832,833,5,91,0,0,833,834,5,130,0,0,834, - 835,7,9,0,0,835,836,3,166,83,0,836,837,5,34,0,0,837,838,3,116,58, - 0,838,839,5,149,0,0,839,936,1,0,0,0,840,841,3,160,80,0,841,843,5, - 130,0,0,842,844,3,114,57,0,843,842,1,0,0,0,843,844,1,0,0,0,844,845, - 1,0,0,0,845,846,5,149,0,0,846,855,1,0,0,0,847,849,5,130,0,0,848, - 850,5,24,0,0,849,848,1,0,0,0,849,850,1,0,0,0,850,852,1,0,0,0,851, - 853,3,118,59,0,852,851,1,0,0,0,852,853,1,0,0,0,853,854,1,0,0,0,854, - 856,5,149,0,0,855,847,1,0,0,0,855,856,1,0,0,0,856,857,1,0,0,0,857, - 858,5,66,0,0,858,859,5,130,0,0,859,860,3,98,49,0,860,861,5,149,0, - 0,861,936,1,0,0,0,862,863,3,160,80,0,863,865,5,130,0,0,864,866,3, - 114,57,0,865,864,1,0,0,0,865,866,1,0,0,0,866,867,1,0,0,0,867,868, - 5,149,0,0,868,877,1,0,0,0,869,871,5,130,0,0,870,872,5,24,0,0,871, - 870,1,0,0,0,871,872,1,0,0,0,872,874,1,0,0,0,873,875,3,118,59,0,874, - 873,1,0,0,0,874,875,1,0,0,0,875,876,1,0,0,0,876,878,5,149,0,0,877, - 869,1,0,0,0,877,878,1,0,0,0,878,879,1,0,0,0,879,880,5,66,0,0,880, - 881,3,160,80,0,881,936,1,0,0,0,882,888,3,160,80,0,883,885,5,130, - 0,0,884,886,3,114,57,0,885,884,1,0,0,0,885,886,1,0,0,0,886,887,1, - 0,0,0,887,889,5,149,0,0,888,883,1,0,0,0,888,889,1,0,0,0,889,890, - 1,0,0,0,890,892,5,130,0,0,891,893,5,24,0,0,892,891,1,0,0,0,892,893, - 1,0,0,0,893,895,1,0,0,0,894,896,3,118,59,0,895,894,1,0,0,0,895,896, - 1,0,0,0,896,897,1,0,0,0,897,898,5,149,0,0,898,936,1,0,0,0,899,936, - 3,124,62,0,900,936,3,168,84,0,901,936,3,150,75,0,902,903,5,118,0, - 0,903,936,3,116,58,19,904,905,5,58,0,0,905,936,3,116,58,13,906,907, - 3,140,70,0,907,908,5,120,0,0,908,910,1,0,0,0,909,906,1,0,0,0,909, - 910,1,0,0,0,910,911,1,0,0,0,911,936,5,112,0,0,912,913,5,130,0,0, - 913,914,3,44,22,0,914,915,5,149,0,0,915,936,1,0,0,0,916,917,5,130, - 0,0,917,918,3,116,58,0,918,919,5,149,0,0,919,936,1,0,0,0,920,921, - 5,130,0,0,921,922,3,114,57,0,922,923,5,149,0,0,923,936,1,0,0,0,924, - 926,5,129,0,0,925,927,3,114,57,0,926,925,1,0,0,0,926,927,1,0,0,0, - 927,928,1,0,0,0,928,936,5,148,0,0,929,931,5,128,0,0,930,932,3,40, - 20,0,931,930,1,0,0,0,931,932,1,0,0,0,932,933,1,0,0,0,933,936,5,147, - 0,0,934,936,3,132,66,0,935,786,1,0,0,0,935,806,1,0,0,0,935,813,1, - 0,0,0,935,815,1,0,0,0,935,819,1,0,0,0,935,830,1,0,0,0,935,832,1, - 0,0,0,935,840,1,0,0,0,935,862,1,0,0,0,935,882,1,0,0,0,935,899,1, - 0,0,0,935,900,1,0,0,0,935,901,1,0,0,0,935,902,1,0,0,0,935,904,1, - 0,0,0,935,909,1,0,0,0,935,912,1,0,0,0,935,916,1,0,0,0,935,920,1, - 0,0,0,935,924,1,0,0,0,935,929,1,0,0,0,935,934,1,0,0,0,936,1041,1, - 0,0,0,937,941,10,18,0,0,938,942,5,112,0,0,939,942,5,151,0,0,940, - 942,5,138,0,0,941,938,1,0,0,0,941,939,1,0,0,0,941,940,1,0,0,0,942, - 943,1,0,0,0,943,1040,3,116,58,19,944,948,10,17,0,0,945,949,5,139, - 0,0,946,949,5,118,0,0,947,949,5,117,0,0,948,945,1,0,0,0,948,946, - 1,0,0,0,948,947,1,0,0,0,949,950,1,0,0,0,950,1040,3,116,58,18,951, - 976,10,16,0,0,952,977,5,121,0,0,953,977,5,122,0,0,954,977,5,133, - 0,0,955,977,5,131,0,0,956,977,5,132,0,0,957,977,5,123,0,0,958,977, - 5,124,0,0,959,961,5,58,0,0,960,959,1,0,0,0,960,961,1,0,0,0,961,962, - 1,0,0,0,962,964,5,42,0,0,963,965,5,15,0,0,964,963,1,0,0,0,964,965, - 1,0,0,0,965,977,1,0,0,0,966,968,5,58,0,0,967,966,1,0,0,0,967,968, - 1,0,0,0,968,969,1,0,0,0,969,977,7,10,0,0,970,977,5,145,0,0,971,977, - 5,146,0,0,972,977,5,135,0,0,973,977,5,126,0,0,974,977,5,127,0,0, - 975,977,5,134,0,0,976,952,1,0,0,0,976,953,1,0,0,0,976,954,1,0,0, - 0,976,955,1,0,0,0,976,956,1,0,0,0,976,957,1,0,0,0,976,958,1,0,0, - 0,976,960,1,0,0,0,976,967,1,0,0,0,976,970,1,0,0,0,976,971,1,0,0, - 0,976,972,1,0,0,0,976,973,1,0,0,0,976,974,1,0,0,0,976,975,1,0,0, - 0,977,978,1,0,0,0,978,1040,3,116,58,17,979,980,10,14,0,0,980,981, - 5,137,0,0,981,1040,3,116,58,15,982,983,10,12,0,0,983,984,5,2,0,0, - 984,1040,3,116,58,13,985,986,10,11,0,0,986,987,5,63,0,0,987,1040, - 3,116,58,12,988,990,10,10,0,0,989,991,5,58,0,0,990,989,1,0,0,0,990, - 991,1,0,0,0,991,992,1,0,0,0,992,993,5,9,0,0,993,994,3,116,58,0,994, - 995,5,2,0,0,995,996,3,116,58,11,996,1040,1,0,0,0,997,998,10,9,0, - 0,998,999,5,140,0,0,999,1000,3,116,58,0,1000,1001,5,115,0,0,1001, - 1002,3,116,58,9,1002,1040,1,0,0,0,1003,1004,10,25,0,0,1004,1005, - 5,129,0,0,1005,1006,3,116,58,0,1006,1007,5,148,0,0,1007,1040,1,0, - 0,0,1008,1009,10,24,0,0,1009,1010,5,120,0,0,1010,1040,5,108,0,0, - 1011,1012,10,23,0,0,1012,1013,5,120,0,0,1013,1040,3,160,80,0,1014, - 1015,10,22,0,0,1015,1016,5,136,0,0,1016,1017,5,129,0,0,1017,1018, - 3,116,58,0,1018,1019,5,148,0,0,1019,1040,1,0,0,0,1020,1021,10,21, - 0,0,1021,1022,5,136,0,0,1022,1040,5,108,0,0,1023,1024,10,20,0,0, - 1024,1025,5,136,0,0,1025,1040,3,160,80,0,1026,1027,10,15,0,0,1027, - 1029,5,46,0,0,1028,1030,5,58,0,0,1029,1028,1,0,0,0,1029,1030,1,0, - 0,0,1030,1031,1,0,0,0,1031,1040,5,59,0,0,1032,1037,10,8,0,0,1033, - 1034,5,6,0,0,1034,1038,3,160,80,0,1035,1036,5,6,0,0,1036,1038,5, - 110,0,0,1037,1033,1,0,0,0,1037,1035,1,0,0,0,1038,1040,1,0,0,0,1039, - 937,1,0,0,0,1039,944,1,0,0,0,1039,951,1,0,0,0,1039,979,1,0,0,0,1039, - 982,1,0,0,0,1039,985,1,0,0,0,1039,988,1,0,0,0,1039,997,1,0,0,0,1039, - 1003,1,0,0,0,1039,1008,1,0,0,0,1039,1011,1,0,0,0,1039,1014,1,0,0, - 0,1039,1020,1,0,0,0,1039,1023,1,0,0,0,1039,1026,1,0,0,0,1039,1032, - 1,0,0,0,1040,1043,1,0,0,0,1041,1039,1,0,0,0,1041,1042,1,0,0,0,1042, - 117,1,0,0,0,1043,1041,1,0,0,0,1044,1049,3,120,60,0,1045,1046,5,116, - 0,0,1046,1048,3,120,60,0,1047,1045,1,0,0,0,1048,1051,1,0,0,0,1049, - 1047,1,0,0,0,1049,1050,1,0,0,0,1050,1053,1,0,0,0,1051,1049,1,0,0, - 0,1052,1054,5,116,0,0,1053,1052,1,0,0,0,1053,1054,1,0,0,0,1054,119, - 1,0,0,0,1055,1058,3,122,61,0,1056,1058,3,116,58,0,1057,1055,1,0, - 0,0,1057,1056,1,0,0,0,1058,121,1,0,0,0,1059,1060,5,130,0,0,1060, - 1065,3,160,80,0,1061,1062,5,116,0,0,1062,1064,3,160,80,0,1063,1061, - 1,0,0,0,1064,1067,1,0,0,0,1065,1063,1,0,0,0,1065,1066,1,0,0,0,1066, - 1069,1,0,0,0,1067,1065,1,0,0,0,1068,1070,5,116,0,0,1069,1068,1,0, - 0,0,1069,1070,1,0,0,0,1070,1071,1,0,0,0,1071,1072,5,149,0,0,1072, - 1085,1,0,0,0,1073,1078,3,160,80,0,1074,1075,5,116,0,0,1075,1077, - 3,160,80,0,1076,1074,1,0,0,0,1077,1080,1,0,0,0,1078,1076,1,0,0,0, - 1078,1079,1,0,0,0,1079,1082,1,0,0,0,1080,1078,1,0,0,0,1081,1083, - 5,116,0,0,1082,1081,1,0,0,0,1082,1083,1,0,0,0,1083,1085,1,0,0,0, - 1084,1059,1,0,0,0,1084,1073,1,0,0,0,1085,1086,1,0,0,0,1086,1087, - 5,111,0,0,1087,1088,3,116,58,0,1088,123,1,0,0,0,1089,1090,5,132, - 0,0,1090,1094,3,160,80,0,1091,1093,3,126,63,0,1092,1091,1,0,0,0, - 1093,1096,1,0,0,0,1094,1092,1,0,0,0,1094,1095,1,0,0,0,1095,1097, - 1,0,0,0,1096,1094,1,0,0,0,1097,1098,5,151,0,0,1098,1099,5,124,0, - 0,1099,1122,1,0,0,0,1100,1101,5,132,0,0,1101,1105,3,160,80,0,1102, - 1104,3,126,63,0,1103,1102,1,0,0,0,1104,1107,1,0,0,0,1105,1103,1, - 0,0,0,1105,1106,1,0,0,0,1106,1108,1,0,0,0,1107,1105,1,0,0,0,1108, - 1114,5,124,0,0,1109,1115,3,124,62,0,1110,1111,5,128,0,0,1111,1112, - 3,116,58,0,1112,1113,5,147,0,0,1113,1115,1,0,0,0,1114,1109,1,0,0, - 0,1114,1110,1,0,0,0,1114,1115,1,0,0,0,1115,1116,1,0,0,0,1116,1117, - 5,132,0,0,1117,1118,5,151,0,0,1118,1119,3,160,80,0,1119,1120,5,124, - 0,0,1120,1122,1,0,0,0,1121,1089,1,0,0,0,1121,1100,1,0,0,0,1122,125, - 1,0,0,0,1123,1124,3,160,80,0,1124,1125,5,122,0,0,1125,1126,3,166, - 83,0,1126,1135,1,0,0,0,1127,1128,3,160,80,0,1128,1129,5,122,0,0, - 1129,1130,5,128,0,0,1130,1131,3,116,58,0,1131,1132,5,147,0,0,1132, - 1135,1,0,0,0,1133,1135,3,160,80,0,1134,1123,1,0,0,0,1134,1127,1, - 0,0,0,1134,1133,1,0,0,0,1135,127,1,0,0,0,1136,1141,3,130,65,0,1137, - 1138,5,116,0,0,1138,1140,3,130,65,0,1139,1137,1,0,0,0,1140,1143, - 1,0,0,0,1141,1139,1,0,0,0,1141,1142,1,0,0,0,1142,1145,1,0,0,0,1143, - 1141,1,0,0,0,1144,1146,5,116,0,0,1145,1144,1,0,0,0,1145,1146,1,0, - 0,0,1146,129,1,0,0,0,1147,1148,3,160,80,0,1148,1149,5,6,0,0,1149, - 1150,5,130,0,0,1150,1151,3,44,22,0,1151,1152,5,149,0,0,1152,1158, - 1,0,0,0,1153,1154,3,116,58,0,1154,1155,5,6,0,0,1155,1156,3,160,80, - 0,1156,1158,1,0,0,0,1157,1147,1,0,0,0,1157,1153,1,0,0,0,1158,131, - 1,0,0,0,1159,1167,3,164,82,0,1160,1161,3,140,70,0,1161,1162,5,120, - 0,0,1162,1164,1,0,0,0,1163,1160,1,0,0,0,1163,1164,1,0,0,0,1164,1165, - 1,0,0,0,1165,1167,3,134,67,0,1166,1159,1,0,0,0,1166,1163,1,0,0,0, - 1167,133,1,0,0,0,1168,1173,3,160,80,0,1169,1170,5,120,0,0,1170,1172, - 3,160,80,0,1171,1169,1,0,0,0,1172,1175,1,0,0,0,1173,1171,1,0,0,0, - 1173,1174,1,0,0,0,1174,135,1,0,0,0,1175,1173,1,0,0,0,1176,1177,6, - 68,-1,0,1177,1186,3,140,70,0,1178,1186,3,138,69,0,1179,1180,5,130, - 0,0,1180,1181,3,44,22,0,1181,1182,5,149,0,0,1182,1186,1,0,0,0,1183, - 1186,3,124,62,0,1184,1186,3,164,82,0,1185,1176,1,0,0,0,1185,1178, - 1,0,0,0,1185,1179,1,0,0,0,1185,1183,1,0,0,0,1185,1184,1,0,0,0,1186, - 1195,1,0,0,0,1187,1191,10,3,0,0,1188,1192,3,158,79,0,1189,1190,5, - 6,0,0,1190,1192,3,160,80,0,1191,1188,1,0,0,0,1191,1189,1,0,0,0,1192, - 1194,1,0,0,0,1193,1187,1,0,0,0,1194,1197,1,0,0,0,1195,1193,1,0,0, - 0,1195,1196,1,0,0,0,1196,137,1,0,0,0,1197,1195,1,0,0,0,1198,1199, - 3,160,80,0,1199,1201,5,130,0,0,1200,1202,3,142,71,0,1201,1200,1, - 0,0,0,1201,1202,1,0,0,0,1202,1203,1,0,0,0,1203,1204,5,149,0,0,1204, - 139,1,0,0,0,1205,1206,3,144,72,0,1206,1207,5,120,0,0,1207,1209,1, - 0,0,0,1208,1205,1,0,0,0,1208,1209,1,0,0,0,1209,1210,1,0,0,0,1210, - 1211,3,160,80,0,1211,141,1,0,0,0,1212,1217,3,116,58,0,1213,1214, - 5,116,0,0,1214,1216,3,116,58,0,1215,1213,1,0,0,0,1216,1219,1,0,0, - 0,1217,1215,1,0,0,0,1217,1218,1,0,0,0,1218,1221,1,0,0,0,1219,1217, - 1,0,0,0,1220,1222,5,116,0,0,1221,1220,1,0,0,0,1221,1222,1,0,0,0, - 1222,143,1,0,0,0,1223,1224,3,160,80,0,1224,145,1,0,0,0,1225,1234, - 5,106,0,0,1226,1227,5,120,0,0,1227,1234,7,11,0,0,1228,1229,5,108, - 0,0,1229,1231,5,120,0,0,1230,1232,7,11,0,0,1231,1230,1,0,0,0,1231, - 1232,1,0,0,0,1232,1234,1,0,0,0,1233,1225,1,0,0,0,1233,1226,1,0,0, - 0,1233,1228,1,0,0,0,1234,147,1,0,0,0,1235,1237,7,12,0,0,1236,1235, - 1,0,0,0,1236,1237,1,0,0,0,1237,1244,1,0,0,0,1238,1245,3,146,73,0, - 1239,1245,5,107,0,0,1240,1245,5,108,0,0,1241,1245,5,109,0,0,1242, - 1245,5,43,0,0,1243,1245,5,57,0,0,1244,1238,1,0,0,0,1244,1239,1,0, - 0,0,1244,1240,1,0,0,0,1244,1241,1,0,0,0,1244,1242,1,0,0,0,1244,1243, - 1,0,0,0,1245,149,1,0,0,0,1246,1250,3,148,74,0,1247,1250,5,110,0, - 0,1248,1250,5,59,0,0,1249,1246,1,0,0,0,1249,1247,1,0,0,0,1249,1248, - 1,0,0,0,1250,151,1,0,0,0,1251,1252,7,13,0,0,1252,153,1,0,0,0,1253, - 1254,7,14,0,0,1254,155,1,0,0,0,1255,1256,7,15,0,0,1256,157,1,0,0, - 0,1257,1260,5,105,0,0,1258,1260,3,156,78,0,1259,1257,1,0,0,0,1259, - 1258,1,0,0,0,1260,159,1,0,0,0,1261,1265,5,105,0,0,1262,1265,3,152, - 76,0,1263,1265,3,154,77,0,1264,1261,1,0,0,0,1264,1262,1,0,0,0,1264, - 1263,1,0,0,0,1265,161,1,0,0,0,1266,1267,3,166,83,0,1267,1268,5,122, - 0,0,1268,1269,3,148,74,0,1269,163,1,0,0,0,1270,1271,5,128,0,0,1271, - 1272,3,134,67,0,1272,1273,5,147,0,0,1273,165,1,0,0,0,1274,1277,5, - 110,0,0,1275,1277,3,168,84,0,1276,1274,1,0,0,0,1276,1275,1,0,0,0, - 1277,167,1,0,0,0,1278,1282,5,142,0,0,1279,1281,3,170,85,0,1280,1279, - 1,0,0,0,1281,1284,1,0,0,0,1282,1280,1,0,0,0,1282,1283,1,0,0,0,1283, - 1285,1,0,0,0,1284,1282,1,0,0,0,1285,1286,5,144,0,0,1286,169,1,0, - 0,0,1287,1288,5,157,0,0,1288,1289,3,116,58,0,1289,1290,5,147,0,0, - 1290,1293,1,0,0,0,1291,1293,5,156,0,0,1292,1287,1,0,0,0,1292,1291, - 1,0,0,0,1293,171,1,0,0,0,1294,1298,5,143,0,0,1295,1297,3,174,87, - 0,1296,1295,1,0,0,0,1297,1300,1,0,0,0,1298,1296,1,0,0,0,1298,1299, - 1,0,0,0,1299,1301,1,0,0,0,1300,1298,1,0,0,0,1301,1302,5,0,0,1,1302, - 173,1,0,0,0,1303,1304,5,159,0,0,1304,1305,3,116,58,0,1305,1306,5, - 147,0,0,1306,1309,1,0,0,0,1307,1309,5,158,0,0,1308,1303,1,0,0,0, - 1308,1307,1,0,0,0,1309,175,1,0,0,0,168,179,186,195,202,206,220,224, - 227,231,234,241,245,254,259,268,276,283,287,293,298,306,313,319, - 331,339,353,357,362,372,381,384,388,391,395,398,401,404,407,411, - 415,418,421,424,428,431,440,446,467,484,501,507,513,524,526,537, - 540,546,554,560,562,566,571,574,577,581,585,588,590,593,597,601, - 604,606,608,613,624,630,637,642,646,650,656,658,665,673,676,679, - 698,712,728,732,743,747,758,762,769,773,780,784,789,798,802,826, - 843,849,852,855,865,871,874,877,885,888,892,895,909,926,931,935, - 941,948,960,964,967,976,990,1029,1037,1039,1041,1049,1053,1057,1065, - 1069,1078,1082,1084,1094,1105,1114,1121,1134,1141,1145,1157,1163, - 1166,1173,1185,1191,1195,1201,1208,1217,1221,1231,1233,1236,1244, - 1249,1259,1264,1276,1282,1292,1298,1308 + 1,0,0,0,598,600,1,0,0,0,599,601,7,5,0,0,600,599,1,0,0,0,600,601, + 1,0,0,0,601,603,1,0,0,0,602,589,1,0,0,0,602,595,1,0,0,0,603,605, + 1,0,0,0,604,570,1,0,0,0,604,586,1,0,0,0,604,602,1,0,0,0,605,81,1, + 0,0,0,606,607,5,17,0,0,607,610,5,47,0,0,608,610,5,116,0,0,609,606, + 1,0,0,0,609,608,1,0,0,0,610,83,1,0,0,0,611,612,5,62,0,0,612,621, + 3,114,57,0,613,614,5,96,0,0,614,615,5,130,0,0,615,616,3,114,57,0, + 616,617,5,149,0,0,617,621,1,0,0,0,618,619,5,96,0,0,619,621,3,114, + 57,0,620,611,1,0,0,0,620,613,1,0,0,0,620,618,1,0,0,0,621,85,1,0, + 0,0,622,623,5,77,0,0,623,626,3,92,46,0,624,625,5,61,0,0,625,627, + 3,92,46,0,626,624,1,0,0,0,626,627,1,0,0,0,627,87,1,0,0,0,628,633, + 3,90,45,0,629,630,5,116,0,0,630,632,3,90,45,0,631,629,1,0,0,0,632, + 635,1,0,0,0,633,631,1,0,0,0,633,634,1,0,0,0,634,89,1,0,0,0,635,633, + 1,0,0,0,636,638,3,116,58,0,637,639,7,6,0,0,638,637,1,0,0,0,638,639, + 1,0,0,0,639,642,1,0,0,0,640,641,5,60,0,0,641,643,7,7,0,0,642,640, + 1,0,0,0,642,643,1,0,0,0,643,646,1,0,0,0,644,645,5,16,0,0,645,647, + 5,110,0,0,646,644,1,0,0,0,646,647,1,0,0,0,647,91,1,0,0,0,648,655, + 3,160,80,0,649,652,3,144,72,0,650,651,5,151,0,0,651,653,3,144,72, + 0,652,650,1,0,0,0,652,653,1,0,0,0,653,655,1,0,0,0,654,648,1,0,0, + 0,654,649,1,0,0,0,655,93,1,0,0,0,656,661,3,96,48,0,657,658,5,116, + 0,0,658,660,3,96,48,0,659,657,1,0,0,0,660,663,1,0,0,0,661,659,1, + 0,0,0,661,662,1,0,0,0,662,95,1,0,0,0,663,661,1,0,0,0,664,665,3,156, + 78,0,665,666,5,122,0,0,666,667,3,146,73,0,667,97,1,0,0,0,668,670, + 3,100,50,0,669,668,1,0,0,0,669,670,1,0,0,0,670,672,1,0,0,0,671,673, + 3,102,51,0,672,671,1,0,0,0,672,673,1,0,0,0,673,675,1,0,0,0,674,676, + 3,104,52,0,675,674,1,0,0,0,675,676,1,0,0,0,676,99,1,0,0,0,677,678, + 5,67,0,0,678,679,5,11,0,0,679,680,3,114,57,0,680,101,1,0,0,0,681, + 682,5,64,0,0,682,683,5,11,0,0,683,684,3,88,44,0,684,103,1,0,0,0, + 685,686,7,8,0,0,686,687,3,106,53,0,687,105,1,0,0,0,688,695,3,108, + 54,0,689,690,5,9,0,0,690,691,3,108,54,0,691,692,5,2,0,0,692,693, + 3,108,54,0,693,695,1,0,0,0,694,688,1,0,0,0,694,689,1,0,0,0,695,107, + 1,0,0,0,696,697,5,19,0,0,697,709,5,75,0,0,698,699,5,94,0,0,699,709, + 5,68,0,0,700,701,5,94,0,0,701,709,5,32,0,0,702,703,3,144,72,0,703, + 704,5,68,0,0,704,709,1,0,0,0,705,706,3,144,72,0,706,707,5,32,0,0, + 707,709,1,0,0,0,708,696,1,0,0,0,708,698,1,0,0,0,708,700,1,0,0,0, + 708,702,1,0,0,0,708,705,1,0,0,0,709,109,1,0,0,0,710,711,3,116,58, + 0,711,712,5,0,0,1,712,111,1,0,0,0,713,770,3,156,78,0,714,715,3,156, + 78,0,715,716,5,130,0,0,716,717,3,156,78,0,717,724,3,112,56,0,718, + 719,5,116,0,0,719,720,3,156,78,0,720,721,3,112,56,0,721,723,1,0, + 0,0,722,718,1,0,0,0,723,726,1,0,0,0,724,722,1,0,0,0,724,725,1,0, + 0,0,725,728,1,0,0,0,726,724,1,0,0,0,727,729,5,116,0,0,728,727,1, + 0,0,0,728,729,1,0,0,0,729,730,1,0,0,0,730,731,5,149,0,0,731,770, + 1,0,0,0,732,733,3,156,78,0,733,734,5,130,0,0,734,739,3,158,79,0, + 735,736,5,116,0,0,736,738,3,158,79,0,737,735,1,0,0,0,738,741,1,0, + 0,0,739,737,1,0,0,0,739,740,1,0,0,0,740,743,1,0,0,0,741,739,1,0, + 0,0,742,744,5,116,0,0,743,742,1,0,0,0,743,744,1,0,0,0,744,745,1, + 0,0,0,745,746,5,149,0,0,746,770,1,0,0,0,747,748,3,156,78,0,748,749, + 5,130,0,0,749,754,3,112,56,0,750,751,5,116,0,0,751,753,3,112,56, + 0,752,750,1,0,0,0,753,756,1,0,0,0,754,752,1,0,0,0,754,755,1,0,0, + 0,755,758,1,0,0,0,756,754,1,0,0,0,757,759,5,116,0,0,758,757,1,0, + 0,0,758,759,1,0,0,0,759,760,1,0,0,0,760,761,5,149,0,0,761,770,1, + 0,0,0,762,763,3,156,78,0,763,765,5,130,0,0,764,766,3,114,57,0,765, + 764,1,0,0,0,765,766,1,0,0,0,766,767,1,0,0,0,767,768,5,149,0,0,768, + 770,1,0,0,0,769,713,1,0,0,0,769,714,1,0,0,0,769,732,1,0,0,0,769, + 747,1,0,0,0,769,762,1,0,0,0,770,113,1,0,0,0,771,776,3,116,58,0,772, + 773,5,116,0,0,773,775,3,116,58,0,774,772,1,0,0,0,775,778,1,0,0,0, + 776,774,1,0,0,0,776,777,1,0,0,0,777,780,1,0,0,0,778,776,1,0,0,0, + 779,781,5,116,0,0,780,779,1,0,0,0,780,781,1,0,0,0,781,115,1,0,0, + 0,782,783,6,58,-1,0,783,785,5,12,0,0,784,786,3,116,58,0,785,784, + 1,0,0,0,785,786,1,0,0,0,786,792,1,0,0,0,787,788,5,98,0,0,788,789, + 3,116,58,0,789,790,5,83,0,0,790,791,3,116,58,0,791,793,1,0,0,0,792, + 787,1,0,0,0,793,794,1,0,0,0,794,792,1,0,0,0,794,795,1,0,0,0,795, + 798,1,0,0,0,796,797,5,25,0,0,797,799,3,116,58,0,798,796,1,0,0,0, + 798,799,1,0,0,0,799,800,1,0,0,0,800,801,5,26,0,0,801,933,1,0,0,0, + 802,803,5,13,0,0,803,804,5,130,0,0,804,805,3,116,58,0,805,806,5, + 6,0,0,806,807,3,112,56,0,807,808,5,149,0,0,808,933,1,0,0,0,809,810, + 5,20,0,0,810,933,5,110,0,0,811,812,5,45,0,0,812,813,3,116,58,0,813, + 814,3,148,74,0,814,933,1,0,0,0,815,816,5,82,0,0,816,817,5,130,0, + 0,817,818,3,116,58,0,818,819,5,34,0,0,819,822,3,116,58,0,820,821, + 5,33,0,0,821,823,3,116,58,0,822,820,1,0,0,0,822,823,1,0,0,0,823, + 824,1,0,0,0,824,825,5,149,0,0,825,933,1,0,0,0,826,827,5,86,0,0,827, + 933,5,110,0,0,828,829,5,91,0,0,829,830,5,130,0,0,830,831,7,9,0,0, + 831,832,3,162,81,0,832,833,5,34,0,0,833,834,3,116,58,0,834,835,5, + 149,0,0,835,933,1,0,0,0,836,837,3,156,78,0,837,839,5,130,0,0,838, + 840,3,114,57,0,839,838,1,0,0,0,839,840,1,0,0,0,840,841,1,0,0,0,841, + 842,5,149,0,0,842,851,1,0,0,0,843,845,5,130,0,0,844,846,5,24,0,0, + 845,844,1,0,0,0,845,846,1,0,0,0,846,848,1,0,0,0,847,849,3,114,57, + 0,848,847,1,0,0,0,848,849,1,0,0,0,849,850,1,0,0,0,850,852,5,149, + 0,0,851,843,1,0,0,0,851,852,1,0,0,0,852,853,1,0,0,0,853,854,5,66, + 0,0,854,855,5,130,0,0,855,856,3,98,49,0,856,857,5,149,0,0,857,933, + 1,0,0,0,858,859,3,156,78,0,859,861,5,130,0,0,860,862,3,114,57,0, + 861,860,1,0,0,0,861,862,1,0,0,0,862,863,1,0,0,0,863,864,5,149,0, + 0,864,873,1,0,0,0,865,867,5,130,0,0,866,868,5,24,0,0,867,866,1,0, + 0,0,867,868,1,0,0,0,868,870,1,0,0,0,869,871,3,114,57,0,870,869,1, + 0,0,0,870,871,1,0,0,0,871,872,1,0,0,0,872,874,5,149,0,0,873,865, + 1,0,0,0,873,874,1,0,0,0,874,875,1,0,0,0,875,876,5,66,0,0,876,877, + 3,156,78,0,877,933,1,0,0,0,878,884,3,156,78,0,879,881,5,130,0,0, + 880,882,3,114,57,0,881,880,1,0,0,0,881,882,1,0,0,0,882,883,1,0,0, + 0,883,885,5,149,0,0,884,879,1,0,0,0,884,885,1,0,0,0,885,886,1,0, + 0,0,886,888,5,130,0,0,887,889,5,24,0,0,888,887,1,0,0,0,888,889,1, + 0,0,0,889,891,1,0,0,0,890,892,3,114,57,0,891,890,1,0,0,0,891,892, + 1,0,0,0,892,893,1,0,0,0,893,894,5,149,0,0,894,933,1,0,0,0,895,933, + 3,120,60,0,896,933,3,164,82,0,897,933,3,146,73,0,898,899,5,118,0, + 0,899,933,3,116,58,20,900,901,5,58,0,0,901,933,3,116,58,14,902,903, + 3,136,68,0,903,904,5,120,0,0,904,906,1,0,0,0,905,902,1,0,0,0,905, + 906,1,0,0,0,906,907,1,0,0,0,907,933,5,112,0,0,908,909,5,130,0,0, + 909,910,3,44,22,0,910,911,5,149,0,0,911,933,1,0,0,0,912,913,5,130, + 0,0,913,914,3,116,58,0,914,915,5,149,0,0,915,933,1,0,0,0,916,917, + 5,130,0,0,917,918,3,114,57,0,918,919,5,149,0,0,919,933,1,0,0,0,920, + 922,5,129,0,0,921,923,3,114,57,0,922,921,1,0,0,0,922,923,1,0,0,0, + 923,924,1,0,0,0,924,933,5,148,0,0,925,927,5,128,0,0,926,928,3,40, + 20,0,927,926,1,0,0,0,927,928,1,0,0,0,928,929,1,0,0,0,929,933,5,147, + 0,0,930,933,3,118,59,0,931,933,3,128,64,0,932,782,1,0,0,0,932,802, + 1,0,0,0,932,809,1,0,0,0,932,811,1,0,0,0,932,815,1,0,0,0,932,826, + 1,0,0,0,932,828,1,0,0,0,932,836,1,0,0,0,932,858,1,0,0,0,932,878, + 1,0,0,0,932,895,1,0,0,0,932,896,1,0,0,0,932,897,1,0,0,0,932,898, + 1,0,0,0,932,900,1,0,0,0,932,905,1,0,0,0,932,908,1,0,0,0,932,912, + 1,0,0,0,932,916,1,0,0,0,932,920,1,0,0,0,932,925,1,0,0,0,932,930, + 1,0,0,0,932,931,1,0,0,0,933,1044,1,0,0,0,934,938,10,19,0,0,935,939, + 5,112,0,0,936,939,5,151,0,0,937,939,5,138,0,0,938,935,1,0,0,0,938, + 936,1,0,0,0,938,937,1,0,0,0,939,940,1,0,0,0,940,1043,3,116,58,20, + 941,945,10,18,0,0,942,946,5,139,0,0,943,946,5,118,0,0,944,946,5, + 117,0,0,945,942,1,0,0,0,945,943,1,0,0,0,945,944,1,0,0,0,946,947, + 1,0,0,0,947,1043,3,116,58,19,948,973,10,17,0,0,949,974,5,121,0,0, + 950,974,5,122,0,0,951,974,5,133,0,0,952,974,5,131,0,0,953,974,5, + 132,0,0,954,974,5,123,0,0,955,974,5,124,0,0,956,958,5,58,0,0,957, + 956,1,0,0,0,957,958,1,0,0,0,958,959,1,0,0,0,959,961,5,42,0,0,960, + 962,5,15,0,0,961,960,1,0,0,0,961,962,1,0,0,0,962,974,1,0,0,0,963, + 965,5,58,0,0,964,963,1,0,0,0,964,965,1,0,0,0,965,966,1,0,0,0,966, + 974,7,10,0,0,967,974,5,145,0,0,968,974,5,146,0,0,969,974,5,135,0, + 0,970,974,5,126,0,0,971,974,5,127,0,0,972,974,5,134,0,0,973,949, + 1,0,0,0,973,950,1,0,0,0,973,951,1,0,0,0,973,952,1,0,0,0,973,953, + 1,0,0,0,973,954,1,0,0,0,973,955,1,0,0,0,973,957,1,0,0,0,973,964, + 1,0,0,0,973,967,1,0,0,0,973,968,1,0,0,0,973,969,1,0,0,0,973,970, + 1,0,0,0,973,971,1,0,0,0,973,972,1,0,0,0,974,975,1,0,0,0,975,1043, + 3,116,58,18,976,977,10,15,0,0,977,978,5,137,0,0,978,1043,3,116,58, + 16,979,980,10,13,0,0,980,981,5,2,0,0,981,1043,3,116,58,14,982,983, + 10,12,0,0,983,984,5,63,0,0,984,1043,3,116,58,13,985,987,10,11,0, + 0,986,988,5,58,0,0,987,986,1,0,0,0,987,988,1,0,0,0,988,989,1,0,0, + 0,989,990,5,9,0,0,990,991,3,116,58,0,991,992,5,2,0,0,992,993,3,116, + 58,12,993,1043,1,0,0,0,994,995,10,10,0,0,995,996,5,140,0,0,996,997, + 3,116,58,0,997,998,5,115,0,0,998,999,3,116,58,10,999,1043,1,0,0, + 0,1000,1001,10,30,0,0,1001,1003,5,130,0,0,1002,1004,3,114,57,0,1003, + 1002,1,0,0,0,1003,1004,1,0,0,0,1004,1005,1,0,0,0,1005,1043,5,149, + 0,0,1006,1007,10,26,0,0,1007,1008,5,129,0,0,1008,1009,3,116,58,0, + 1009,1010,5,148,0,0,1010,1043,1,0,0,0,1011,1012,10,25,0,0,1012,1013, + 5,120,0,0,1013,1043,5,108,0,0,1014,1015,10,24,0,0,1015,1016,5,120, + 0,0,1016,1043,3,156,78,0,1017,1018,10,23,0,0,1018,1019,5,136,0,0, + 1019,1020,5,129,0,0,1020,1021,3,116,58,0,1021,1022,5,148,0,0,1022, + 1043,1,0,0,0,1023,1024,10,22,0,0,1024,1025,5,136,0,0,1025,1043,5, + 108,0,0,1026,1027,10,21,0,0,1027,1028,5,136,0,0,1028,1043,3,156, + 78,0,1029,1030,10,16,0,0,1030,1032,5,46,0,0,1031,1033,5,58,0,0,1032, + 1031,1,0,0,0,1032,1033,1,0,0,0,1033,1034,1,0,0,0,1034,1043,5,59, + 0,0,1035,1040,10,9,0,0,1036,1037,5,6,0,0,1037,1041,3,156,78,0,1038, + 1039,5,6,0,0,1039,1041,5,110,0,0,1040,1036,1,0,0,0,1040,1038,1,0, + 0,0,1041,1043,1,0,0,0,1042,934,1,0,0,0,1042,941,1,0,0,0,1042,948, + 1,0,0,0,1042,976,1,0,0,0,1042,979,1,0,0,0,1042,982,1,0,0,0,1042, + 985,1,0,0,0,1042,994,1,0,0,0,1042,1000,1,0,0,0,1042,1006,1,0,0,0, + 1042,1011,1,0,0,0,1042,1014,1,0,0,0,1042,1017,1,0,0,0,1042,1023, + 1,0,0,0,1042,1026,1,0,0,0,1042,1029,1,0,0,0,1042,1035,1,0,0,0,1043, + 1046,1,0,0,0,1044,1042,1,0,0,0,1044,1045,1,0,0,0,1045,117,1,0,0, + 0,1046,1044,1,0,0,0,1047,1048,5,130,0,0,1048,1053,3,156,78,0,1049, + 1050,5,116,0,0,1050,1052,3,156,78,0,1051,1049,1,0,0,0,1052,1055, + 1,0,0,0,1053,1051,1,0,0,0,1053,1054,1,0,0,0,1054,1057,1,0,0,0,1055, + 1053,1,0,0,0,1056,1058,5,116,0,0,1057,1056,1,0,0,0,1057,1058,1,0, + 0,0,1058,1059,1,0,0,0,1059,1060,5,149,0,0,1060,1075,1,0,0,0,1061, + 1066,3,156,78,0,1062,1063,5,116,0,0,1063,1065,3,156,78,0,1064,1062, + 1,0,0,0,1065,1068,1,0,0,0,1066,1064,1,0,0,0,1066,1067,1,0,0,0,1067, + 1070,1,0,0,0,1068,1066,1,0,0,0,1069,1071,5,116,0,0,1070,1069,1,0, + 0,0,1070,1071,1,0,0,0,1071,1075,1,0,0,0,1072,1073,5,130,0,0,1073, + 1075,5,149,0,0,1074,1047,1,0,0,0,1074,1061,1,0,0,0,1074,1072,1,0, + 0,0,1075,1076,1,0,0,0,1076,1079,5,111,0,0,1077,1080,3,116,58,0,1078, + 1080,3,36,18,0,1079,1077,1,0,0,0,1079,1078,1,0,0,0,1080,119,1,0, + 0,0,1081,1082,5,132,0,0,1082,1086,3,156,78,0,1083,1085,3,122,61, + 0,1084,1083,1,0,0,0,1085,1088,1,0,0,0,1086,1084,1,0,0,0,1086,1087, + 1,0,0,0,1087,1089,1,0,0,0,1088,1086,1,0,0,0,1089,1090,5,151,0,0, + 1090,1091,5,124,0,0,1091,1114,1,0,0,0,1092,1093,5,132,0,0,1093,1097, + 3,156,78,0,1094,1096,3,122,61,0,1095,1094,1,0,0,0,1096,1099,1,0, + 0,0,1097,1095,1,0,0,0,1097,1098,1,0,0,0,1098,1100,1,0,0,0,1099,1097, + 1,0,0,0,1100,1106,5,124,0,0,1101,1107,3,120,60,0,1102,1103,5,128, + 0,0,1103,1104,3,116,58,0,1104,1105,5,147,0,0,1105,1107,1,0,0,0,1106, + 1101,1,0,0,0,1106,1102,1,0,0,0,1106,1107,1,0,0,0,1107,1108,1,0,0, + 0,1108,1109,5,132,0,0,1109,1110,5,151,0,0,1110,1111,3,156,78,0,1111, + 1112,5,124,0,0,1112,1114,1,0,0,0,1113,1081,1,0,0,0,1113,1092,1,0, + 0,0,1114,121,1,0,0,0,1115,1116,3,156,78,0,1116,1117,5,122,0,0,1117, + 1118,3,162,81,0,1118,1127,1,0,0,0,1119,1120,3,156,78,0,1120,1121, + 5,122,0,0,1121,1122,5,128,0,0,1122,1123,3,116,58,0,1123,1124,5,147, + 0,0,1124,1127,1,0,0,0,1125,1127,3,156,78,0,1126,1115,1,0,0,0,1126, + 1119,1,0,0,0,1126,1125,1,0,0,0,1127,123,1,0,0,0,1128,1133,3,126, + 63,0,1129,1130,5,116,0,0,1130,1132,3,126,63,0,1131,1129,1,0,0,0, + 1132,1135,1,0,0,0,1133,1131,1,0,0,0,1133,1134,1,0,0,0,1134,1137, + 1,0,0,0,1135,1133,1,0,0,0,1136,1138,5,116,0,0,1137,1136,1,0,0,0, + 1137,1138,1,0,0,0,1138,125,1,0,0,0,1139,1140,3,156,78,0,1140,1141, + 5,6,0,0,1141,1142,5,130,0,0,1142,1143,3,44,22,0,1143,1144,5,149, + 0,0,1144,1150,1,0,0,0,1145,1146,3,116,58,0,1146,1147,5,6,0,0,1147, + 1148,3,156,78,0,1148,1150,1,0,0,0,1149,1139,1,0,0,0,1149,1145,1, + 0,0,0,1150,127,1,0,0,0,1151,1159,3,160,80,0,1152,1153,3,136,68,0, + 1153,1154,5,120,0,0,1154,1156,1,0,0,0,1155,1152,1,0,0,0,1155,1156, + 1,0,0,0,1156,1157,1,0,0,0,1157,1159,3,130,65,0,1158,1151,1,0,0,0, + 1158,1155,1,0,0,0,1159,129,1,0,0,0,1160,1165,3,156,78,0,1161,1162, + 5,120,0,0,1162,1164,3,156,78,0,1163,1161,1,0,0,0,1164,1167,1,0,0, + 0,1165,1163,1,0,0,0,1165,1166,1,0,0,0,1166,131,1,0,0,0,1167,1165, + 1,0,0,0,1168,1169,6,66,-1,0,1169,1178,3,136,68,0,1170,1178,3,134, + 67,0,1171,1172,5,130,0,0,1172,1173,3,44,22,0,1173,1174,5,149,0,0, + 1174,1178,1,0,0,0,1175,1178,3,120,60,0,1176,1178,3,160,80,0,1177, + 1168,1,0,0,0,1177,1170,1,0,0,0,1177,1171,1,0,0,0,1177,1175,1,0,0, + 0,1177,1176,1,0,0,0,1178,1187,1,0,0,0,1179,1183,10,3,0,0,1180,1184, + 3,154,77,0,1181,1182,5,6,0,0,1182,1184,3,156,78,0,1183,1180,1,0, + 0,0,1183,1181,1,0,0,0,1184,1186,1,0,0,0,1185,1179,1,0,0,0,1186,1189, + 1,0,0,0,1187,1185,1,0,0,0,1187,1188,1,0,0,0,1188,133,1,0,0,0,1189, + 1187,1,0,0,0,1190,1191,3,156,78,0,1191,1193,5,130,0,0,1192,1194, + 3,138,69,0,1193,1192,1,0,0,0,1193,1194,1,0,0,0,1194,1195,1,0,0,0, + 1195,1196,5,149,0,0,1196,135,1,0,0,0,1197,1198,3,140,70,0,1198,1199, + 5,120,0,0,1199,1201,1,0,0,0,1200,1197,1,0,0,0,1200,1201,1,0,0,0, + 1201,1202,1,0,0,0,1202,1203,3,156,78,0,1203,137,1,0,0,0,1204,1209, + 3,116,58,0,1205,1206,5,116,0,0,1206,1208,3,116,58,0,1207,1205,1, + 0,0,0,1208,1211,1,0,0,0,1209,1207,1,0,0,0,1209,1210,1,0,0,0,1210, + 1213,1,0,0,0,1211,1209,1,0,0,0,1212,1214,5,116,0,0,1213,1212,1,0, + 0,0,1213,1214,1,0,0,0,1214,139,1,0,0,0,1215,1216,3,156,78,0,1216, + 141,1,0,0,0,1217,1226,5,106,0,0,1218,1219,5,120,0,0,1219,1226,7, + 11,0,0,1220,1221,5,108,0,0,1221,1223,5,120,0,0,1222,1224,7,11,0, + 0,1223,1222,1,0,0,0,1223,1224,1,0,0,0,1224,1226,1,0,0,0,1225,1217, + 1,0,0,0,1225,1218,1,0,0,0,1225,1220,1,0,0,0,1226,143,1,0,0,0,1227, + 1229,7,12,0,0,1228,1227,1,0,0,0,1228,1229,1,0,0,0,1229,1236,1,0, + 0,0,1230,1237,3,142,71,0,1231,1237,5,107,0,0,1232,1237,5,108,0,0, + 1233,1237,5,109,0,0,1234,1237,5,43,0,0,1235,1237,5,57,0,0,1236,1230, + 1,0,0,0,1236,1231,1,0,0,0,1236,1232,1,0,0,0,1236,1233,1,0,0,0,1236, + 1234,1,0,0,0,1236,1235,1,0,0,0,1237,145,1,0,0,0,1238,1242,3,144, + 72,0,1239,1242,5,110,0,0,1240,1242,5,59,0,0,1241,1238,1,0,0,0,1241, + 1239,1,0,0,0,1241,1240,1,0,0,0,1242,147,1,0,0,0,1243,1244,7,13,0, + 0,1244,149,1,0,0,0,1245,1246,7,14,0,0,1246,151,1,0,0,0,1247,1248, + 7,15,0,0,1248,153,1,0,0,0,1249,1252,5,105,0,0,1250,1252,3,152,76, + 0,1251,1249,1,0,0,0,1251,1250,1,0,0,0,1252,155,1,0,0,0,1253,1257, + 5,105,0,0,1254,1257,3,148,74,0,1255,1257,3,150,75,0,1256,1253,1, + 0,0,0,1256,1254,1,0,0,0,1256,1255,1,0,0,0,1257,157,1,0,0,0,1258, + 1259,3,162,81,0,1259,1260,5,122,0,0,1260,1261,3,144,72,0,1261,159, + 1,0,0,0,1262,1263,5,128,0,0,1263,1264,3,130,65,0,1264,1265,5,147, + 0,0,1265,161,1,0,0,0,1266,1269,5,110,0,0,1267,1269,3,164,82,0,1268, + 1266,1,0,0,0,1268,1267,1,0,0,0,1269,163,1,0,0,0,1270,1274,5,142, + 0,0,1271,1273,3,166,83,0,1272,1271,1,0,0,0,1273,1276,1,0,0,0,1274, + 1272,1,0,0,0,1274,1275,1,0,0,0,1275,1277,1,0,0,0,1276,1274,1,0,0, + 0,1277,1278,5,144,0,0,1278,165,1,0,0,0,1279,1280,5,157,0,0,1280, + 1281,3,116,58,0,1281,1282,5,147,0,0,1282,1285,1,0,0,0,1283,1285, + 5,156,0,0,1284,1279,1,0,0,0,1284,1283,1,0,0,0,1285,167,1,0,0,0,1286, + 1290,5,143,0,0,1287,1289,3,170,85,0,1288,1287,1,0,0,0,1289,1292, + 1,0,0,0,1290,1288,1,0,0,0,1290,1291,1,0,0,0,1291,1293,1,0,0,0,1292, + 1290,1,0,0,0,1293,1294,5,0,0,1,1294,169,1,0,0,0,1295,1296,5,159, + 0,0,1296,1297,3,116,58,0,1297,1298,5,147,0,0,1298,1301,1,0,0,0,1299, + 1301,5,158,0,0,1300,1295,1,0,0,0,1300,1299,1,0,0,0,1301,171,1,0, + 0,0,167,175,182,191,198,202,216,220,223,227,230,237,241,250,255, + 264,272,279,283,289,294,302,309,315,327,335,349,353,358,368,377, + 380,384,387,391,394,397,400,403,407,411,414,417,420,424,427,436, + 442,463,480,497,503,509,520,522,533,536,542,550,556,558,562,567, + 570,573,577,581,584,586,589,593,597,600,602,604,609,620,626,633, + 638,642,646,652,654,661,669,672,675,694,708,724,728,739,743,754, + 758,765,769,776,780,785,794,798,822,839,845,848,851,861,867,870, + 873,881,884,888,891,905,922,927,932,938,945,957,961,964,973,987, + 1003,1032,1040,1042,1044,1053,1057,1066,1070,1074,1079,1086,1097, + 1106,1113,1126,1133,1137,1149,1155,1158,1165,1177,1183,1187,1193, + 1200,1209,1213,1223,1225,1228,1236,1241,1251,1256,1268,1274,1284, + 1290,1300 ] class HogQLParser ( Parser ): @@ -675,35 +674,33 @@ class HogQLParser ( Parser ): RULE_columnTypeExpr = 56 RULE_columnExprList = 57 RULE_columnExpr = 58 - RULE_columnArgList = 59 - RULE_columnArgExpr = 60 - RULE_columnLambdaExpr = 61 - RULE_hogqlxTagElement = 62 - RULE_hogqlxTagAttribute = 63 - RULE_withExprList = 64 - RULE_withExpr = 65 - RULE_columnIdentifier = 66 - RULE_nestedIdentifier = 67 - RULE_tableExpr = 68 - RULE_tableFunctionExpr = 69 - RULE_tableIdentifier = 70 - RULE_tableArgList = 71 - RULE_databaseIdentifier = 72 - RULE_floatingLiteral = 73 - RULE_numberLiteral = 74 - RULE_literal = 75 - RULE_interval = 76 - RULE_keyword = 77 - RULE_keywordForAlias = 78 - RULE_alias = 79 - RULE_identifier = 80 - RULE_enumValue = 81 - RULE_placeholder = 82 - RULE_string = 83 - RULE_templateString = 84 - RULE_stringContents = 85 - RULE_fullTemplateString = 86 - RULE_stringContentsFull = 87 + RULE_columnLambdaExpr = 59 + RULE_hogqlxTagElement = 60 + RULE_hogqlxTagAttribute = 61 + RULE_withExprList = 62 + RULE_withExpr = 63 + RULE_columnIdentifier = 64 + RULE_nestedIdentifier = 65 + RULE_tableExpr = 66 + RULE_tableFunctionExpr = 67 + RULE_tableIdentifier = 68 + RULE_tableArgList = 69 + RULE_databaseIdentifier = 70 + RULE_floatingLiteral = 71 + RULE_numberLiteral = 72 + RULE_literal = 73 + RULE_interval = 74 + RULE_keyword = 75 + RULE_keywordForAlias = 76 + RULE_alias = 77 + RULE_identifier = 78 + RULE_enumValue = 79 + RULE_placeholder = 80 + RULE_string = 81 + RULE_templateString = 82 + RULE_stringContents = 83 + RULE_fullTemplateString = 84 + RULE_stringContentsFull = 85 ruleNames = [ "program", "declaration", "expression", "varDecl", "identifierList", "statement", "returnStmt", "throwStmt", "catchBlock", @@ -720,12 +717,11 @@ class HogQLParser ( Parser ): "windowExpr", "winPartitionByClause", "winOrderByClause", "winFrameClause", "winFrameExtend", "winFrameBound", "expr", "columnTypeExpr", "columnExprList", "columnExpr", - "columnArgList", "columnArgExpr", "columnLambdaExpr", - "hogqlxTagElement", "hogqlxTagAttribute", "withExprList", - "withExpr", "columnIdentifier", "nestedIdentifier", "tableExpr", - "tableFunctionExpr", "tableIdentifier", "tableArgList", - "databaseIdentifier", "floatingLiteral", "numberLiteral", - "literal", "interval", "keyword", "keywordForAlias", + "columnLambdaExpr", "hogqlxTagElement", "hogqlxTagAttribute", + "withExprList", "withExpr", "columnIdentifier", "nestedIdentifier", + "tableExpr", "tableFunctionExpr", "tableIdentifier", + "tableArgList", "databaseIdentifier", "floatingLiteral", + "numberLiteral", "literal", "interval", "keyword", "keywordForAlias", "alias", "identifier", "enumValue", "placeholder", "string", "templateString", "stringContents", "fullTemplateString", "stringContentsFull" ] @@ -893,7 +889,7 @@ class HogQLParser ( Parser ): def __init__(self, input:TokenStream, output:TextIO = sys.stdout): super().__init__(input, output) - self.checkVersion("4.13.1") + self.checkVersion("4.13.2") self._interp = ParserATNSimulator(self, self.atn, self.decisionsToDFA, self.sharedContextCache) self._predicates = None @@ -936,17 +932,17 @@ def program(self): self._la = 0 # Token type try: self.enterOuterAlt(localctx, 1) - self.state = 179 + self.state = 175 self._errHandler.sync(self) _la = self._input.LA(1) while (((_la) & ~0x3f) == 0 and ((1 << _la) & -536887298) != 0) or ((((_la - 64)) & ~0x3f) == 0 and ((1 << (_la - 64)) & 90493105500848127) != 0) or ((((_la - 128)) & ~0x3f) == 0 and ((1 << (_la - 128)) & 4212759) != 0): - self.state = 176 + self.state = 172 self.declaration() - self.state = 181 + self.state = 177 self._errHandler.sync(self) _la = self._input.LA(1) - self.state = 182 + self.state = 178 self.match(HogQLParser.EOF) except RecognitionException as re: localctx.exception = re @@ -989,17 +985,17 @@ def declaration(self): localctx = HogQLParser.DeclarationContext(self, self._ctx, self.state) self.enterRule(localctx, 2, self.RULE_declaration) try: - self.state = 186 + self.state = 182 self._errHandler.sync(self) token = self._input.LA(1) if token in [52]: self.enterOuterAlt(localctx, 1) - self.state = 184 + self.state = 180 self.varDecl() pass elif token in [1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45, 46, 47, 48, 49, 50, 51, 53, 54, 55, 56, 57, 58, 59, 60, 61, 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 81, 82, 83, 84, 85, 86, 87, 88, 89, 90, 91, 92, 93, 94, 95, 96, 97, 98, 99, 100, 101, 102, 103, 105, 106, 107, 108, 109, 110, 112, 118, 120, 128, 129, 130, 132, 139, 142, 150]: self.enterOuterAlt(localctx, 2) - self.state = 185 + self.state = 181 self.statement() pass else: @@ -1043,7 +1039,7 @@ def expression(self): self.enterRule(localctx, 4, self.RULE_expression) try: self.enterOuterAlt(localctx, 1) - self.state = 188 + self.state = 184 self.columnExpr(0) except RecognitionException as re: localctx.exception = re @@ -1097,19 +1093,19 @@ def varDecl(self): self._la = 0 # Token type try: self.enterOuterAlt(localctx, 1) - self.state = 190 + self.state = 186 self.match(HogQLParser.LET) - self.state = 191 + self.state = 187 self.identifier() - self.state = 195 + self.state = 191 self._errHandler.sync(self) _la = self._input.LA(1) if _la==115: - self.state = 192 + self.state = 188 self.match(HogQLParser.COLON) - self.state = 193 + self.state = 189 self.match(HogQLParser.EQ_SINGLE) - self.state = 194 + self.state = 190 self.expression() @@ -1161,26 +1157,26 @@ def identifierList(self): self._la = 0 # Token type try: self.enterOuterAlt(localctx, 1) - self.state = 197 + self.state = 193 self.identifier() - self.state = 202 + self.state = 198 self._errHandler.sync(self) _alt = self._interp.adaptivePredict(self._input,3,self._ctx) while _alt!=2 and _alt!=ATN.INVALID_ALT_NUMBER: if _alt==1: - self.state = 198 + self.state = 194 self.match(HogQLParser.COMMA) - self.state = 199 + self.state = 195 self.identifier() - self.state = 204 + self.state = 200 self._errHandler.sync(self) _alt = self._interp.adaptivePredict(self._input,3,self._ctx) - self.state = 206 + self.state = 202 self._errHandler.sync(self) _la = self._input.LA(1) if _la==116: - self.state = 205 + self.state = 201 self.match(HogQLParser.COMMA) @@ -1265,78 +1261,78 @@ def statement(self): localctx = HogQLParser.StatementContext(self, self._ctx, self.state) self.enterRule(localctx, 10, self.RULE_statement) try: - self.state = 220 + self.state = 216 self._errHandler.sync(self) la_ = self._interp.adaptivePredict(self._input,5,self._ctx) if la_ == 1: self.enterOuterAlt(localctx, 1) - self.state = 208 + self.state = 204 self.returnStmt() pass elif la_ == 2: self.enterOuterAlt(localctx, 2) - self.state = 209 + self.state = 205 self.throwStmt() pass elif la_ == 3: self.enterOuterAlt(localctx, 3) - self.state = 210 + self.state = 206 self.tryCatchStmt() pass elif la_ == 4: self.enterOuterAlt(localctx, 4) - self.state = 211 + self.state = 207 self.ifStmt() pass elif la_ == 5: self.enterOuterAlt(localctx, 5) - self.state = 212 + self.state = 208 self.whileStmt() pass elif la_ == 6: self.enterOuterAlt(localctx, 6) - self.state = 213 + self.state = 209 self.forInStmt() pass elif la_ == 7: self.enterOuterAlt(localctx, 7) - self.state = 214 + self.state = 210 self.forStmt() pass elif la_ == 8: self.enterOuterAlt(localctx, 8) - self.state = 215 + self.state = 211 self.funcStmt() pass elif la_ == 9: self.enterOuterAlt(localctx, 9) - self.state = 216 + self.state = 212 self.varAssignment() pass elif la_ == 10: self.enterOuterAlt(localctx, 10) - self.state = 217 + self.state = 213 self.block() pass elif la_ == 11: self.enterOuterAlt(localctx, 11) - self.state = 218 + self.state = 214 self.exprStmt() pass elif la_ == 12: self.enterOuterAlt(localctx, 12) - self.state = 219 + self.state = 215 self.emptyStmt() pass @@ -1385,21 +1381,21 @@ def returnStmt(self): self.enterRule(localctx, 12, self.RULE_returnStmt) try: self.enterOuterAlt(localctx, 1) - self.state = 222 + self.state = 218 self.match(HogQLParser.RETURN) - self.state = 224 + self.state = 220 self._errHandler.sync(self) la_ = self._interp.adaptivePredict(self._input,6,self._ctx) if la_ == 1: - self.state = 223 + self.state = 219 self.expression() - self.state = 227 + self.state = 223 self._errHandler.sync(self) la_ = self._interp.adaptivePredict(self._input,7,self._ctx) if la_ == 1: - self.state = 226 + self.state = 222 self.match(HogQLParser.SEMICOLON) @@ -1447,21 +1443,21 @@ def throwStmt(self): self.enterRule(localctx, 14, self.RULE_throwStmt) try: self.enterOuterAlt(localctx, 1) - self.state = 229 + self.state = 225 self.match(HogQLParser.THROW) - self.state = 231 + self.state = 227 self._errHandler.sync(self) la_ = self._interp.adaptivePredict(self._input,8,self._ctx) if la_ == 1: - self.state = 230 + self.state = 226 self.expression() - self.state = 234 + self.state = 230 self._errHandler.sync(self) la_ = self._interp.adaptivePredict(self._input,9,self._ctx) if la_ == 1: - self.state = 233 + self.state = 229 self.match(HogQLParser.SEMICOLON) @@ -1526,31 +1522,31 @@ def catchBlock(self): self._la = 0 # Token type try: self.enterOuterAlt(localctx, 1) - self.state = 236 + self.state = 232 self.match(HogQLParser.CATCH) - self.state = 245 + self.state = 241 self._errHandler.sync(self) _la = self._input.LA(1) if _la==130: - self.state = 237 + self.state = 233 self.match(HogQLParser.LPAREN) - self.state = 238 + self.state = 234 localctx.catchVar = self.identifier() - self.state = 241 + self.state = 237 self._errHandler.sync(self) _la = self._input.LA(1) if _la==115: - self.state = 239 + self.state = 235 self.match(HogQLParser.COLON) - self.state = 240 + self.state = 236 localctx.catchType = self.identifier() - self.state = 243 + self.state = 239 self.match(HogQLParser.RPAREN) - self.state = 247 + self.state = 243 localctx.catchStmt = self.block() except RecognitionException as re: localctx.exception = re @@ -1609,27 +1605,27 @@ def tryCatchStmt(self): self._la = 0 # Token type try: self.enterOuterAlt(localctx, 1) - self.state = 249 + self.state = 245 self.match(HogQLParser.TRY) - self.state = 250 + self.state = 246 localctx.tryStmt = self.block() - self.state = 254 + self.state = 250 self._errHandler.sync(self) _la = self._input.LA(1) while _la==14: - self.state = 251 + self.state = 247 self.catchBlock() - self.state = 256 + self.state = 252 self._errHandler.sync(self) _la = self._input.LA(1) - self.state = 259 + self.state = 255 self._errHandler.sync(self) _la = self._input.LA(1) if _la==29: - self.state = 257 + self.state = 253 self.match(HogQLParser.FINALLY) - self.state = 258 + self.state = 254 localctx.finallyStmt = self.block() @@ -1690,23 +1686,23 @@ def ifStmt(self): self.enterRule(localctx, 20, self.RULE_ifStmt) try: self.enterOuterAlt(localctx, 1) - self.state = 261 + self.state = 257 self.match(HogQLParser.IF) - self.state = 262 + self.state = 258 self.match(HogQLParser.LPAREN) - self.state = 263 + self.state = 259 self.expression() - self.state = 264 + self.state = 260 self.match(HogQLParser.RPAREN) - self.state = 265 + self.state = 261 self.statement() - self.state = 268 + self.state = 264 self._errHandler.sync(self) la_ = self._interp.adaptivePredict(self._input,14,self._ctx) if la_ == 1: - self.state = 266 + self.state = 262 self.match(HogQLParser.ELSE) - self.state = 267 + self.state = 263 self.statement() @@ -1764,21 +1760,21 @@ def whileStmt(self): self.enterRule(localctx, 22, self.RULE_whileStmt) try: self.enterOuterAlt(localctx, 1) - self.state = 270 + self.state = 266 self.match(HogQLParser.WHILE) - self.state = 271 + self.state = 267 self.match(HogQLParser.LPAREN) - self.state = 272 + self.state = 268 self.expression() - self.state = 273 + self.state = 269 self.match(HogQLParser.RPAREN) - self.state = 274 + self.state = 270 self.statement() - self.state = 276 + self.state = 272 self._errHandler.sync(self) la_ = self._interp.adaptivePredict(self._input,15,self._ctx) if la_ == 1: - self.state = 275 + self.state = 271 self.match(HogQLParser.SEMICOLON) @@ -1864,63 +1860,63 @@ def forStmt(self): self._la = 0 # Token type try: self.enterOuterAlt(localctx, 1) - self.state = 278 + self.state = 274 self.match(HogQLParser.FOR) - self.state = 279 + self.state = 275 self.match(HogQLParser.LPAREN) - self.state = 283 + self.state = 279 self._errHandler.sync(self) la_ = self._interp.adaptivePredict(self._input,16,self._ctx) if la_ == 1: - self.state = 280 + self.state = 276 localctx.initializerVarDeclr = self.varDecl() elif la_ == 2: - self.state = 281 + self.state = 277 localctx.initializerVarAssignment = self.varAssignment() elif la_ == 3: - self.state = 282 + self.state = 278 localctx.initializerExpression = self.expression() - self.state = 285 + self.state = 281 self.match(HogQLParser.SEMICOLON) - self.state = 287 + self.state = 283 self._errHandler.sync(self) _la = self._input.LA(1) if (((_la) & ~0x3f) == 0 and ((1 << _la) & -4503602311741442) != 0) or ((((_la - 64)) & ~0x3f) == 0 and ((1 << (_la - 64)) & 90493036243451903) != 0) or ((((_la - 128)) & ~0x3f) == 0 and ((1 << (_la - 128)) & 18455) != 0): - self.state = 286 + self.state = 282 localctx.condition = self.expression() - self.state = 289 + self.state = 285 self.match(HogQLParser.SEMICOLON) - self.state = 293 + self.state = 289 self._errHandler.sync(self) la_ = self._interp.adaptivePredict(self._input,18,self._ctx) if la_ == 1: - self.state = 290 + self.state = 286 localctx.incrementVarDeclr = self.varDecl() elif la_ == 2: - self.state = 291 + self.state = 287 localctx.incrementVarAssignment = self.varAssignment() elif la_ == 3: - self.state = 292 + self.state = 288 localctx.incrementExpression = self.expression() - self.state = 295 + self.state = 291 self.match(HogQLParser.RPAREN) - self.state = 296 + self.state = 292 self.statement() - self.state = 298 + self.state = 294 self._errHandler.sync(self) la_ = self._interp.adaptivePredict(self._input,19,self._ctx) if la_ == 1: - self.state = 297 + self.state = 293 self.match(HogQLParser.SEMICOLON) @@ -1995,37 +1991,37 @@ def forInStmt(self): self._la = 0 # Token type try: self.enterOuterAlt(localctx, 1) - self.state = 300 + self.state = 296 self.match(HogQLParser.FOR) - self.state = 301 + self.state = 297 self.match(HogQLParser.LPAREN) - self.state = 302 + self.state = 298 self.match(HogQLParser.LET) - self.state = 303 + self.state = 299 self.identifier() - self.state = 306 + self.state = 302 self._errHandler.sync(self) _la = self._input.LA(1) if _la==116: - self.state = 304 + self.state = 300 self.match(HogQLParser.COMMA) - self.state = 305 + self.state = 301 self.identifier() - self.state = 308 + self.state = 304 self.match(HogQLParser.IN) - self.state = 309 + self.state = 305 self.expression() - self.state = 310 + self.state = 306 self.match(HogQLParser.RPAREN) - self.state = 311 + self.state = 307 self.statement() - self.state = 313 + self.state = 309 self._errHandler.sync(self) la_ = self._interp.adaptivePredict(self._input,21,self._ctx) if la_ == 1: - self.state = 312 + self.state = 308 self.match(HogQLParser.SEMICOLON) @@ -2085,23 +2081,23 @@ def funcStmt(self): self._la = 0 # Token type try: self.enterOuterAlt(localctx, 1) - self.state = 315 + self.state = 311 self.match(HogQLParser.FN) - self.state = 316 + self.state = 312 self.identifier() - self.state = 317 + self.state = 313 self.match(HogQLParser.LPAREN) - self.state = 319 + self.state = 315 self._errHandler.sync(self) _la = self._input.LA(1) if (((_la) & ~0x3f) == 0 and ((1 << _la) & -725088338784043010) != 0) or ((((_la - 64)) & ~0x3f) == 0 and ((1 << (_la - 64)) & 3229277487103) != 0): - self.state = 318 + self.state = 314 self.identifierList() - self.state = 321 + self.state = 317 self.match(HogQLParser.RPAREN) - self.state = 322 + self.state = 318 self.block() except RecognitionException as re: localctx.exception = re @@ -2150,13 +2146,13 @@ def varAssignment(self): self.enterRule(localctx, 30, self.RULE_varAssignment) try: self.enterOuterAlt(localctx, 1) - self.state = 324 + self.state = 320 self.expression() - self.state = 325 + self.state = 321 self.match(HogQLParser.COLON) - self.state = 326 + self.state = 322 self.match(HogQLParser.EQ_SINGLE) - self.state = 327 + self.state = 323 self.expression() except RecognitionException as re: localctx.exception = re @@ -2199,13 +2195,13 @@ def exprStmt(self): self.enterRule(localctx, 32, self.RULE_exprStmt) try: self.enterOuterAlt(localctx, 1) - self.state = 329 + self.state = 325 self.expression() - self.state = 331 + self.state = 327 self._errHandler.sync(self) la_ = self._interp.adaptivePredict(self._input,23,self._ctx) if la_ == 1: - self.state = 330 + self.state = 326 self.match(HogQLParser.SEMICOLON) @@ -2246,7 +2242,7 @@ def emptyStmt(self): self.enterRule(localctx, 34, self.RULE_emptyStmt) try: self.enterOuterAlt(localctx, 1) - self.state = 333 + self.state = 329 self.match(HogQLParser.SEMICOLON) except RecognitionException as re: localctx.exception = re @@ -2296,19 +2292,19 @@ def block(self): self._la = 0 # Token type try: self.enterOuterAlt(localctx, 1) - self.state = 335 + self.state = 331 self.match(HogQLParser.LBRACE) - self.state = 339 + self.state = 335 self._errHandler.sync(self) _la = self._input.LA(1) while (((_la) & ~0x3f) == 0 and ((1 << _la) & -536887298) != 0) or ((((_la - 64)) & ~0x3f) == 0 and ((1 << (_la - 64)) & 90493105500848127) != 0) or ((((_la - 128)) & ~0x3f) == 0 and ((1 << (_la - 128)) & 4212759) != 0): - self.state = 336 + self.state = 332 self.declaration() - self.state = 341 + self.state = 337 self._errHandler.sync(self) _la = self._input.LA(1) - self.state = 342 + self.state = 338 self.match(HogQLParser.RBRACE) except RecognitionException as re: localctx.exception = re @@ -2354,11 +2350,11 @@ def kvPair(self): self.enterRule(localctx, 38, self.RULE_kvPair) try: self.enterOuterAlt(localctx, 1) - self.state = 344 + self.state = 340 self.expression() - self.state = 345 + self.state = 341 self.match(HogQLParser.COLON) - self.state = 346 + self.state = 342 self.expression() except RecognitionException as re: localctx.exception = re @@ -2408,26 +2404,26 @@ def kvPairList(self): self._la = 0 # Token type try: self.enterOuterAlt(localctx, 1) - self.state = 348 + self.state = 344 self.kvPair() - self.state = 353 + self.state = 349 self._errHandler.sync(self) _alt = self._interp.adaptivePredict(self._input,25,self._ctx) while _alt!=2 and _alt!=ATN.INVALID_ALT_NUMBER: if _alt==1: - self.state = 349 + self.state = 345 self.match(HogQLParser.COMMA) - self.state = 350 + self.state = 346 self.kvPair() - self.state = 355 + self.state = 351 self._errHandler.sync(self) _alt = self._interp.adaptivePredict(self._input,25,self._ctx) - self.state = 357 + self.state = 353 self._errHandler.sync(self) _la = self._input.LA(1) if _la==116: - self.state = 356 + self.state = 352 self.match(HogQLParser.COMMA) @@ -2480,26 +2476,26 @@ def select(self): self.enterRule(localctx, 42, self.RULE_select) try: self.enterOuterAlt(localctx, 1) - self.state = 362 + self.state = 358 self._errHandler.sync(self) la_ = self._interp.adaptivePredict(self._input,27,self._ctx) if la_ == 1: - self.state = 359 + self.state = 355 self.selectUnionStmt() pass elif la_ == 2: - self.state = 360 + self.state = 356 self.selectStmt() pass elif la_ == 3: - self.state = 361 + self.state = 357 self.hogqlxTagElement() pass - self.state = 364 + self.state = 360 self.match(HogQLParser.EOF) except RecognitionException as re: localctx.exception = re @@ -2555,19 +2551,19 @@ def selectUnionStmt(self): self._la = 0 # Token type try: self.enterOuterAlt(localctx, 1) - self.state = 366 + self.state = 362 self.selectStmtWithParens() - self.state = 372 + self.state = 368 self._errHandler.sync(self) _la = self._input.LA(1) while _la==95: - self.state = 367 + self.state = 363 self.match(HogQLParser.UNION) - self.state = 368 + self.state = 364 self.match(HogQLParser.ALL) - self.state = 369 + self.state = 365 self.selectStmtWithParens() - self.state = 374 + self.state = 370 self._errHandler.sync(self) _la = self._input.LA(1) @@ -2622,26 +2618,26 @@ def selectStmtWithParens(self): localctx = HogQLParser.SelectStmtWithParensContext(self, self._ctx, self.state) self.enterRule(localctx, 46, self.RULE_selectStmtWithParens) try: - self.state = 381 + self.state = 377 self._errHandler.sync(self) token = self._input.LA(1) if token in [79, 102]: self.enterOuterAlt(localctx, 1) - self.state = 375 + self.state = 371 self.selectStmt() pass elif token in [130]: self.enterOuterAlt(localctx, 2) - self.state = 376 + self.state = 372 self.match(HogQLParser.LPAREN) - self.state = 377 + self.state = 373 self.selectUnionStmt() - self.state = 378 + self.state = 374 self.match(HogQLParser.RPAREN) pass elif token in [128]: self.enterOuterAlt(localctx, 3) - self.state = 380 + self.state = 376 self.placeholder() pass else: @@ -2763,81 +2759,81 @@ def selectStmt(self): self._la = 0 # Token type try: self.enterOuterAlt(localctx, 1) - self.state = 384 + self.state = 380 self._errHandler.sync(self) _la = self._input.LA(1) if _la==102: - self.state = 383 + self.state = 379 localctx.with_ = self.withClause() - self.state = 386 + self.state = 382 self.match(HogQLParser.SELECT) - self.state = 388 + self.state = 384 self._errHandler.sync(self) la_ = self._interp.adaptivePredict(self._input,31,self._ctx) if la_ == 1: - self.state = 387 + self.state = 383 self.match(HogQLParser.DISTINCT) - self.state = 391 + self.state = 387 self._errHandler.sync(self) la_ = self._interp.adaptivePredict(self._input,32,self._ctx) if la_ == 1: - self.state = 390 + self.state = 386 self.topClause() - self.state = 393 + self.state = 389 localctx.columns = self.columnExprList() - self.state = 395 + self.state = 391 self._errHandler.sync(self) _la = self._input.LA(1) if _la==34: - self.state = 394 + self.state = 390 localctx.from_ = self.fromClause() - self.state = 398 + self.state = 394 self._errHandler.sync(self) _la = self._input.LA(1) if (((_la) & ~0x3f) == 0 and ((1 << _la) & 2269391999729696) != 0): - self.state = 397 + self.state = 393 self.arrayJoinClause() - self.state = 401 + self.state = 397 self._errHandler.sync(self) _la = self._input.LA(1) if _la==69: - self.state = 400 + self.state = 396 self.prewhereClause() - self.state = 404 + self.state = 400 self._errHandler.sync(self) _la = self._input.LA(1) if _la==99: - self.state = 403 + self.state = 399 localctx.where = self.whereClause() - self.state = 407 + self.state = 403 self._errHandler.sync(self) _la = self._input.LA(1) if _la==36: - self.state = 406 + self.state = 402 self.groupByClause() - self.state = 411 + self.state = 407 self._errHandler.sync(self) la_ = self._interp.adaptivePredict(self._input,38,self._ctx) if la_ == 1: - self.state = 409 + self.state = 405 self.match(HogQLParser.WITH) - self.state = 410 + self.state = 406 _la = self._input.LA(1) if not(_la==18 or _la==74): self._errHandler.recoverInline(self) @@ -2846,60 +2842,60 @@ def selectStmt(self): self.consume() - self.state = 415 + self.state = 411 self._errHandler.sync(self) _la = self._input.LA(1) if _la==102: - self.state = 413 + self.state = 409 self.match(HogQLParser.WITH) - self.state = 414 + self.state = 410 self.match(HogQLParser.TOTALS) - self.state = 418 + self.state = 414 self._errHandler.sync(self) _la = self._input.LA(1) if _la==37: - self.state = 417 + self.state = 413 self.havingClause() - self.state = 421 + self.state = 417 self._errHandler.sync(self) _la = self._input.LA(1) if _la==101: - self.state = 420 + self.state = 416 self.windowClause() - self.state = 424 + self.state = 420 self._errHandler.sync(self) _la = self._input.LA(1) if _la==64: - self.state = 423 + self.state = 419 self.orderByClause() - self.state = 428 + self.state = 424 self._errHandler.sync(self) token = self._input.LA(1) if token in [54]: - self.state = 426 + self.state = 422 self.limitAndOffsetClause() pass elif token in [61]: - self.state = 427 + self.state = 423 self.offsetOnlyClause() pass elif token in [-1, 81, 95, 149]: pass else: pass - self.state = 431 + self.state = 427 self._errHandler.sync(self) _la = self._input.LA(1) if _la==81: - self.state = 430 + self.state = 426 self.settingsClause() @@ -2944,9 +2940,9 @@ def withClause(self): self.enterRule(localctx, 50, self.RULE_withClause) try: self.enterOuterAlt(localctx, 1) - self.state = 433 + self.state = 429 self.match(HogQLParser.WITH) - self.state = 434 + self.state = 430 self.withExprList() except RecognitionException as re: localctx.exception = re @@ -2994,17 +2990,17 @@ def topClause(self): self.enterRule(localctx, 52, self.RULE_topClause) try: self.enterOuterAlt(localctx, 1) - self.state = 436 + self.state = 432 self.match(HogQLParser.TOP) - self.state = 437 + self.state = 433 self.match(HogQLParser.DECIMAL_LITERAL) - self.state = 440 + self.state = 436 self._errHandler.sync(self) la_ = self._interp.adaptivePredict(self._input,45,self._ctx) if la_ == 1: - self.state = 438 + self.state = 434 self.match(HogQLParser.WITH) - self.state = 439 + self.state = 435 self.match(HogQLParser.TIES) @@ -3049,9 +3045,9 @@ def fromClause(self): self.enterRule(localctx, 54, self.RULE_fromClause) try: self.enterOuterAlt(localctx, 1) - self.state = 442 + self.state = 438 self.match(HogQLParser.FROM) - self.state = 443 + self.state = 439 self.joinExpr(0) except RecognitionException as re: localctx.exception = re @@ -3104,11 +3100,11 @@ def arrayJoinClause(self): self._la = 0 # Token type try: self.enterOuterAlt(localctx, 1) - self.state = 446 + self.state = 442 self._errHandler.sync(self) _la = self._input.LA(1) if _la==44 or _la==51: - self.state = 445 + self.state = 441 _la = self._input.LA(1) if not(_la==44 or _la==51): self._errHandler.recoverInline(self) @@ -3117,11 +3113,11 @@ def arrayJoinClause(self): self.consume() - self.state = 448 + self.state = 444 self.match(HogQLParser.ARRAY) - self.state = 449 + self.state = 445 self.match(HogQLParser.JOIN) - self.state = 450 + self.state = 446 self.columnExprList() except RecognitionException as re: localctx.exception = re @@ -3199,35 +3195,35 @@ def windowClause(self): self._la = 0 # Token type try: self.enterOuterAlt(localctx, 1) - self.state = 452 + self.state = 448 self.match(HogQLParser.WINDOW) - self.state = 453 + self.state = 449 self.identifier() - self.state = 454 + self.state = 450 self.match(HogQLParser.AS) - self.state = 455 + self.state = 451 self.match(HogQLParser.LPAREN) - self.state = 456 + self.state = 452 self.windowExpr() - self.state = 457 + self.state = 453 self.match(HogQLParser.RPAREN) - self.state = 467 + self.state = 463 self._errHandler.sync(self) _la = self._input.LA(1) while _la==116: - self.state = 458 + self.state = 454 self.match(HogQLParser.COMMA) - self.state = 459 + self.state = 455 self.identifier() - self.state = 460 + self.state = 456 self.match(HogQLParser.AS) - self.state = 461 + self.state = 457 self.match(HogQLParser.LPAREN) - self.state = 462 + self.state = 458 self.windowExpr() - self.state = 463 + self.state = 459 self.match(HogQLParser.RPAREN) - self.state = 469 + self.state = 465 self._errHandler.sync(self) _la = self._input.LA(1) @@ -3272,9 +3268,9 @@ def prewhereClause(self): self.enterRule(localctx, 60, self.RULE_prewhereClause) try: self.enterOuterAlt(localctx, 1) - self.state = 470 + self.state = 466 self.match(HogQLParser.PREWHERE) - self.state = 471 + self.state = 467 self.columnExpr(0) except RecognitionException as re: localctx.exception = re @@ -3317,9 +3313,9 @@ def whereClause(self): self.enterRule(localctx, 62, self.RULE_whereClause) try: self.enterOuterAlt(localctx, 1) - self.state = 473 + self.state = 469 self.match(HogQLParser.WHERE) - self.state = 474 + self.state = 470 self.columnExpr(0) except RecognitionException as re: localctx.exception = re @@ -3378,31 +3374,31 @@ def groupByClause(self): self._la = 0 # Token type try: self.enterOuterAlt(localctx, 1) - self.state = 476 + self.state = 472 self.match(HogQLParser.GROUP) - self.state = 477 + self.state = 473 self.match(HogQLParser.BY) - self.state = 484 + self.state = 480 self._errHandler.sync(self) la_ = self._interp.adaptivePredict(self._input,48,self._ctx) if la_ == 1: - self.state = 478 + self.state = 474 _la = self._input.LA(1) if not(_la==18 or _la==74): self._errHandler.recoverInline(self) else: self._errHandler.reportMatch(self) self.consume() - self.state = 479 + self.state = 475 self.match(HogQLParser.LPAREN) - self.state = 480 + self.state = 476 self.columnExprList() - self.state = 481 + self.state = 477 self.match(HogQLParser.RPAREN) pass elif la_ == 2: - self.state = 483 + self.state = 479 self.columnExprList() pass @@ -3448,9 +3444,9 @@ def havingClause(self): self.enterRule(localctx, 66, self.RULE_havingClause) try: self.enterOuterAlt(localctx, 1) - self.state = 486 + self.state = 482 self.match(HogQLParser.HAVING) - self.state = 487 + self.state = 483 self.columnExpr(0) except RecognitionException as re: localctx.exception = re @@ -3496,11 +3492,11 @@ def orderByClause(self): self.enterRule(localctx, 68, self.RULE_orderByClause) try: self.enterOuterAlt(localctx, 1) - self.state = 489 + self.state = 485 self.match(HogQLParser.ORDER) - self.state = 490 + self.state = 486 self.match(HogQLParser.BY) - self.state = 491 + self.state = 487 self.orderExprList() except RecognitionException as re: localctx.exception = re @@ -3546,11 +3542,11 @@ def projectionOrderByClause(self): self.enterRule(localctx, 70, self.RULE_projectionOrderByClause) try: self.enterOuterAlt(localctx, 1) - self.state = 493 + self.state = 489 self.match(HogQLParser.ORDER) - self.state = 494 + self.state = 490 self.match(HogQLParser.BY) - self.state = 495 + self.state = 491 self.columnExprList() except RecognitionException as re: localctx.exception = re @@ -3615,38 +3611,38 @@ def limitAndOffsetClause(self): self.enterRule(localctx, 72, self.RULE_limitAndOffsetClause) self._la = 0 # Token type try: - self.state = 526 + self.state = 522 self._errHandler.sync(self) la_ = self._interp.adaptivePredict(self._input,53,self._ctx) if la_ == 1: self.enterOuterAlt(localctx, 1) - self.state = 497 + self.state = 493 self.match(HogQLParser.LIMIT) - self.state = 498 + self.state = 494 self.columnExpr(0) - self.state = 501 + self.state = 497 self._errHandler.sync(self) _la = self._input.LA(1) if _la==116: - self.state = 499 + self.state = 495 self.match(HogQLParser.COMMA) - self.state = 500 + self.state = 496 self.columnExpr(0) - self.state = 507 + self.state = 503 self._errHandler.sync(self) token = self._input.LA(1) if token in [102]: - self.state = 503 + self.state = 499 self.match(HogQLParser.WITH) - self.state = 504 + self.state = 500 self.match(HogQLParser.TIES) pass elif token in [11]: - self.state = 505 + self.state = 501 self.match(HogQLParser.BY) - self.state = 506 + self.state = 502 self.columnExprList() pass elif token in [-1, 81, 95, 149]: @@ -3657,43 +3653,43 @@ def limitAndOffsetClause(self): elif la_ == 2: self.enterOuterAlt(localctx, 2) - self.state = 509 + self.state = 505 self.match(HogQLParser.LIMIT) - self.state = 510 + self.state = 506 self.columnExpr(0) - self.state = 513 + self.state = 509 self._errHandler.sync(self) _la = self._input.LA(1) if _la==102: - self.state = 511 + self.state = 507 self.match(HogQLParser.WITH) - self.state = 512 + self.state = 508 self.match(HogQLParser.TIES) - self.state = 515 + self.state = 511 self.match(HogQLParser.OFFSET) - self.state = 516 + self.state = 512 self.columnExpr(0) pass elif la_ == 3: self.enterOuterAlt(localctx, 3) - self.state = 518 + self.state = 514 self.match(HogQLParser.LIMIT) - self.state = 519 + self.state = 515 self.columnExpr(0) - self.state = 520 + self.state = 516 self.match(HogQLParser.OFFSET) - self.state = 521 + self.state = 517 self.columnExpr(0) - self.state = 524 + self.state = 520 self._errHandler.sync(self) _la = self._input.LA(1) if _la==11: - self.state = 522 + self.state = 518 self.match(HogQLParser.BY) - self.state = 523 + self.state = 519 self.columnExprList() @@ -3741,9 +3737,9 @@ def offsetOnlyClause(self): self.enterRule(localctx, 74, self.RULE_offsetOnlyClause) try: self.enterOuterAlt(localctx, 1) - self.state = 528 + self.state = 524 self.match(HogQLParser.OFFSET) - self.state = 529 + self.state = 525 self.columnExpr(0) except RecognitionException as re: localctx.exception = re @@ -3786,9 +3782,9 @@ def settingsClause(self): self.enterRule(localctx, 76, self.RULE_settingsClause) try: self.enterOuterAlt(localctx, 1) - self.state = 531 + self.state = 527 self.match(HogQLParser.SETTINGS) - self.state = 532 + self.state = 528 self.settingExprList() except RecognitionException as re: localctx.exception = re @@ -3920,7 +3916,7 @@ def joinExpr(self, _p:int=0): self._la = 0 # Token type try: self.enterOuterAlt(localctx, 1) - self.state = 546 + self.state = 542 self._errHandler.sync(self) la_ = self._interp.adaptivePredict(self._input,56,self._ctx) if la_ == 1: @@ -3928,21 +3924,21 @@ def joinExpr(self, _p:int=0): self._ctx = localctx _prevctx = localctx - self.state = 535 + self.state = 531 self.tableExpr(0) - self.state = 537 + self.state = 533 self._errHandler.sync(self) la_ = self._interp.adaptivePredict(self._input,54,self._ctx) if la_ == 1: - self.state = 536 + self.state = 532 self.match(HogQLParser.FINAL) - self.state = 540 + self.state = 536 self._errHandler.sync(self) la_ = self._interp.adaptivePredict(self._input,55,self._ctx) if la_ == 1: - self.state = 539 + self.state = 535 self.sampleClause() @@ -3952,17 +3948,17 @@ def joinExpr(self, _p:int=0): localctx = HogQLParser.JoinExprParensContext(self, localctx) self._ctx = localctx _prevctx = localctx - self.state = 542 + self.state = 538 self.match(HogQLParser.LPAREN) - self.state = 543 + self.state = 539 self.joinExpr(0) - self.state = 544 + self.state = 540 self.match(HogQLParser.RPAREN) pass self._ctx.stop = self._input.LT(-1) - self.state = 562 + self.state = 558 self._errHandler.sync(self) _alt = self._interp.adaptivePredict(self._input,59,self._ctx) while _alt!=2 and _alt!=ATN.INVALID_ALT_NUMBER: @@ -3970,47 +3966,47 @@ def joinExpr(self, _p:int=0): if self._parseListeners is not None: self.triggerExitRuleEvent() _prevctx = localctx - self.state = 560 + self.state = 556 self._errHandler.sync(self) la_ = self._interp.adaptivePredict(self._input,58,self._ctx) if la_ == 1: localctx = HogQLParser.JoinExprCrossOpContext(self, HogQLParser.JoinExprContext(self, _parentctx, _parentState)) self.pushNewRecursionContext(localctx, _startState, self.RULE_joinExpr) - self.state = 548 + self.state = 544 if not self.precpred(self._ctx, 3): from antlr4.error.Errors import FailedPredicateException raise FailedPredicateException(self, "self.precpred(self._ctx, 3)") - self.state = 549 + self.state = 545 self.joinOpCross() - self.state = 550 + self.state = 546 self.joinExpr(4) pass elif la_ == 2: localctx = HogQLParser.JoinExprOpContext(self, HogQLParser.JoinExprContext(self, _parentctx, _parentState)) self.pushNewRecursionContext(localctx, _startState, self.RULE_joinExpr) - self.state = 552 + self.state = 548 if not self.precpred(self._ctx, 4): from antlr4.error.Errors import FailedPredicateException raise FailedPredicateException(self, "self.precpred(self._ctx, 4)") - self.state = 554 + self.state = 550 self._errHandler.sync(self) _la = self._input.LA(1) if (((_la) & ~0x3f) == 0 and ((1 << _la) & 2269426359468314) != 0) or _la==73 or _la==80: - self.state = 553 + self.state = 549 self.joinOp() - self.state = 556 + self.state = 552 self.match(HogQLParser.JOIN) - self.state = 557 + self.state = 553 self.joinExpr(0) - self.state = 558 + self.state = 554 self.joinConstraintClause() pass - self.state = 564 + self.state = 560 self._errHandler.sync(self) _alt = self._interp.adaptivePredict(self._input,59,self._ctx) @@ -4121,21 +4117,21 @@ def joinOp(self): self.enterRule(localctx, 80, self.RULE_joinOp) self._la = 0 # Token type try: - self.state = 608 + self.state = 604 self._errHandler.sync(self) la_ = self._interp.adaptivePredict(self._input,73,self._ctx) if la_ == 1: localctx = HogQLParser.JoinOpInnerContext(self, localctx) self.enterOuterAlt(localctx, 1) - self.state = 574 + self.state = 570 self._errHandler.sync(self) la_ = self._interp.adaptivePredict(self._input,62,self._ctx) if la_ == 1: - self.state = 566 + self.state = 562 self._errHandler.sync(self) _la = self._input.LA(1) if (((_la) & ~0x3f) == 0 and ((1 << _la) & 274) != 0): - self.state = 565 + self.state = 561 _la = self._input.LA(1) if not((((_la) & ~0x3f) == 0 and ((1 << _la) & 274) != 0)): self._errHandler.recoverInline(self) @@ -4144,18 +4140,18 @@ def joinOp(self): self.consume() - self.state = 568 + self.state = 564 self.match(HogQLParser.INNER) pass elif la_ == 2: - self.state = 569 + self.state = 565 self.match(HogQLParser.INNER) - self.state = 571 + self.state = 567 self._errHandler.sync(self) _la = self._input.LA(1) if (((_la) & ~0x3f) == 0 and ((1 << _la) & 274) != 0): - self.state = 570 + self.state = 566 _la = self._input.LA(1) if not((((_la) & ~0x3f) == 0 and ((1 << _la) & 274) != 0)): self._errHandler.recoverInline(self) @@ -4167,7 +4163,7 @@ def joinOp(self): pass elif la_ == 3: - self.state = 573 + self.state = 569 _la = self._input.LA(1) if not((((_la) & ~0x3f) == 0 and ((1 << _la) & 274) != 0)): self._errHandler.recoverInline(self) @@ -4182,15 +4178,15 @@ def joinOp(self): elif la_ == 2: localctx = HogQLParser.JoinOpLeftRightContext(self, localctx) self.enterOuterAlt(localctx, 2) - self.state = 590 + self.state = 586 self._errHandler.sync(self) la_ = self._interp.adaptivePredict(self._input,67,self._ctx) if la_ == 1: - self.state = 577 + self.state = 573 self._errHandler.sync(self) _la = self._input.LA(1) if (((_la) & ~0x3f) == 0 and ((1 << _la) & 282) != 0) or _la==80: - self.state = 576 + self.state = 572 _la = self._input.LA(1) if not((((_la) & ~0x3f) == 0 and ((1 << _la) & 282) != 0) or _la==80): self._errHandler.recoverInline(self) @@ -4199,44 +4195,44 @@ def joinOp(self): self.consume() - self.state = 579 + self.state = 575 _la = self._input.LA(1) if not(_la==51 or _la==73): self._errHandler.recoverInline(self) else: self._errHandler.reportMatch(self) self.consume() - self.state = 581 + self.state = 577 self._errHandler.sync(self) _la = self._input.LA(1) if _la==65: - self.state = 580 + self.state = 576 self.match(HogQLParser.OUTER) pass elif la_ == 2: - self.state = 583 + self.state = 579 _la = self._input.LA(1) if not(_la==51 or _la==73): self._errHandler.recoverInline(self) else: self._errHandler.reportMatch(self) self.consume() - self.state = 585 + self.state = 581 self._errHandler.sync(self) _la = self._input.LA(1) if _la==65: - self.state = 584 + self.state = 580 self.match(HogQLParser.OUTER) - self.state = 588 + self.state = 584 self._errHandler.sync(self) _la = self._input.LA(1) if (((_la) & ~0x3f) == 0 and ((1 << _la) & 282) != 0) or _la==80: - self.state = 587 + self.state = 583 _la = self._input.LA(1) if not((((_la) & ~0x3f) == 0 and ((1 << _la) & 282) != 0) or _la==80): self._errHandler.recoverInline(self) @@ -4253,15 +4249,15 @@ def joinOp(self): elif la_ == 3: localctx = HogQLParser.JoinOpFullContext(self, localctx) self.enterOuterAlt(localctx, 3) - self.state = 606 + self.state = 602 self._errHandler.sync(self) la_ = self._interp.adaptivePredict(self._input,72,self._ctx) if la_ == 1: - self.state = 593 + self.state = 589 self._errHandler.sync(self) _la = self._input.LA(1) if _la==1 or _la==4: - self.state = 592 + self.state = 588 _la = self._input.LA(1) if not(_la==1 or _la==4): self._errHandler.recoverInline(self) @@ -4270,34 +4266,34 @@ def joinOp(self): self.consume() - self.state = 595 + self.state = 591 self.match(HogQLParser.FULL) - self.state = 597 + self.state = 593 self._errHandler.sync(self) _la = self._input.LA(1) if _la==65: - self.state = 596 + self.state = 592 self.match(HogQLParser.OUTER) pass elif la_ == 2: - self.state = 599 + self.state = 595 self.match(HogQLParser.FULL) - self.state = 601 + self.state = 597 self._errHandler.sync(self) _la = self._input.LA(1) if _la==65: - self.state = 600 + self.state = 596 self.match(HogQLParser.OUTER) - self.state = 604 + self.state = 600 self._errHandler.sync(self) _la = self._input.LA(1) if _la==1 or _la==4: - self.state = 603 + self.state = 599 _la = self._input.LA(1) if not(_la==1 or _la==4): self._errHandler.recoverInline(self) @@ -4354,19 +4350,19 @@ def joinOpCross(self): localctx = HogQLParser.JoinOpCrossContext(self, self._ctx, self.state) self.enterRule(localctx, 82, self.RULE_joinOpCross) try: - self.state = 613 + self.state = 609 self._errHandler.sync(self) token = self._input.LA(1) if token in [17]: self.enterOuterAlt(localctx, 1) - self.state = 610 + self.state = 606 self.match(HogQLParser.CROSS) - self.state = 611 + self.state = 607 self.match(HogQLParser.JOIN) pass elif token in [116]: self.enterOuterAlt(localctx, 2) - self.state = 612 + self.state = 608 self.match(HogQLParser.COMMA) pass else: @@ -4421,34 +4417,34 @@ def joinConstraintClause(self): localctx = HogQLParser.JoinConstraintClauseContext(self, self._ctx, self.state) self.enterRule(localctx, 84, self.RULE_joinConstraintClause) try: - self.state = 624 + self.state = 620 self._errHandler.sync(self) la_ = self._interp.adaptivePredict(self._input,75,self._ctx) if la_ == 1: self.enterOuterAlt(localctx, 1) - self.state = 615 + self.state = 611 self.match(HogQLParser.ON) - self.state = 616 + self.state = 612 self.columnExprList() pass elif la_ == 2: self.enterOuterAlt(localctx, 2) - self.state = 617 + self.state = 613 self.match(HogQLParser.USING) - self.state = 618 + self.state = 614 self.match(HogQLParser.LPAREN) - self.state = 619 + self.state = 615 self.columnExprList() - self.state = 620 + self.state = 616 self.match(HogQLParser.RPAREN) pass elif la_ == 3: self.enterOuterAlt(localctx, 3) - self.state = 622 + self.state = 618 self.match(HogQLParser.USING) - self.state = 623 + self.state = 619 self.columnExprList() pass @@ -4500,17 +4496,17 @@ def sampleClause(self): self.enterRule(localctx, 86, self.RULE_sampleClause) try: self.enterOuterAlt(localctx, 1) - self.state = 626 + self.state = 622 self.match(HogQLParser.SAMPLE) - self.state = 627 + self.state = 623 self.ratioExpr() - self.state = 630 + self.state = 626 self._errHandler.sync(self) la_ = self._interp.adaptivePredict(self._input,76,self._ctx) if la_ == 1: - self.state = 628 + self.state = 624 self.match(HogQLParser.OFFSET) - self.state = 629 + self.state = 625 self.ratioExpr() @@ -4562,17 +4558,17 @@ def orderExprList(self): self._la = 0 # Token type try: self.enterOuterAlt(localctx, 1) - self.state = 632 + self.state = 628 self.orderExpr() - self.state = 637 + self.state = 633 self._errHandler.sync(self) _la = self._input.LA(1) while _la==116: - self.state = 633 + self.state = 629 self.match(HogQLParser.COMMA) - self.state = 634 + self.state = 630 self.orderExpr() - self.state = 639 + self.state = 635 self._errHandler.sync(self) _la = self._input.LA(1) @@ -4639,13 +4635,13 @@ def orderExpr(self): self._la = 0 # Token type try: self.enterOuterAlt(localctx, 1) - self.state = 640 + self.state = 636 self.columnExpr(0) - self.state = 642 + self.state = 638 self._errHandler.sync(self) _la = self._input.LA(1) if (((_la) & ~0x3f) == 0 and ((1 << _la) & 12583040) != 0): - self.state = 641 + self.state = 637 _la = self._input.LA(1) if not((((_la) & ~0x3f) == 0 and ((1 << _la) & 12583040) != 0)): self._errHandler.recoverInline(self) @@ -4654,13 +4650,13 @@ def orderExpr(self): self.consume() - self.state = 646 + self.state = 642 self._errHandler.sync(self) _la = self._input.LA(1) if _la==60: - self.state = 644 + self.state = 640 self.match(HogQLParser.NULLS) - self.state = 645 + self.state = 641 _la = self._input.LA(1) if not(_la==30 or _la==49): self._errHandler.recoverInline(self) @@ -4669,13 +4665,13 @@ def orderExpr(self): self.consume() - self.state = 650 + self.state = 646 self._errHandler.sync(self) _la = self._input.LA(1) if _la==16: - self.state = 648 + self.state = 644 self.match(HogQLParser.COLLATE) - self.state = 649 + self.state = 645 self.match(HogQLParser.STRING_LITERAL) @@ -4726,25 +4722,25 @@ def ratioExpr(self): localctx = HogQLParser.RatioExprContext(self, self._ctx, self.state) self.enterRule(localctx, 92, self.RULE_ratioExpr) try: - self.state = 658 + self.state = 654 self._errHandler.sync(self) token = self._input.LA(1) if token in [128]: self.enterOuterAlt(localctx, 1) - self.state = 652 + self.state = 648 self.placeholder() pass elif token in [43, 57, 106, 107, 108, 109, 118, 120, 139]: self.enterOuterAlt(localctx, 2) - self.state = 653 + self.state = 649 self.numberLiteral() - self.state = 656 + self.state = 652 self._errHandler.sync(self) la_ = self._interp.adaptivePredict(self._input,81,self._ctx) if la_ == 1: - self.state = 654 + self.state = 650 self.match(HogQLParser.SLASH) - self.state = 655 + self.state = 651 self.numberLiteral() @@ -4800,17 +4796,17 @@ def settingExprList(self): self._la = 0 # Token type try: self.enterOuterAlt(localctx, 1) - self.state = 660 + self.state = 656 self.settingExpr() - self.state = 665 + self.state = 661 self._errHandler.sync(self) _la = self._input.LA(1) while _la==116: - self.state = 661 + self.state = 657 self.match(HogQLParser.COMMA) - self.state = 662 + self.state = 658 self.settingExpr() - self.state = 667 + self.state = 663 self._errHandler.sync(self) _la = self._input.LA(1) @@ -4859,11 +4855,11 @@ def settingExpr(self): self.enterRule(localctx, 96, self.RULE_settingExpr) try: self.enterOuterAlt(localctx, 1) - self.state = 668 + self.state = 664 self.identifier() - self.state = 669 + self.state = 665 self.match(HogQLParser.EQ_SINGLE) - self.state = 670 + self.state = 666 self.literal() except RecognitionException as re: localctx.exception = re @@ -4912,27 +4908,27 @@ def windowExpr(self): self._la = 0 # Token type try: self.enterOuterAlt(localctx, 1) - self.state = 673 + self.state = 669 self._errHandler.sync(self) _la = self._input.LA(1) if _la==67: - self.state = 672 + self.state = 668 self.winPartitionByClause() - self.state = 676 + self.state = 672 self._errHandler.sync(self) _la = self._input.LA(1) if _la==64: - self.state = 675 + self.state = 671 self.winOrderByClause() - self.state = 679 + self.state = 675 self._errHandler.sync(self) _la = self._input.LA(1) if _la==71 or _la==76: - self.state = 678 + self.state = 674 self.winFrameClause() @@ -4980,11 +4976,11 @@ def winPartitionByClause(self): self.enterRule(localctx, 100, self.RULE_winPartitionByClause) try: self.enterOuterAlt(localctx, 1) - self.state = 681 + self.state = 677 self.match(HogQLParser.PARTITION) - self.state = 682 + self.state = 678 self.match(HogQLParser.BY) - self.state = 683 + self.state = 679 self.columnExprList() except RecognitionException as re: localctx.exception = re @@ -5030,11 +5026,11 @@ def winOrderByClause(self): self.enterRule(localctx, 102, self.RULE_winOrderByClause) try: self.enterOuterAlt(localctx, 1) - self.state = 685 + self.state = 681 self.match(HogQLParser.ORDER) - self.state = 686 + self.state = 682 self.match(HogQLParser.BY) - self.state = 687 + self.state = 683 self.orderExprList() except RecognitionException as re: localctx.exception = re @@ -5081,14 +5077,14 @@ def winFrameClause(self): self._la = 0 # Token type try: self.enterOuterAlt(localctx, 1) - self.state = 689 + self.state = 685 _la = self._input.LA(1) if not(_la==71 or _la==76): self._errHandler.recoverInline(self) else: self._errHandler.reportMatch(self) self.consume() - self.state = 690 + self.state = 686 self.winFrameExtend() except RecognitionException as re: localctx.exception = re @@ -5163,25 +5159,25 @@ def winFrameExtend(self): localctx = HogQLParser.WinFrameExtendContext(self, self._ctx, self.state) self.enterRule(localctx, 106, self.RULE_winFrameExtend) try: - self.state = 698 + self.state = 694 self._errHandler.sync(self) token = self._input.LA(1) if token in [19, 43, 57, 94, 106, 107, 108, 109, 118, 120, 139]: localctx = HogQLParser.FrameStartContext(self, localctx) self.enterOuterAlt(localctx, 1) - self.state = 692 + self.state = 688 self.winFrameBound() pass elif token in [9]: localctx = HogQLParser.FrameBetweenContext(self, localctx) self.enterOuterAlt(localctx, 2) - self.state = 693 + self.state = 689 self.match(HogQLParser.BETWEEN) - self.state = 694 + self.state = 690 self.winFrameBound() - self.state = 695 + self.state = 691 self.match(HogQLParser.AND) - self.state = 696 + self.state = 692 self.winFrameBound() pass else: @@ -5240,41 +5236,41 @@ def winFrameBound(self): self.enterRule(localctx, 108, self.RULE_winFrameBound) try: self.enterOuterAlt(localctx, 1) - self.state = 712 + self.state = 708 self._errHandler.sync(self) la_ = self._interp.adaptivePredict(self._input,88,self._ctx) if la_ == 1: - self.state = 700 + self.state = 696 self.match(HogQLParser.CURRENT) - self.state = 701 + self.state = 697 self.match(HogQLParser.ROW) pass elif la_ == 2: - self.state = 702 + self.state = 698 self.match(HogQLParser.UNBOUNDED) - self.state = 703 + self.state = 699 self.match(HogQLParser.PRECEDING) pass elif la_ == 3: - self.state = 704 + self.state = 700 self.match(HogQLParser.UNBOUNDED) - self.state = 705 + self.state = 701 self.match(HogQLParser.FOLLOWING) pass elif la_ == 4: - self.state = 706 + self.state = 702 self.numberLiteral() - self.state = 707 + self.state = 703 self.match(HogQLParser.PRECEDING) pass elif la_ == 5: - self.state = 709 + self.state = 705 self.numberLiteral() - self.state = 710 + self.state = 706 self.match(HogQLParser.FOLLOWING) pass @@ -5320,9 +5316,9 @@ def expr(self): self.enterRule(localctx, 110, self.RULE_expr) try: self.enterOuterAlt(localctx, 1) - self.state = 714 + self.state = 710 self.columnExpr(0) - self.state = 715 + self.state = 711 self.match(HogQLParser.EOF) except RecognitionException as re: localctx.exception = re @@ -5497,138 +5493,138 @@ def columnTypeExpr(self): self.enterRule(localctx, 112, self.RULE_columnTypeExpr) self._la = 0 # Token type try: - self.state = 773 + self.state = 769 self._errHandler.sync(self) la_ = self._interp.adaptivePredict(self._input,96,self._ctx) if la_ == 1: localctx = HogQLParser.ColumnTypeExprSimpleContext(self, localctx) self.enterOuterAlt(localctx, 1) - self.state = 717 + self.state = 713 self.identifier() pass elif la_ == 2: localctx = HogQLParser.ColumnTypeExprNestedContext(self, localctx) self.enterOuterAlt(localctx, 2) - self.state = 718 + self.state = 714 self.identifier() - self.state = 719 + self.state = 715 self.match(HogQLParser.LPAREN) - self.state = 720 + self.state = 716 self.identifier() - self.state = 721 + self.state = 717 self.columnTypeExpr() - self.state = 728 + self.state = 724 self._errHandler.sync(self) _alt = self._interp.adaptivePredict(self._input,89,self._ctx) while _alt!=2 and _alt!=ATN.INVALID_ALT_NUMBER: if _alt==1: - self.state = 722 + self.state = 718 self.match(HogQLParser.COMMA) - self.state = 723 + self.state = 719 self.identifier() - self.state = 724 + self.state = 720 self.columnTypeExpr() - self.state = 730 + self.state = 726 self._errHandler.sync(self) _alt = self._interp.adaptivePredict(self._input,89,self._ctx) - self.state = 732 + self.state = 728 self._errHandler.sync(self) _la = self._input.LA(1) if _la==116: - self.state = 731 + self.state = 727 self.match(HogQLParser.COMMA) - self.state = 734 + self.state = 730 self.match(HogQLParser.RPAREN) pass elif la_ == 3: localctx = HogQLParser.ColumnTypeExprEnumContext(self, localctx) self.enterOuterAlt(localctx, 3) - self.state = 736 + self.state = 732 self.identifier() - self.state = 737 + self.state = 733 self.match(HogQLParser.LPAREN) - self.state = 738 + self.state = 734 self.enumValue() - self.state = 743 + self.state = 739 self._errHandler.sync(self) _alt = self._interp.adaptivePredict(self._input,91,self._ctx) while _alt!=2 and _alt!=ATN.INVALID_ALT_NUMBER: if _alt==1: - self.state = 739 + self.state = 735 self.match(HogQLParser.COMMA) - self.state = 740 + self.state = 736 self.enumValue() - self.state = 745 + self.state = 741 self._errHandler.sync(self) _alt = self._interp.adaptivePredict(self._input,91,self._ctx) - self.state = 747 + self.state = 743 self._errHandler.sync(self) _la = self._input.LA(1) if _la==116: - self.state = 746 + self.state = 742 self.match(HogQLParser.COMMA) - self.state = 749 + self.state = 745 self.match(HogQLParser.RPAREN) pass elif la_ == 4: localctx = HogQLParser.ColumnTypeExprComplexContext(self, localctx) self.enterOuterAlt(localctx, 4) - self.state = 751 + self.state = 747 self.identifier() - self.state = 752 + self.state = 748 self.match(HogQLParser.LPAREN) - self.state = 753 + self.state = 749 self.columnTypeExpr() - self.state = 758 + self.state = 754 self._errHandler.sync(self) _alt = self._interp.adaptivePredict(self._input,93,self._ctx) while _alt!=2 and _alt!=ATN.INVALID_ALT_NUMBER: if _alt==1: - self.state = 754 + self.state = 750 self.match(HogQLParser.COMMA) - self.state = 755 + self.state = 751 self.columnTypeExpr() - self.state = 760 + self.state = 756 self._errHandler.sync(self) _alt = self._interp.adaptivePredict(self._input,93,self._ctx) - self.state = 762 + self.state = 758 self._errHandler.sync(self) _la = self._input.LA(1) if _la==116: - self.state = 761 + self.state = 757 self.match(HogQLParser.COMMA) - self.state = 764 + self.state = 760 self.match(HogQLParser.RPAREN) pass elif la_ == 5: localctx = HogQLParser.ColumnTypeExprParamContext(self, localctx) self.enterOuterAlt(localctx, 5) - self.state = 766 + self.state = 762 self.identifier() - self.state = 767 + self.state = 763 self.match(HogQLParser.LPAREN) - self.state = 769 + self.state = 765 self._errHandler.sync(self) _la = self._input.LA(1) if (((_la) & ~0x3f) == 0 and ((1 << _la) & -4503602311741442) != 0) or ((((_la - 64)) & ~0x3f) == 0 and ((1 << (_la - 64)) & 90493036243451903) != 0) or ((((_la - 128)) & ~0x3f) == 0 and ((1 << (_la - 128)) & 18455) != 0): - self.state = 768 + self.state = 764 self.columnExprList() - self.state = 771 + self.state = 767 self.match(HogQLParser.RPAREN) pass @@ -5680,26 +5676,26 @@ def columnExprList(self): self.enterRule(localctx, 114, self.RULE_columnExprList) try: self.enterOuterAlt(localctx, 1) - self.state = 775 + self.state = 771 self.columnExpr(0) - self.state = 780 + self.state = 776 self._errHandler.sync(self) _alt = self._interp.adaptivePredict(self._input,97,self._ctx) while _alt!=2 and _alt!=ATN.INVALID_ALT_NUMBER: if _alt==1: - self.state = 776 + self.state = 772 self.match(HogQLParser.COMMA) - self.state = 777 + self.state = 773 self.columnExpr(0) - self.state = 782 + self.state = 778 self._errHandler.sync(self) _alt = self._interp.adaptivePredict(self._input,97,self._ctx) - self.state = 784 + self.state = 780 self._errHandler.sync(self) la_ = self._interp.adaptivePredict(self._input,98,self._ctx) if la_ == 1: - self.state = 783 + self.state = 779 self.match(HogQLParser.COMMA) @@ -6142,6 +6138,8 @@ class ColumnExprWinFunctionTargetContext(ColumnExprContext): def __init__(self, parser, ctx:ParserRuleContext): # actually a HogQLParser.ColumnExprContext super().__init__(parser) + self.columnExprs = None # ColumnExprListContext + self.columnArgList = None # ColumnExprListContext self.copyFrom(ctx) def identifier(self, i:int=None): @@ -6162,14 +6160,14 @@ def RPAREN(self, i:int=None): return self.getTokens(HogQLParser.RPAREN) else: return self.getToken(HogQLParser.RPAREN, i) - def columnExprList(self): - return self.getTypedRuleContext(HogQLParser.ColumnExprListContext,0) + def columnExprList(self, i:int=None): + if i is None: + return self.getTypedRuleContexts(HogQLParser.ColumnExprListContext) + else: + return self.getTypedRuleContext(HogQLParser.ColumnExprListContext,i) def DISTINCT(self): return self.getToken(HogQLParser.DISTINCT, 0) - def columnArgList(self): - return self.getTypedRuleContext(HogQLParser.ColumnArgListContext,0) - def accept(self, visitor:ParseTreeVisitor): if hasattr( visitor, "visitColumnExprWinFunctionTarget" ): @@ -6289,6 +6287,30 @@ def accept(self, visitor:ParseTreeVisitor): return visitor.visitChildren(self) + class ColumnExprCallContext(ColumnExprContext): + + def __init__(self, parser, ctx:ParserRuleContext): # actually a HogQLParser.ColumnExprContext + super().__init__(parser) + self.copyFrom(ctx) + + def columnExpr(self): + return self.getTypedRuleContext(HogQLParser.ColumnExprContext,0) + + def LPAREN(self): + return self.getToken(HogQLParser.LPAREN, 0) + def RPAREN(self): + return self.getToken(HogQLParser.RPAREN, 0) + def columnExprList(self): + return self.getTypedRuleContext(HogQLParser.ColumnExprListContext,0) + + + def accept(self, visitor:ParseTreeVisitor): + if hasattr( visitor, "visitColumnExprCall" ): + return visitor.visitColumnExprCall(self) + else: + return visitor.visitChildren(self) + + class ColumnExprArrayAccessContext(ColumnExprContext): def __init__(self, parser, ctx:ParserRuleContext): # actually a HogQLParser.ColumnExprContext @@ -6572,6 +6594,8 @@ class ColumnExprWinFunctionContext(ColumnExprContext): def __init__(self, parser, ctx:ParserRuleContext): # actually a HogQLParser.ColumnExprContext super().__init__(parser) + self.columnExprs = None # ColumnExprListContext + self.columnArgList = None # ColumnExprListContext self.copyFrom(ctx) def identifier(self): @@ -6592,14 +6616,14 @@ def RPAREN(self, i:int=None): return self.getTokens(HogQLParser.RPAREN) else: return self.getToken(HogQLParser.RPAREN, i) - def columnExprList(self): - return self.getTypedRuleContext(HogQLParser.ColumnExprListContext,0) + def columnExprList(self, i:int=None): + if i is None: + return self.getTypedRuleContexts(HogQLParser.ColumnExprListContext) + else: + return self.getTypedRuleContext(HogQLParser.ColumnExprListContext,i) def DISTINCT(self): return self.getToken(HogQLParser.DISTINCT, 0) - def columnArgList(self): - return self.getTypedRuleContext(HogQLParser.ColumnArgListContext,0) - def accept(self, visitor:ParseTreeVisitor): if hasattr( visitor, "visitColumnExprWinFunction" ): @@ -6608,6 +6632,23 @@ def accept(self, visitor:ParseTreeVisitor): return visitor.visitChildren(self) + class ColumnExprLambdaContext(ColumnExprContext): + + def __init__(self, parser, ctx:ParserRuleContext): # actually a HogQLParser.ColumnExprContext + super().__init__(parser) + self.copyFrom(ctx) + + def columnLambdaExpr(self): + return self.getTypedRuleContext(HogQLParser.ColumnLambdaExprContext,0) + + + def accept(self, visitor:ParseTreeVisitor): + if hasattr( visitor, "visitColumnExprLambda" ): + return visitor.visitColumnExprLambda(self) + else: + return visitor.visitChildren(self) + + class ColumnExprIdentifierContext(ColumnExprContext): def __init__(self, parser, ctx:ParserRuleContext): # actually a HogQLParser.ColumnExprContext @@ -6629,6 +6670,8 @@ class ColumnExprFunctionContext(ColumnExprContext): def __init__(self, parser, ctx:ParserRuleContext): # actually a HogQLParser.ColumnExprContext super().__init__(parser) + self.columnExprs = None # ColumnExprListContext + self.columnArgList = None # ColumnExprListContext self.copyFrom(ctx) def identifier(self): @@ -6646,11 +6689,11 @@ def RPAREN(self, i:int=None): return self.getToken(HogQLParser.RPAREN, i) def DISTINCT(self): return self.getToken(HogQLParser.DISTINCT, 0) - def columnArgList(self): - return self.getTypedRuleContext(HogQLParser.ColumnArgListContext,0) - - def columnExprList(self): - return self.getTypedRuleContext(HogQLParser.ColumnExprListContext,0) + def columnExprList(self, i:int=None): + if i is None: + return self.getTypedRuleContexts(HogQLParser.ColumnExprListContext) + else: + return self.getTypedRuleContext(HogQLParser.ColumnExprListContext,i) def accept(self, visitor:ParseTreeVisitor): @@ -6692,7 +6735,7 @@ def columnExpr(self, _p:int=0): self._la = 0 # Token type try: self.enterOuterAlt(localctx, 1) - self.state = 935 + self.state = 932 self._errHandler.sync(self) la_ = self._interp.adaptivePredict(self._input,118,self._ctx) if la_ == 1: @@ -6700,45 +6743,45 @@ def columnExpr(self, _p:int=0): self._ctx = localctx _prevctx = localctx - self.state = 787 + self.state = 783 self.match(HogQLParser.CASE) - self.state = 789 + self.state = 785 self._errHandler.sync(self) la_ = self._interp.adaptivePredict(self._input,99,self._ctx) if la_ == 1: - self.state = 788 + self.state = 784 localctx.caseExpr = self.columnExpr(0) - self.state = 796 + self.state = 792 self._errHandler.sync(self) _la = self._input.LA(1) while True: - self.state = 791 + self.state = 787 self.match(HogQLParser.WHEN) - self.state = 792 + self.state = 788 localctx.whenExpr = self.columnExpr(0) - self.state = 793 + self.state = 789 self.match(HogQLParser.THEN) - self.state = 794 + self.state = 790 localctx.thenExpr = self.columnExpr(0) - self.state = 798 + self.state = 794 self._errHandler.sync(self) _la = self._input.LA(1) if not (_la==98): break - self.state = 802 + self.state = 798 self._errHandler.sync(self) _la = self._input.LA(1) if _la==25: - self.state = 800 + self.state = 796 self.match(HogQLParser.ELSE) - self.state = 801 + self.state = 797 localctx.elseExpr = self.columnExpr(0) - self.state = 804 + self.state = 800 self.match(HogQLParser.END) pass @@ -6746,17 +6789,17 @@ def columnExpr(self, _p:int=0): localctx = HogQLParser.ColumnExprCastContext(self, localctx) self._ctx = localctx _prevctx = localctx - self.state = 806 + self.state = 802 self.match(HogQLParser.CAST) - self.state = 807 + self.state = 803 self.match(HogQLParser.LPAREN) - self.state = 808 + self.state = 804 self.columnExpr(0) - self.state = 809 + self.state = 805 self.match(HogQLParser.AS) - self.state = 810 + self.state = 806 self.columnTypeExpr() - self.state = 811 + self.state = 807 self.match(HogQLParser.RPAREN) pass @@ -6764,9 +6807,9 @@ def columnExpr(self, _p:int=0): localctx = HogQLParser.ColumnExprDateContext(self, localctx) self._ctx = localctx _prevctx = localctx - self.state = 813 + self.state = 809 self.match(HogQLParser.DATE) - self.state = 814 + self.state = 810 self.match(HogQLParser.STRING_LITERAL) pass @@ -6774,11 +6817,11 @@ def columnExpr(self, _p:int=0): localctx = HogQLParser.ColumnExprIntervalContext(self, localctx) self._ctx = localctx _prevctx = localctx - self.state = 815 + self.state = 811 self.match(HogQLParser.INTERVAL) - self.state = 816 + self.state = 812 self.columnExpr(0) - self.state = 817 + self.state = 813 self.interval() pass @@ -6786,27 +6829,27 @@ def columnExpr(self, _p:int=0): localctx = HogQLParser.ColumnExprSubstringContext(self, localctx) self._ctx = localctx _prevctx = localctx - self.state = 819 + self.state = 815 self.match(HogQLParser.SUBSTRING) - self.state = 820 + self.state = 816 self.match(HogQLParser.LPAREN) - self.state = 821 + self.state = 817 self.columnExpr(0) - self.state = 822 + self.state = 818 self.match(HogQLParser.FROM) - self.state = 823 + self.state = 819 self.columnExpr(0) - self.state = 826 + self.state = 822 self._errHandler.sync(self) _la = self._input.LA(1) if _la==33: - self.state = 824 + self.state = 820 self.match(HogQLParser.FOR) - self.state = 825 + self.state = 821 self.columnExpr(0) - self.state = 828 + self.state = 824 self.match(HogQLParser.RPAREN) pass @@ -6814,9 +6857,9 @@ def columnExpr(self, _p:int=0): localctx = HogQLParser.ColumnExprTimestampContext(self, localctx) self._ctx = localctx _prevctx = localctx - self.state = 830 + self.state = 826 self.match(HogQLParser.TIMESTAMP) - self.state = 831 + self.state = 827 self.match(HogQLParser.STRING_LITERAL) pass @@ -6824,24 +6867,24 @@ def columnExpr(self, _p:int=0): localctx = HogQLParser.ColumnExprTrimContext(self, localctx) self._ctx = localctx _prevctx = localctx - self.state = 832 + self.state = 828 self.match(HogQLParser.TRIM) - self.state = 833 + self.state = 829 self.match(HogQLParser.LPAREN) - self.state = 834 + self.state = 830 _la = self._input.LA(1) if not(_la==10 or _la==50 or _la==90): self._errHandler.recoverInline(self) else: self._errHandler.reportMatch(self) self.consume() - self.state = 835 + self.state = 831 self.string() - self.state = 836 + self.state = 832 self.match(HogQLParser.FROM) - self.state = 837 + self.state = 833 self.columnExpr(0) - self.state = 838 + self.state = 834 self.match(HogQLParser.RPAREN) pass @@ -6849,54 +6892,54 @@ def columnExpr(self, _p:int=0): localctx = HogQLParser.ColumnExprWinFunctionContext(self, localctx) self._ctx = localctx _prevctx = localctx - self.state = 840 + self.state = 836 self.identifier() - self.state = 841 + self.state = 837 self.match(HogQLParser.LPAREN) - self.state = 843 + self.state = 839 self._errHandler.sync(self) _la = self._input.LA(1) if (((_la) & ~0x3f) == 0 and ((1 << _la) & -4503602311741442) != 0) or ((((_la - 64)) & ~0x3f) == 0 and ((1 << (_la - 64)) & 90493036243451903) != 0) or ((((_la - 128)) & ~0x3f) == 0 and ((1 << (_la - 128)) & 18455) != 0): - self.state = 842 - self.columnExprList() + self.state = 838 + localctx.columnExprs = self.columnExprList() - self.state = 845 + self.state = 841 self.match(HogQLParser.RPAREN) - self.state = 855 + self.state = 851 self._errHandler.sync(self) _la = self._input.LA(1) if _la==130: - self.state = 847 + self.state = 843 self.match(HogQLParser.LPAREN) - self.state = 849 + self.state = 845 self._errHandler.sync(self) la_ = self._interp.adaptivePredict(self._input,104,self._ctx) if la_ == 1: - self.state = 848 + self.state = 844 self.match(HogQLParser.DISTINCT) - self.state = 852 + self.state = 848 self._errHandler.sync(self) _la = self._input.LA(1) if (((_la) & ~0x3f) == 0 and ((1 << _la) & -4503602311741442) != 0) or ((((_la - 64)) & ~0x3f) == 0 and ((1 << (_la - 64)) & 90493036243451903) != 0) or ((((_la - 128)) & ~0x3f) == 0 and ((1 << (_la - 128)) & 18455) != 0): - self.state = 851 - self.columnArgList() + self.state = 847 + localctx.columnArgList = self.columnExprList() - self.state = 854 + self.state = 850 self.match(HogQLParser.RPAREN) - self.state = 857 + self.state = 853 self.match(HogQLParser.OVER) - self.state = 858 + self.state = 854 self.match(HogQLParser.LPAREN) - self.state = 859 + self.state = 855 self.windowExpr() - self.state = 860 + self.state = 856 self.match(HogQLParser.RPAREN) pass @@ -6904,50 +6947,50 @@ def columnExpr(self, _p:int=0): localctx = HogQLParser.ColumnExprWinFunctionTargetContext(self, localctx) self._ctx = localctx _prevctx = localctx - self.state = 862 + self.state = 858 self.identifier() - self.state = 863 + self.state = 859 self.match(HogQLParser.LPAREN) - self.state = 865 + self.state = 861 self._errHandler.sync(self) _la = self._input.LA(1) if (((_la) & ~0x3f) == 0 and ((1 << _la) & -4503602311741442) != 0) or ((((_la - 64)) & ~0x3f) == 0 and ((1 << (_la - 64)) & 90493036243451903) != 0) or ((((_la - 128)) & ~0x3f) == 0 and ((1 << (_la - 128)) & 18455) != 0): - self.state = 864 - self.columnExprList() + self.state = 860 + localctx.columnExprs = self.columnExprList() - self.state = 867 + self.state = 863 self.match(HogQLParser.RPAREN) - self.state = 877 + self.state = 873 self._errHandler.sync(self) _la = self._input.LA(1) if _la==130: - self.state = 869 + self.state = 865 self.match(HogQLParser.LPAREN) - self.state = 871 + self.state = 867 self._errHandler.sync(self) la_ = self._interp.adaptivePredict(self._input,108,self._ctx) if la_ == 1: - self.state = 870 + self.state = 866 self.match(HogQLParser.DISTINCT) - self.state = 874 + self.state = 870 self._errHandler.sync(self) _la = self._input.LA(1) if (((_la) & ~0x3f) == 0 and ((1 << _la) & -4503602311741442) != 0) or ((((_la - 64)) & ~0x3f) == 0 and ((1 << (_la - 64)) & 90493036243451903) != 0) or ((((_la - 128)) & ~0x3f) == 0 and ((1 << (_la - 128)) & 18455) != 0): - self.state = 873 - self.columnArgList() + self.state = 869 + localctx.columnArgList = self.columnExprList() - self.state = 876 + self.state = 872 self.match(HogQLParser.RPAREN) - self.state = 879 + self.state = 875 self.match(HogQLParser.OVER) - self.state = 880 + self.state = 876 self.identifier() pass @@ -6955,45 +6998,45 @@ def columnExpr(self, _p:int=0): localctx = HogQLParser.ColumnExprFunctionContext(self, localctx) self._ctx = localctx _prevctx = localctx - self.state = 882 + self.state = 878 self.identifier() - self.state = 888 + self.state = 884 self._errHandler.sync(self) la_ = self._interp.adaptivePredict(self._input,112,self._ctx) if la_ == 1: - self.state = 883 + self.state = 879 self.match(HogQLParser.LPAREN) - self.state = 885 + self.state = 881 self._errHandler.sync(self) _la = self._input.LA(1) if (((_la) & ~0x3f) == 0 and ((1 << _la) & -4503602311741442) != 0) or ((((_la - 64)) & ~0x3f) == 0 and ((1 << (_la - 64)) & 90493036243451903) != 0) or ((((_la - 128)) & ~0x3f) == 0 and ((1 << (_la - 128)) & 18455) != 0): - self.state = 884 - self.columnExprList() + self.state = 880 + localctx.columnExprs = self.columnExprList() - self.state = 887 + self.state = 883 self.match(HogQLParser.RPAREN) - self.state = 890 + self.state = 886 self.match(HogQLParser.LPAREN) - self.state = 892 + self.state = 888 self._errHandler.sync(self) la_ = self._interp.adaptivePredict(self._input,113,self._ctx) if la_ == 1: - self.state = 891 + self.state = 887 self.match(HogQLParser.DISTINCT) - self.state = 895 + self.state = 891 self._errHandler.sync(self) _la = self._input.LA(1) if (((_la) & ~0x3f) == 0 and ((1 << _la) & -4503602311741442) != 0) or ((((_la - 64)) & ~0x3f) == 0 and ((1 << (_la - 64)) & 90493036243451903) != 0) or ((((_la - 128)) & ~0x3f) == 0 and ((1 << (_la - 128)) & 18455) != 0): - self.state = 894 - self.columnArgList() + self.state = 890 + localctx.columnArgList = self.columnExprList() - self.state = 897 + self.state = 893 self.match(HogQLParser.RPAREN) pass @@ -7001,7 +7044,7 @@ def columnExpr(self, _p:int=0): localctx = HogQLParser.ColumnExprTagElementContext(self, localctx) self._ctx = localctx _prevctx = localctx - self.state = 899 + self.state = 895 self.hogqlxTagElement() pass @@ -7009,7 +7052,7 @@ def columnExpr(self, _p:int=0): localctx = HogQLParser.ColumnExprTemplateStringContext(self, localctx) self._ctx = localctx _prevctx = localctx - self.state = 900 + self.state = 896 self.templateString() pass @@ -7017,7 +7060,7 @@ def columnExpr(self, _p:int=0): localctx = HogQLParser.ColumnExprLiteralContext(self, localctx) self._ctx = localctx _prevctx = localctx - self.state = 901 + self.state = 897 self.literal() pass @@ -7025,37 +7068,37 @@ def columnExpr(self, _p:int=0): localctx = HogQLParser.ColumnExprNegateContext(self, localctx) self._ctx = localctx _prevctx = localctx - self.state = 902 + self.state = 898 self.match(HogQLParser.DASH) - self.state = 903 - self.columnExpr(19) + self.state = 899 + self.columnExpr(20) pass elif la_ == 15: localctx = HogQLParser.ColumnExprNotContext(self, localctx) self._ctx = localctx _prevctx = localctx - self.state = 904 + self.state = 900 self.match(HogQLParser.NOT) - self.state = 905 - self.columnExpr(13) + self.state = 901 + self.columnExpr(14) pass elif la_ == 16: localctx = HogQLParser.ColumnExprAsteriskContext(self, localctx) self._ctx = localctx _prevctx = localctx - self.state = 909 + self.state = 905 self._errHandler.sync(self) _la = self._input.LA(1) if (((_la) & ~0x3f) == 0 and ((1 << _la) & -725088338784043010) != 0) or ((((_la - 64)) & ~0x3f) == 0 and ((1 << (_la - 64)) & 3229277487103) != 0): - self.state = 906 + self.state = 902 self.tableIdentifier() - self.state = 907 + self.state = 903 self.match(HogQLParser.DOT) - self.state = 911 + self.state = 907 self.match(HogQLParser.ASTERISK) pass @@ -7063,11 +7106,11 @@ def columnExpr(self, _p:int=0): localctx = HogQLParser.ColumnExprSubqueryContext(self, localctx) self._ctx = localctx _prevctx = localctx - self.state = 912 + self.state = 908 self.match(HogQLParser.LPAREN) - self.state = 913 + self.state = 909 self.selectUnionStmt() - self.state = 914 + self.state = 910 self.match(HogQLParser.RPAREN) pass @@ -7075,11 +7118,11 @@ def columnExpr(self, _p:int=0): localctx = HogQLParser.ColumnExprParensContext(self, localctx) self._ctx = localctx _prevctx = localctx - self.state = 916 + self.state = 912 self.match(HogQLParser.LPAREN) - self.state = 917 + self.state = 913 self.columnExpr(0) - self.state = 918 + self.state = 914 self.match(HogQLParser.RPAREN) pass @@ -7087,11 +7130,11 @@ def columnExpr(self, _p:int=0): localctx = HogQLParser.ColumnExprTupleContext(self, localctx) self._ctx = localctx _prevctx = localctx - self.state = 920 + self.state = 916 self.match(HogQLParser.LPAREN) - self.state = 921 + self.state = 917 self.columnExprList() - self.state = 922 + self.state = 918 self.match(HogQLParser.RPAREN) pass @@ -7099,17 +7142,17 @@ def columnExpr(self, _p:int=0): localctx = HogQLParser.ColumnExprArrayContext(self, localctx) self._ctx = localctx _prevctx = localctx - self.state = 924 + self.state = 920 self.match(HogQLParser.LBRACKET) - self.state = 926 + self.state = 922 self._errHandler.sync(self) _la = self._input.LA(1) if (((_la) & ~0x3f) == 0 and ((1 << _la) & -4503602311741442) != 0) or ((((_la - 64)) & ~0x3f) == 0 and ((1 << (_la - 64)) & 90493036243451903) != 0) or ((((_la - 128)) & ~0x3f) == 0 and ((1 << (_la - 128)) & 18455) != 0): - self.state = 925 + self.state = 921 self.columnExprList() - self.state = 928 + self.state = 924 self.match(HogQLParser.RBRACKET) pass @@ -7117,178 +7160,186 @@ def columnExpr(self, _p:int=0): localctx = HogQLParser.ColumnExprDictContext(self, localctx) self._ctx = localctx _prevctx = localctx - self.state = 929 + self.state = 925 self.match(HogQLParser.LBRACE) - self.state = 931 + self.state = 927 self._errHandler.sync(self) _la = self._input.LA(1) if (((_la) & ~0x3f) == 0 and ((1 << _la) & -4503602311741442) != 0) or ((((_la - 64)) & ~0x3f) == 0 and ((1 << (_la - 64)) & 90493036243451903) != 0) or ((((_la - 128)) & ~0x3f) == 0 and ((1 << (_la - 128)) & 18455) != 0): - self.state = 930 + self.state = 926 self.kvPairList() - self.state = 933 + self.state = 929 self.match(HogQLParser.RBRACE) pass elif la_ == 22: + localctx = HogQLParser.ColumnExprLambdaContext(self, localctx) + self._ctx = localctx + _prevctx = localctx + self.state = 930 + self.columnLambdaExpr() + pass + + elif la_ == 23: localctx = HogQLParser.ColumnExprIdentifierContext(self, localctx) self._ctx = localctx _prevctx = localctx - self.state = 934 + self.state = 931 self.columnIdentifier() pass self._ctx.stop = self._input.LT(-1) - self.state = 1041 + self.state = 1044 self._errHandler.sync(self) - _alt = self._interp.adaptivePredict(self._input,129,self._ctx) + _alt = self._interp.adaptivePredict(self._input,130,self._ctx) while _alt!=2 and _alt!=ATN.INVALID_ALT_NUMBER: if _alt==1: if self._parseListeners is not None: self.triggerExitRuleEvent() _prevctx = localctx - self.state = 1039 + self.state = 1042 self._errHandler.sync(self) - la_ = self._interp.adaptivePredict(self._input,128,self._ctx) + la_ = self._interp.adaptivePredict(self._input,129,self._ctx) if la_ == 1: localctx = HogQLParser.ColumnExprPrecedence1Context(self, HogQLParser.ColumnExprContext(self, _parentctx, _parentState)) localctx.left = _prevctx self.pushNewRecursionContext(localctx, _startState, self.RULE_columnExpr) - self.state = 937 - if not self.precpred(self._ctx, 18): + self.state = 934 + if not self.precpred(self._ctx, 19): from antlr4.error.Errors import FailedPredicateException - raise FailedPredicateException(self, "self.precpred(self._ctx, 18)") - self.state = 941 + raise FailedPredicateException(self, "self.precpred(self._ctx, 19)") + self.state = 938 self._errHandler.sync(self) token = self._input.LA(1) if token in [112]: - self.state = 938 + self.state = 935 localctx.operator = self.match(HogQLParser.ASTERISK) pass elif token in [151]: - self.state = 939 + self.state = 936 localctx.operator = self.match(HogQLParser.SLASH) pass elif token in [138]: - self.state = 940 + self.state = 937 localctx.operator = self.match(HogQLParser.PERCENT) pass else: raise NoViableAltException(self) - self.state = 943 - localctx.right = self.columnExpr(19) + self.state = 940 + localctx.right = self.columnExpr(20) pass elif la_ == 2: localctx = HogQLParser.ColumnExprPrecedence2Context(self, HogQLParser.ColumnExprContext(self, _parentctx, _parentState)) localctx.left = _prevctx self.pushNewRecursionContext(localctx, _startState, self.RULE_columnExpr) - self.state = 944 - if not self.precpred(self._ctx, 17): + self.state = 941 + if not self.precpred(self._ctx, 18): from antlr4.error.Errors import FailedPredicateException - raise FailedPredicateException(self, "self.precpred(self._ctx, 17)") - self.state = 948 + raise FailedPredicateException(self, "self.precpred(self._ctx, 18)") + self.state = 945 self._errHandler.sync(self) token = self._input.LA(1) if token in [139]: - self.state = 945 + self.state = 942 localctx.operator = self.match(HogQLParser.PLUS) pass elif token in [118]: - self.state = 946 + self.state = 943 localctx.operator = self.match(HogQLParser.DASH) pass elif token in [117]: - self.state = 947 + self.state = 944 localctx.operator = self.match(HogQLParser.CONCAT) pass else: raise NoViableAltException(self) - self.state = 950 - localctx.right = self.columnExpr(18) + self.state = 947 + localctx.right = self.columnExpr(19) pass elif la_ == 3: localctx = HogQLParser.ColumnExprPrecedence3Context(self, HogQLParser.ColumnExprContext(self, _parentctx, _parentState)) localctx.left = _prevctx self.pushNewRecursionContext(localctx, _startState, self.RULE_columnExpr) - self.state = 951 - if not self.precpred(self._ctx, 16): + self.state = 948 + if not self.precpred(self._ctx, 17): from antlr4.error.Errors import FailedPredicateException - raise FailedPredicateException(self, "self.precpred(self._ctx, 16)") - self.state = 976 + raise FailedPredicateException(self, "self.precpred(self._ctx, 17)") + self.state = 973 self._errHandler.sync(self) la_ = self._interp.adaptivePredict(self._input,124,self._ctx) if la_ == 1: - self.state = 952 + self.state = 949 localctx.operator = self.match(HogQLParser.EQ_DOUBLE) pass elif la_ == 2: - self.state = 953 + self.state = 950 localctx.operator = self.match(HogQLParser.EQ_SINGLE) pass elif la_ == 3: - self.state = 954 + self.state = 951 localctx.operator = self.match(HogQLParser.NOT_EQ) pass elif la_ == 4: - self.state = 955 + self.state = 952 localctx.operator = self.match(HogQLParser.LT_EQ) pass elif la_ == 5: - self.state = 956 + self.state = 953 localctx.operator = self.match(HogQLParser.LT) pass elif la_ == 6: - self.state = 957 + self.state = 954 localctx.operator = self.match(HogQLParser.GT_EQ) pass elif la_ == 7: - self.state = 958 + self.state = 955 localctx.operator = self.match(HogQLParser.GT) pass elif la_ == 8: - self.state = 960 + self.state = 957 self._errHandler.sync(self) _la = self._input.LA(1) if _la==58: - self.state = 959 + self.state = 956 localctx.operator = self.match(HogQLParser.NOT) - self.state = 962 + self.state = 959 self.match(HogQLParser.IN) - self.state = 964 + self.state = 961 self._errHandler.sync(self) la_ = self._interp.adaptivePredict(self._input,122,self._ctx) if la_ == 1: - self.state = 963 + self.state = 960 self.match(HogQLParser.COHORT) pass elif la_ == 9: - self.state = 967 + self.state = 964 self._errHandler.sync(self) _la = self._input.LA(1) if _la==58: - self.state = 966 + self.state = 963 localctx.operator = self.match(HogQLParser.NOT) - self.state = 969 + self.state = 966 _la = self._input.LA(1) if not(_la==41 or _la==53): self._errHandler.recoverInline(self) @@ -7298,247 +7349,268 @@ def columnExpr(self, _p:int=0): pass elif la_ == 10: - self.state = 970 + self.state = 967 localctx.operator = self.match(HogQLParser.REGEX_SINGLE) pass elif la_ == 11: - self.state = 971 + self.state = 968 localctx.operator = self.match(HogQLParser.REGEX_DOUBLE) pass elif la_ == 12: - self.state = 972 + self.state = 969 localctx.operator = self.match(HogQLParser.NOT_REGEX) pass elif la_ == 13: - self.state = 973 + self.state = 970 localctx.operator = self.match(HogQLParser.IREGEX_SINGLE) pass elif la_ == 14: - self.state = 974 + self.state = 971 localctx.operator = self.match(HogQLParser.IREGEX_DOUBLE) pass elif la_ == 15: - self.state = 975 + self.state = 972 localctx.operator = self.match(HogQLParser.NOT_IREGEX) pass - self.state = 978 - localctx.right = self.columnExpr(17) + self.state = 975 + localctx.right = self.columnExpr(18) pass elif la_ == 4: localctx = HogQLParser.ColumnExprNullishContext(self, HogQLParser.ColumnExprContext(self, _parentctx, _parentState)) self.pushNewRecursionContext(localctx, _startState, self.RULE_columnExpr) - self.state = 979 - if not self.precpred(self._ctx, 14): + self.state = 976 + if not self.precpred(self._ctx, 15): from antlr4.error.Errors import FailedPredicateException - raise FailedPredicateException(self, "self.precpred(self._ctx, 14)") - self.state = 980 + raise FailedPredicateException(self, "self.precpred(self._ctx, 15)") + self.state = 977 self.match(HogQLParser.NULLISH) - self.state = 981 - self.columnExpr(15) + self.state = 978 + self.columnExpr(16) pass elif la_ == 5: localctx = HogQLParser.ColumnExprAndContext(self, HogQLParser.ColumnExprContext(self, _parentctx, _parentState)) self.pushNewRecursionContext(localctx, _startState, self.RULE_columnExpr) - self.state = 982 - if not self.precpred(self._ctx, 12): + self.state = 979 + if not self.precpred(self._ctx, 13): from antlr4.error.Errors import FailedPredicateException - raise FailedPredicateException(self, "self.precpred(self._ctx, 12)") - self.state = 983 + raise FailedPredicateException(self, "self.precpred(self._ctx, 13)") + self.state = 980 self.match(HogQLParser.AND) - self.state = 984 - self.columnExpr(13) + self.state = 981 + self.columnExpr(14) pass elif la_ == 6: localctx = HogQLParser.ColumnExprOrContext(self, HogQLParser.ColumnExprContext(self, _parentctx, _parentState)) self.pushNewRecursionContext(localctx, _startState, self.RULE_columnExpr) - self.state = 985 - if not self.precpred(self._ctx, 11): + self.state = 982 + if not self.precpred(self._ctx, 12): from antlr4.error.Errors import FailedPredicateException - raise FailedPredicateException(self, "self.precpred(self._ctx, 11)") - self.state = 986 + raise FailedPredicateException(self, "self.precpred(self._ctx, 12)") + self.state = 983 self.match(HogQLParser.OR) - self.state = 987 - self.columnExpr(12) + self.state = 984 + self.columnExpr(13) pass elif la_ == 7: localctx = HogQLParser.ColumnExprBetweenContext(self, HogQLParser.ColumnExprContext(self, _parentctx, _parentState)) self.pushNewRecursionContext(localctx, _startState, self.RULE_columnExpr) - self.state = 988 - if not self.precpred(self._ctx, 10): + self.state = 985 + if not self.precpred(self._ctx, 11): from antlr4.error.Errors import FailedPredicateException - raise FailedPredicateException(self, "self.precpred(self._ctx, 10)") - self.state = 990 + raise FailedPredicateException(self, "self.precpred(self._ctx, 11)") + self.state = 987 self._errHandler.sync(self) _la = self._input.LA(1) if _la==58: - self.state = 989 + self.state = 986 self.match(HogQLParser.NOT) - self.state = 992 + self.state = 989 self.match(HogQLParser.BETWEEN) - self.state = 993 + self.state = 990 self.columnExpr(0) - self.state = 994 + self.state = 991 self.match(HogQLParser.AND) - self.state = 995 - self.columnExpr(11) + self.state = 992 + self.columnExpr(12) pass elif la_ == 8: localctx = HogQLParser.ColumnExprTernaryOpContext(self, HogQLParser.ColumnExprContext(self, _parentctx, _parentState)) self.pushNewRecursionContext(localctx, _startState, self.RULE_columnExpr) - self.state = 997 - if not self.precpred(self._ctx, 9): + self.state = 994 + if not self.precpred(self._ctx, 10): from antlr4.error.Errors import FailedPredicateException - raise FailedPredicateException(self, "self.precpred(self._ctx, 9)") - self.state = 998 + raise FailedPredicateException(self, "self.precpred(self._ctx, 10)") + self.state = 995 self.match(HogQLParser.QUERY) - self.state = 999 + self.state = 996 self.columnExpr(0) - self.state = 1000 + self.state = 997 self.match(HogQLParser.COLON) - self.state = 1001 - self.columnExpr(9) + self.state = 998 + self.columnExpr(10) pass elif la_ == 9: - localctx = HogQLParser.ColumnExprArrayAccessContext(self, HogQLParser.ColumnExprContext(self, _parentctx, _parentState)) + localctx = HogQLParser.ColumnExprCallContext(self, HogQLParser.ColumnExprContext(self, _parentctx, _parentState)) self.pushNewRecursionContext(localctx, _startState, self.RULE_columnExpr) - self.state = 1003 - if not self.precpred(self._ctx, 25): + self.state = 1000 + if not self.precpred(self._ctx, 30): from antlr4.error.Errors import FailedPredicateException - raise FailedPredicateException(self, "self.precpred(self._ctx, 25)") - self.state = 1004 - self.match(HogQLParser.LBRACKET) + raise FailedPredicateException(self, "self.precpred(self._ctx, 30)") + self.state = 1001 + self.match(HogQLParser.LPAREN) + self.state = 1003 + self._errHandler.sync(self) + _la = self._input.LA(1) + if (((_la) & ~0x3f) == 0 and ((1 << _la) & -4503602311741442) != 0) or ((((_la - 64)) & ~0x3f) == 0 and ((1 << (_la - 64)) & 90493036243451903) != 0) or ((((_la - 128)) & ~0x3f) == 0 and ((1 << (_la - 128)) & 18455) != 0): + self.state = 1002 + self.columnExprList() + + self.state = 1005 - self.columnExpr(0) - self.state = 1006 - self.match(HogQLParser.RBRACKET) + self.match(HogQLParser.RPAREN) pass elif la_ == 10: - localctx = HogQLParser.ColumnExprTupleAccessContext(self, HogQLParser.ColumnExprContext(self, _parentctx, _parentState)) + localctx = HogQLParser.ColumnExprArrayAccessContext(self, HogQLParser.ColumnExprContext(self, _parentctx, _parentState)) self.pushNewRecursionContext(localctx, _startState, self.RULE_columnExpr) - self.state = 1008 - if not self.precpred(self._ctx, 24): + self.state = 1006 + if not self.precpred(self._ctx, 26): from antlr4.error.Errors import FailedPredicateException - raise FailedPredicateException(self, "self.precpred(self._ctx, 24)") + raise FailedPredicateException(self, "self.precpred(self._ctx, 26)") + self.state = 1007 + self.match(HogQLParser.LBRACKET) + self.state = 1008 + self.columnExpr(0) self.state = 1009 - self.match(HogQLParser.DOT) - self.state = 1010 - self.match(HogQLParser.DECIMAL_LITERAL) + self.match(HogQLParser.RBRACKET) pass elif la_ == 11: - localctx = HogQLParser.ColumnExprPropertyAccessContext(self, HogQLParser.ColumnExprContext(self, _parentctx, _parentState)) + localctx = HogQLParser.ColumnExprTupleAccessContext(self, HogQLParser.ColumnExprContext(self, _parentctx, _parentState)) self.pushNewRecursionContext(localctx, _startState, self.RULE_columnExpr) self.state = 1011 - if not self.precpred(self._ctx, 23): + if not self.precpred(self._ctx, 25): from antlr4.error.Errors import FailedPredicateException - raise FailedPredicateException(self, "self.precpred(self._ctx, 23)") + raise FailedPredicateException(self, "self.precpred(self._ctx, 25)") self.state = 1012 self.match(HogQLParser.DOT) self.state = 1013 - self.identifier() + self.match(HogQLParser.DECIMAL_LITERAL) pass elif la_ == 12: - localctx = HogQLParser.ColumnExprNullArrayAccessContext(self, HogQLParser.ColumnExprContext(self, _parentctx, _parentState)) + localctx = HogQLParser.ColumnExprPropertyAccessContext(self, HogQLParser.ColumnExprContext(self, _parentctx, _parentState)) self.pushNewRecursionContext(localctx, _startState, self.RULE_columnExpr) self.state = 1014 - if not self.precpred(self._ctx, 22): + if not self.precpred(self._ctx, 24): from antlr4.error.Errors import FailedPredicateException - raise FailedPredicateException(self, "self.precpred(self._ctx, 22)") + raise FailedPredicateException(self, "self.precpred(self._ctx, 24)") self.state = 1015 - self.match(HogQLParser.NULL_PROPERTY) + self.match(HogQLParser.DOT) self.state = 1016 - self.match(HogQLParser.LBRACKET) - self.state = 1017 - self.columnExpr(0) - self.state = 1018 - self.match(HogQLParser.RBRACKET) + self.identifier() pass elif la_ == 13: - localctx = HogQLParser.ColumnExprNullTupleAccessContext(self, HogQLParser.ColumnExprContext(self, _parentctx, _parentState)) + localctx = HogQLParser.ColumnExprNullArrayAccessContext(self, HogQLParser.ColumnExprContext(self, _parentctx, _parentState)) self.pushNewRecursionContext(localctx, _startState, self.RULE_columnExpr) - self.state = 1020 - if not self.precpred(self._ctx, 21): + self.state = 1017 + if not self.precpred(self._ctx, 23): from antlr4.error.Errors import FailedPredicateException - raise FailedPredicateException(self, "self.precpred(self._ctx, 21)") - self.state = 1021 + raise FailedPredicateException(self, "self.precpred(self._ctx, 23)") + self.state = 1018 self.match(HogQLParser.NULL_PROPERTY) - self.state = 1022 - self.match(HogQLParser.DECIMAL_LITERAL) + self.state = 1019 + self.match(HogQLParser.LBRACKET) + self.state = 1020 + self.columnExpr(0) + self.state = 1021 + self.match(HogQLParser.RBRACKET) pass elif la_ == 14: - localctx = HogQLParser.ColumnExprNullPropertyAccessContext(self, HogQLParser.ColumnExprContext(self, _parentctx, _parentState)) + localctx = HogQLParser.ColumnExprNullTupleAccessContext(self, HogQLParser.ColumnExprContext(self, _parentctx, _parentState)) self.pushNewRecursionContext(localctx, _startState, self.RULE_columnExpr) self.state = 1023 - if not self.precpred(self._ctx, 20): + if not self.precpred(self._ctx, 22): from antlr4.error.Errors import FailedPredicateException - raise FailedPredicateException(self, "self.precpred(self._ctx, 20)") + raise FailedPredicateException(self, "self.precpred(self._ctx, 22)") self.state = 1024 self.match(HogQLParser.NULL_PROPERTY) self.state = 1025 - self.identifier() + self.match(HogQLParser.DECIMAL_LITERAL) pass elif la_ == 15: - localctx = HogQLParser.ColumnExprIsNullContext(self, HogQLParser.ColumnExprContext(self, _parentctx, _parentState)) + localctx = HogQLParser.ColumnExprNullPropertyAccessContext(self, HogQLParser.ColumnExprContext(self, _parentctx, _parentState)) self.pushNewRecursionContext(localctx, _startState, self.RULE_columnExpr) self.state = 1026 - if not self.precpred(self._ctx, 15): + if not self.precpred(self._ctx, 21): from antlr4.error.Errors import FailedPredicateException - raise FailedPredicateException(self, "self.precpred(self._ctx, 15)") + raise FailedPredicateException(self, "self.precpred(self._ctx, 21)") self.state = 1027 - self.match(HogQLParser.IS) + self.match(HogQLParser.NULL_PROPERTY) + self.state = 1028 + self.identifier() + pass + + elif la_ == 16: + localctx = HogQLParser.ColumnExprIsNullContext(self, HogQLParser.ColumnExprContext(self, _parentctx, _parentState)) + self.pushNewRecursionContext(localctx, _startState, self.RULE_columnExpr) self.state = 1029 + if not self.precpred(self._ctx, 16): + from antlr4.error.Errors import FailedPredicateException + raise FailedPredicateException(self, "self.precpred(self._ctx, 16)") + self.state = 1030 + self.match(HogQLParser.IS) + self.state = 1032 self._errHandler.sync(self) _la = self._input.LA(1) if _la==58: - self.state = 1028 + self.state = 1031 self.match(HogQLParser.NOT) - self.state = 1031 + self.state = 1034 self.match(HogQLParser.NULL_SQL) pass - elif la_ == 16: + elif la_ == 17: localctx = HogQLParser.ColumnExprAliasContext(self, HogQLParser.ColumnExprContext(self, _parentctx, _parentState)) self.pushNewRecursionContext(localctx, _startState, self.RULE_columnExpr) - self.state = 1032 - if not self.precpred(self._ctx, 8): + self.state = 1035 + if not self.precpred(self._ctx, 9): from antlr4.error.Errors import FailedPredicateException - raise FailedPredicateException(self, "self.precpred(self._ctx, 8)") - self.state = 1037 + raise FailedPredicateException(self, "self.precpred(self._ctx, 9)") + self.state = 1040 self._errHandler.sync(self) - la_ = self._interp.adaptivePredict(self._input,127,self._ctx) + la_ = self._interp.adaptivePredict(self._input,128,self._ctx) if la_ == 1: - self.state = 1033 + self.state = 1036 self.match(HogQLParser.AS) - self.state = 1034 + self.state = 1037 self.identifier() pass elif la_ == 2: - self.state = 1035 + self.state = 1038 self.match(HogQLParser.AS) - self.state = 1036 + self.state = 1039 self.match(HogQLParser.STRING_LITERAL) pass @@ -7546,144 +7618,16 @@ def columnExpr(self, _p:int=0): pass - self.state = 1043 - self._errHandler.sync(self) - _alt = self._interp.adaptivePredict(self._input,129,self._ctx) - - except RecognitionException as re: - localctx.exception = re - self._errHandler.reportError(self, re) - self._errHandler.recover(self, re) - finally: - self.unrollRecursionContexts(_parentctx) - return localctx - - - class ColumnArgListContext(ParserRuleContext): - __slots__ = 'parser' - - def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1): - super().__init__(parent, invokingState) - self.parser = parser - - def columnArgExpr(self, i:int=None): - if i is None: - return self.getTypedRuleContexts(HogQLParser.ColumnArgExprContext) - else: - return self.getTypedRuleContext(HogQLParser.ColumnArgExprContext,i) - - - def COMMA(self, i:int=None): - if i is None: - return self.getTokens(HogQLParser.COMMA) - else: - return self.getToken(HogQLParser.COMMA, i) - - def getRuleIndex(self): - return HogQLParser.RULE_columnArgList - - def accept(self, visitor:ParseTreeVisitor): - if hasattr( visitor, "visitColumnArgList" ): - return visitor.visitColumnArgList(self) - else: - return visitor.visitChildren(self) - - - - - def columnArgList(self): - - localctx = HogQLParser.ColumnArgListContext(self, self._ctx, self.state) - self.enterRule(localctx, 118, self.RULE_columnArgList) - self._la = 0 # Token type - try: - self.enterOuterAlt(localctx, 1) - self.state = 1044 - self.columnArgExpr() - self.state = 1049 - self._errHandler.sync(self) - _alt = self._interp.adaptivePredict(self._input,130,self._ctx) - while _alt!=2 and _alt!=ATN.INVALID_ALT_NUMBER: - if _alt==1: - self.state = 1045 - self.match(HogQLParser.COMMA) - self.state = 1046 - self.columnArgExpr() - self.state = 1051 + self.state = 1046 self._errHandler.sync(self) _alt = self._interp.adaptivePredict(self._input,130,self._ctx) - self.state = 1053 - self._errHandler.sync(self) - _la = self._input.LA(1) - if _la==116: - self.state = 1052 - self.match(HogQLParser.COMMA) - - - except RecognitionException as re: - localctx.exception = re - self._errHandler.reportError(self, re) - self._errHandler.recover(self, re) - finally: - self.exitRule() - return localctx - - - class ColumnArgExprContext(ParserRuleContext): - __slots__ = 'parser' - - def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1): - super().__init__(parent, invokingState) - self.parser = parser - - def columnLambdaExpr(self): - return self.getTypedRuleContext(HogQLParser.ColumnLambdaExprContext,0) - - - def columnExpr(self): - return self.getTypedRuleContext(HogQLParser.ColumnExprContext,0) - - - def getRuleIndex(self): - return HogQLParser.RULE_columnArgExpr - - def accept(self, visitor:ParseTreeVisitor): - if hasattr( visitor, "visitColumnArgExpr" ): - return visitor.visitColumnArgExpr(self) - else: - return visitor.visitChildren(self) - - - - - def columnArgExpr(self): - - localctx = HogQLParser.ColumnArgExprContext(self, self._ctx, self.state) - self.enterRule(localctx, 120, self.RULE_columnArgExpr) - try: - self.state = 1057 - self._errHandler.sync(self) - la_ = self._interp.adaptivePredict(self._input,132,self._ctx) - if la_ == 1: - self.enterOuterAlt(localctx, 1) - self.state = 1055 - self.columnLambdaExpr() - pass - - elif la_ == 2: - self.enterOuterAlt(localctx, 2) - self.state = 1056 - self.columnExpr(0) - pass - - except RecognitionException as re: localctx.exception = re self._errHandler.reportError(self, re) self._errHandler.recover(self, re) finally: - self.exitRule() + self.unrollRecursionContexts(_parentctx) return localctx @@ -7697,10 +7641,6 @@ def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1): def ARROW(self): return self.getToken(HogQLParser.ARROW, 0) - def columnExpr(self): - return self.getTypedRuleContext(HogQLParser.ColumnExprContext,0) - - def LPAREN(self): return self.getToken(HogQLParser.LPAREN, 0) @@ -7714,6 +7654,14 @@ def identifier(self, i:int=None): def RPAREN(self): return self.getToken(HogQLParser.RPAREN, 0) + def columnExpr(self): + return self.getTypedRuleContext(HogQLParser.ColumnExprContext,0) + + + def block(self): + return self.getTypedRuleContext(HogQLParser.BlockContext,0) + + def COMMA(self, i:int=None): if i is None: return self.getTokens(HogQLParser.COMMA) @@ -7735,74 +7683,93 @@ def accept(self, visitor:ParseTreeVisitor): def columnLambdaExpr(self): localctx = HogQLParser.ColumnLambdaExprContext(self, self._ctx, self.state) - self.enterRule(localctx, 122, self.RULE_columnLambdaExpr) + self.enterRule(localctx, 118, self.RULE_columnLambdaExpr) self._la = 0 # Token type try: self.enterOuterAlt(localctx, 1) - self.state = 1084 + self.state = 1074 self._errHandler.sync(self) - token = self._input.LA(1) - if token in [130]: - self.state = 1059 + la_ = self._interp.adaptivePredict(self._input,135,self._ctx) + if la_ == 1: + self.state = 1047 self.match(HogQLParser.LPAREN) - self.state = 1060 + self.state = 1048 self.identifier() - self.state = 1065 + self.state = 1053 self._errHandler.sync(self) - _alt = self._interp.adaptivePredict(self._input,133,self._ctx) + _alt = self._interp.adaptivePredict(self._input,131,self._ctx) while _alt!=2 and _alt!=ATN.INVALID_ALT_NUMBER: if _alt==1: - self.state = 1061 + self.state = 1049 self.match(HogQLParser.COMMA) - self.state = 1062 + self.state = 1050 self.identifier() - self.state = 1067 + self.state = 1055 self._errHandler.sync(self) - _alt = self._interp.adaptivePredict(self._input,133,self._ctx) + _alt = self._interp.adaptivePredict(self._input,131,self._ctx) - self.state = 1069 + self.state = 1057 self._errHandler.sync(self) _la = self._input.LA(1) if _la==116: - self.state = 1068 + self.state = 1056 self.match(HogQLParser.COMMA) - self.state = 1071 + self.state = 1059 self.match(HogQLParser.RPAREN) pass - elif token in [1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 30, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 44, 45, 46, 47, 48, 49, 50, 51, 53, 54, 55, 56, 58, 60, 61, 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 81, 82, 83, 85, 86, 87, 88, 89, 90, 91, 92, 94, 95, 96, 97, 98, 99, 101, 102, 103, 105]: - self.state = 1073 + + elif la_ == 2: + self.state = 1061 self.identifier() - self.state = 1078 + self.state = 1066 self._errHandler.sync(self) - _alt = self._interp.adaptivePredict(self._input,135,self._ctx) + _alt = self._interp.adaptivePredict(self._input,133,self._ctx) while _alt!=2 and _alt!=ATN.INVALID_ALT_NUMBER: if _alt==1: - self.state = 1074 + self.state = 1062 self.match(HogQLParser.COMMA) - self.state = 1075 + self.state = 1063 self.identifier() - self.state = 1080 + self.state = 1068 self._errHandler.sync(self) - _alt = self._interp.adaptivePredict(self._input,135,self._ctx) + _alt = self._interp.adaptivePredict(self._input,133,self._ctx) - self.state = 1082 + self.state = 1070 self._errHandler.sync(self) _la = self._input.LA(1) if _la==116: - self.state = 1081 + self.state = 1069 self.match(HogQLParser.COMMA) pass - else: - raise NoViableAltException(self) - self.state = 1086 + elif la_ == 3: + self.state = 1072 + self.match(HogQLParser.LPAREN) + self.state = 1073 + self.match(HogQLParser.RPAREN) + pass + + + self.state = 1076 self.match(HogQLParser.ARROW) - self.state = 1087 - self.columnExpr(0) + self.state = 1079 + self._errHandler.sync(self) + la_ = self._interp.adaptivePredict(self._input,136,self._ctx) + if la_ == 1: + self.state = 1077 + self.columnExpr(0) + pass + + elif la_ == 2: + self.state = 1078 + self.block() + pass + + except RecognitionException as re: localctx.exception = re self._errHandler.reportError(self, re) @@ -7910,77 +7877,77 @@ def accept(self, visitor:ParseTreeVisitor): def hogqlxTagElement(self): localctx = HogQLParser.HogqlxTagElementContext(self, self._ctx, self.state) - self.enterRule(localctx, 124, self.RULE_hogqlxTagElement) + self.enterRule(localctx, 120, self.RULE_hogqlxTagElement) self._la = 0 # Token type try: - self.state = 1121 + self.state = 1113 self._errHandler.sync(self) - la_ = self._interp.adaptivePredict(self._input,141,self._ctx) + la_ = self._interp.adaptivePredict(self._input,140,self._ctx) if la_ == 1: localctx = HogQLParser.HogqlxTagElementClosedContext(self, localctx) self.enterOuterAlt(localctx, 1) - self.state = 1089 + self.state = 1081 self.match(HogQLParser.LT) - self.state = 1090 + self.state = 1082 self.identifier() - self.state = 1094 + self.state = 1086 self._errHandler.sync(self) _la = self._input.LA(1) while (((_la) & ~0x3f) == 0 and ((1 << _la) & -725088338784043010) != 0) or ((((_la - 64)) & ~0x3f) == 0 and ((1 << (_la - 64)) & 3229277487103) != 0): - self.state = 1091 + self.state = 1083 self.hogqlxTagAttribute() - self.state = 1096 + self.state = 1088 self._errHandler.sync(self) _la = self._input.LA(1) - self.state = 1097 + self.state = 1089 self.match(HogQLParser.SLASH) - self.state = 1098 + self.state = 1090 self.match(HogQLParser.GT) pass elif la_ == 2: localctx = HogQLParser.HogqlxTagElementNestedContext(self, localctx) self.enterOuterAlt(localctx, 2) - self.state = 1100 + self.state = 1092 self.match(HogQLParser.LT) - self.state = 1101 + self.state = 1093 self.identifier() - self.state = 1105 + self.state = 1097 self._errHandler.sync(self) _la = self._input.LA(1) while (((_la) & ~0x3f) == 0 and ((1 << _la) & -725088338784043010) != 0) or ((((_la - 64)) & ~0x3f) == 0 and ((1 << (_la - 64)) & 3229277487103) != 0): - self.state = 1102 + self.state = 1094 self.hogqlxTagAttribute() - self.state = 1107 + self.state = 1099 self._errHandler.sync(self) _la = self._input.LA(1) - self.state = 1108 + self.state = 1100 self.match(HogQLParser.GT) - self.state = 1114 + self.state = 1106 self._errHandler.sync(self) - la_ = self._interp.adaptivePredict(self._input,140,self._ctx) + la_ = self._interp.adaptivePredict(self._input,139,self._ctx) if la_ == 1: - self.state = 1109 + self.state = 1101 self.hogqlxTagElement() elif la_ == 2: - self.state = 1110 + self.state = 1102 self.match(HogQLParser.LBRACE) - self.state = 1111 + self.state = 1103 self.columnExpr(0) - self.state = 1112 + self.state = 1104 self.match(HogQLParser.RBRACE) - self.state = 1116 + self.state = 1108 self.match(HogQLParser.LT) - self.state = 1117 + self.state = 1109 self.match(HogQLParser.SLASH) - self.state = 1118 + self.state = 1110 self.identifier() - self.state = 1119 + self.state = 1111 self.match(HogQLParser.GT) pass @@ -8037,38 +8004,38 @@ def accept(self, visitor:ParseTreeVisitor): def hogqlxTagAttribute(self): localctx = HogQLParser.HogqlxTagAttributeContext(self, self._ctx, self.state) - self.enterRule(localctx, 126, self.RULE_hogqlxTagAttribute) + self.enterRule(localctx, 122, self.RULE_hogqlxTagAttribute) try: - self.state = 1134 + self.state = 1126 self._errHandler.sync(self) - la_ = self._interp.adaptivePredict(self._input,142,self._ctx) + la_ = self._interp.adaptivePredict(self._input,141,self._ctx) if la_ == 1: self.enterOuterAlt(localctx, 1) - self.state = 1123 + self.state = 1115 self.identifier() - self.state = 1124 + self.state = 1116 self.match(HogQLParser.EQ_SINGLE) - self.state = 1125 + self.state = 1117 self.string() pass elif la_ == 2: self.enterOuterAlt(localctx, 2) - self.state = 1127 + self.state = 1119 self.identifier() - self.state = 1128 + self.state = 1120 self.match(HogQLParser.EQ_SINGLE) - self.state = 1129 + self.state = 1121 self.match(HogQLParser.LBRACE) - self.state = 1130 + self.state = 1122 self.columnExpr(0) - self.state = 1131 + self.state = 1123 self.match(HogQLParser.RBRACE) pass elif la_ == 3: self.enterOuterAlt(localctx, 3) - self.state = 1133 + self.state = 1125 self.identifier() pass @@ -8117,30 +8084,30 @@ def accept(self, visitor:ParseTreeVisitor): def withExprList(self): localctx = HogQLParser.WithExprListContext(self, self._ctx, self.state) - self.enterRule(localctx, 128, self.RULE_withExprList) + self.enterRule(localctx, 124, self.RULE_withExprList) self._la = 0 # Token type try: self.enterOuterAlt(localctx, 1) - self.state = 1136 + self.state = 1128 self.withExpr() - self.state = 1141 + self.state = 1133 self._errHandler.sync(self) - _alt = self._interp.adaptivePredict(self._input,143,self._ctx) + _alt = self._interp.adaptivePredict(self._input,142,self._ctx) while _alt!=2 and _alt!=ATN.INVALID_ALT_NUMBER: if _alt==1: - self.state = 1137 + self.state = 1129 self.match(HogQLParser.COMMA) - self.state = 1138 + self.state = 1130 self.withExpr() - self.state = 1143 + self.state = 1135 self._errHandler.sync(self) - _alt = self._interp.adaptivePredict(self._input,143,self._ctx) + _alt = self._interp.adaptivePredict(self._input,142,self._ctx) - self.state = 1145 + self.state = 1137 self._errHandler.sync(self) _la = self._input.LA(1) if _la==116: - self.state = 1144 + self.state = 1136 self.match(HogQLParser.COMMA) @@ -8222,34 +8189,34 @@ def accept(self, visitor:ParseTreeVisitor): def withExpr(self): localctx = HogQLParser.WithExprContext(self, self._ctx, self.state) - self.enterRule(localctx, 130, self.RULE_withExpr) + self.enterRule(localctx, 126, self.RULE_withExpr) try: - self.state = 1157 + self.state = 1149 self._errHandler.sync(self) - la_ = self._interp.adaptivePredict(self._input,145,self._ctx) + la_ = self._interp.adaptivePredict(self._input,144,self._ctx) if la_ == 1: localctx = HogQLParser.WithExprSubqueryContext(self, localctx) self.enterOuterAlt(localctx, 1) - self.state = 1147 + self.state = 1139 self.identifier() - self.state = 1148 + self.state = 1140 self.match(HogQLParser.AS) - self.state = 1149 + self.state = 1141 self.match(HogQLParser.LPAREN) - self.state = 1150 + self.state = 1142 self.selectUnionStmt() - self.state = 1151 + self.state = 1143 self.match(HogQLParser.RPAREN) pass elif la_ == 2: localctx = HogQLParser.WithExprColumnContext(self, localctx) self.enterOuterAlt(localctx, 2) - self.state = 1153 + self.state = 1145 self.columnExpr(0) - self.state = 1154 + self.state = 1146 self.match(HogQLParser.AS) - self.state = 1155 + self.state = 1147 self.identifier() pass @@ -8300,29 +8267,29 @@ def accept(self, visitor:ParseTreeVisitor): def columnIdentifier(self): localctx = HogQLParser.ColumnIdentifierContext(self, self._ctx, self.state) - self.enterRule(localctx, 132, self.RULE_columnIdentifier) + self.enterRule(localctx, 128, self.RULE_columnIdentifier) try: - self.state = 1166 + self.state = 1158 self._errHandler.sync(self) token = self._input.LA(1) if token in [128]: self.enterOuterAlt(localctx, 1) - self.state = 1159 + self.state = 1151 self.placeholder() pass elif token in [1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 30, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 44, 45, 46, 47, 48, 49, 50, 51, 53, 54, 55, 56, 58, 60, 61, 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 81, 82, 83, 85, 86, 87, 88, 89, 90, 91, 92, 94, 95, 96, 97, 98, 99, 101, 102, 103, 105]: self.enterOuterAlt(localctx, 2) - self.state = 1163 + self.state = 1155 self._errHandler.sync(self) - la_ = self._interp.adaptivePredict(self._input,146,self._ctx) + la_ = self._interp.adaptivePredict(self._input,145,self._ctx) if la_ == 1: - self.state = 1160 + self.state = 1152 self.tableIdentifier() - self.state = 1161 + self.state = 1153 self.match(HogQLParser.DOT) - self.state = 1165 + self.state = 1157 self.nestedIdentifier() pass else: @@ -8372,23 +8339,23 @@ def accept(self, visitor:ParseTreeVisitor): def nestedIdentifier(self): localctx = HogQLParser.NestedIdentifierContext(self, self._ctx, self.state) - self.enterRule(localctx, 134, self.RULE_nestedIdentifier) + self.enterRule(localctx, 130, self.RULE_nestedIdentifier) try: self.enterOuterAlt(localctx, 1) - self.state = 1168 + self.state = 1160 self.identifier() - self.state = 1173 + self.state = 1165 self._errHandler.sync(self) - _alt = self._interp.adaptivePredict(self._input,148,self._ctx) + _alt = self._interp.adaptivePredict(self._input,147,self._ctx) while _alt!=2 and _alt!=ATN.INVALID_ALT_NUMBER: if _alt==1: - self.state = 1169 + self.state = 1161 self.match(HogQLParser.DOT) - self.state = 1170 + self.state = 1162 self.identifier() - self.state = 1175 + self.state = 1167 self._errHandler.sync(self) - _alt = self._interp.adaptivePredict(self._input,148,self._ctx) + _alt = self._interp.adaptivePredict(self._input,147,self._ctx) except RecognitionException as re: localctx.exception = re @@ -8535,19 +8502,19 @@ def tableExpr(self, _p:int=0): _parentState = self.state localctx = HogQLParser.TableExprContext(self, self._ctx, _parentState) _prevctx = localctx - _startState = 136 - self.enterRecursionRule(localctx, 136, self.RULE_tableExpr, _p) + _startState = 132 + self.enterRecursionRule(localctx, 132, self.RULE_tableExpr, _p) try: self.enterOuterAlt(localctx, 1) - self.state = 1185 + self.state = 1177 self._errHandler.sync(self) - la_ = self._interp.adaptivePredict(self._input,149,self._ctx) + la_ = self._interp.adaptivePredict(self._input,148,self._ctx) if la_ == 1: localctx = HogQLParser.TableExprIdentifierContext(self, localctx) self._ctx = localctx _prevctx = localctx - self.state = 1177 + self.state = 1169 self.tableIdentifier() pass @@ -8555,7 +8522,7 @@ def tableExpr(self, _p:int=0): localctx = HogQLParser.TableExprFunctionContext(self, localctx) self._ctx = localctx _prevctx = localctx - self.state = 1178 + self.state = 1170 self.tableFunctionExpr() pass @@ -8563,11 +8530,11 @@ def tableExpr(self, _p:int=0): localctx = HogQLParser.TableExprSubqueryContext(self, localctx) self._ctx = localctx _prevctx = localctx - self.state = 1179 + self.state = 1171 self.match(HogQLParser.LPAREN) - self.state = 1180 + self.state = 1172 self.selectUnionStmt() - self.state = 1181 + self.state = 1173 self.match(HogQLParser.RPAREN) pass @@ -8575,7 +8542,7 @@ def tableExpr(self, _p:int=0): localctx = HogQLParser.TableExprTagContext(self, localctx) self._ctx = localctx _prevctx = localctx - self.state = 1183 + self.state = 1175 self.hogqlxTagElement() pass @@ -8583,15 +8550,15 @@ def tableExpr(self, _p:int=0): localctx = HogQLParser.TableExprPlaceholderContext(self, localctx) self._ctx = localctx _prevctx = localctx - self.state = 1184 + self.state = 1176 self.placeholder() pass self._ctx.stop = self._input.LT(-1) - self.state = 1195 + self.state = 1187 self._errHandler.sync(self) - _alt = self._interp.adaptivePredict(self._input,151,self._ctx) + _alt = self._interp.adaptivePredict(self._input,150,self._ctx) while _alt!=2 and _alt!=ATN.INVALID_ALT_NUMBER: if _alt==1: if self._parseListeners is not None: @@ -8599,29 +8566,29 @@ def tableExpr(self, _p:int=0): _prevctx = localctx localctx = HogQLParser.TableExprAliasContext(self, HogQLParser.TableExprContext(self, _parentctx, _parentState)) self.pushNewRecursionContext(localctx, _startState, self.RULE_tableExpr) - self.state = 1187 + self.state = 1179 if not self.precpred(self._ctx, 3): from antlr4.error.Errors import FailedPredicateException raise FailedPredicateException(self, "self.precpred(self._ctx, 3)") - self.state = 1191 + self.state = 1183 self._errHandler.sync(self) token = self._input.LA(1) if token in [20, 30, 39, 48, 105]: - self.state = 1188 + self.state = 1180 self.alias() pass elif token in [6]: - self.state = 1189 + self.state = 1181 self.match(HogQLParser.AS) - self.state = 1190 + self.state = 1182 self.identifier() pass else: raise NoViableAltException(self) - self.state = 1197 + self.state = 1189 self._errHandler.sync(self) - _alt = self._interp.adaptivePredict(self._input,151,self._ctx) + _alt = self._interp.adaptivePredict(self._input,150,self._ctx) except RecognitionException as re: localctx.exception = re @@ -8668,23 +8635,23 @@ def accept(self, visitor:ParseTreeVisitor): def tableFunctionExpr(self): localctx = HogQLParser.TableFunctionExprContext(self, self._ctx, self.state) - self.enterRule(localctx, 138, self.RULE_tableFunctionExpr) + self.enterRule(localctx, 134, self.RULE_tableFunctionExpr) self._la = 0 # Token type try: self.enterOuterAlt(localctx, 1) - self.state = 1198 + self.state = 1190 self.identifier() - self.state = 1199 + self.state = 1191 self.match(HogQLParser.LPAREN) - self.state = 1201 + self.state = 1193 self._errHandler.sync(self) _la = self._input.LA(1) if (((_la) & ~0x3f) == 0 and ((1 << _la) & -4503602311741442) != 0) or ((((_la - 64)) & ~0x3f) == 0 and ((1 << (_la - 64)) & 90493036243451903) != 0) or ((((_la - 128)) & ~0x3f) == 0 and ((1 << (_la - 128)) & 18455) != 0): - self.state = 1200 + self.state = 1192 self.tableArgList() - self.state = 1203 + self.state = 1195 self.match(HogQLParser.RPAREN) except RecognitionException as re: localctx.exception = re @@ -8728,20 +8695,20 @@ def accept(self, visitor:ParseTreeVisitor): def tableIdentifier(self): localctx = HogQLParser.TableIdentifierContext(self, self._ctx, self.state) - self.enterRule(localctx, 140, self.RULE_tableIdentifier) + self.enterRule(localctx, 136, self.RULE_tableIdentifier) try: self.enterOuterAlt(localctx, 1) - self.state = 1208 + self.state = 1200 self._errHandler.sync(self) - la_ = self._interp.adaptivePredict(self._input,153,self._ctx) + la_ = self._interp.adaptivePredict(self._input,152,self._ctx) if la_ == 1: - self.state = 1205 + self.state = 1197 self.databaseIdentifier() - self.state = 1206 + self.state = 1198 self.match(HogQLParser.DOT) - self.state = 1210 + self.state = 1202 self.identifier() except RecognitionException as re: localctx.exception = re @@ -8787,30 +8754,30 @@ def accept(self, visitor:ParseTreeVisitor): def tableArgList(self): localctx = HogQLParser.TableArgListContext(self, self._ctx, self.state) - self.enterRule(localctx, 142, self.RULE_tableArgList) + self.enterRule(localctx, 138, self.RULE_tableArgList) self._la = 0 # Token type try: self.enterOuterAlt(localctx, 1) - self.state = 1212 + self.state = 1204 self.columnExpr(0) - self.state = 1217 + self.state = 1209 self._errHandler.sync(self) - _alt = self._interp.adaptivePredict(self._input,154,self._ctx) + _alt = self._interp.adaptivePredict(self._input,153,self._ctx) while _alt!=2 and _alt!=ATN.INVALID_ALT_NUMBER: if _alt==1: - self.state = 1213 + self.state = 1205 self.match(HogQLParser.COMMA) - self.state = 1214 + self.state = 1206 self.columnExpr(0) - self.state = 1219 + self.state = 1211 self._errHandler.sync(self) - _alt = self._interp.adaptivePredict(self._input,154,self._ctx) + _alt = self._interp.adaptivePredict(self._input,153,self._ctx) - self.state = 1221 + self.state = 1213 self._errHandler.sync(self) _la = self._input.LA(1) if _la==116: - self.state = 1220 + self.state = 1212 self.match(HogQLParser.COMMA) @@ -8849,10 +8816,10 @@ def accept(self, visitor:ParseTreeVisitor): def databaseIdentifier(self): localctx = HogQLParser.DatabaseIdentifierContext(self, self._ctx, self.state) - self.enterRule(localctx, 144, self.RULE_databaseIdentifier) + self.enterRule(localctx, 140, self.RULE_databaseIdentifier) try: self.enterOuterAlt(localctx, 1) - self.state = 1223 + self.state = 1215 self.identifier() except RecognitionException as re: localctx.exception = re @@ -8900,22 +8867,22 @@ def accept(self, visitor:ParseTreeVisitor): def floatingLiteral(self): localctx = HogQLParser.FloatingLiteralContext(self, self._ctx, self.state) - self.enterRule(localctx, 146, self.RULE_floatingLiteral) + self.enterRule(localctx, 142, self.RULE_floatingLiteral) self._la = 0 # Token type try: - self.state = 1233 + self.state = 1225 self._errHandler.sync(self) token = self._input.LA(1) if token in [106]: self.enterOuterAlt(localctx, 1) - self.state = 1225 + self.state = 1217 self.match(HogQLParser.FLOATING_LITERAL) pass elif token in [120]: self.enterOuterAlt(localctx, 2) - self.state = 1226 + self.state = 1218 self.match(HogQLParser.DOT) - self.state = 1227 + self.state = 1219 _la = self._input.LA(1) if not(_la==107 or _la==108): self._errHandler.recoverInline(self) @@ -8925,15 +8892,15 @@ def floatingLiteral(self): pass elif token in [108]: self.enterOuterAlt(localctx, 3) - self.state = 1228 + self.state = 1220 self.match(HogQLParser.DECIMAL_LITERAL) - self.state = 1229 + self.state = 1221 self.match(HogQLParser.DOT) - self.state = 1231 + self.state = 1223 self._errHandler.sync(self) - la_ = self._interp.adaptivePredict(self._input,156,self._ctx) + la_ = self._interp.adaptivePredict(self._input,155,self._ctx) if la_ == 1: - self.state = 1230 + self.state = 1222 _la = self._input.LA(1) if not(_la==107 or _la==108): self._errHandler.recoverInline(self) @@ -9002,15 +8969,15 @@ def accept(self, visitor:ParseTreeVisitor): def numberLiteral(self): localctx = HogQLParser.NumberLiteralContext(self, self._ctx, self.state) - self.enterRule(localctx, 148, self.RULE_numberLiteral) + self.enterRule(localctx, 144, self.RULE_numberLiteral) self._la = 0 # Token type try: self.enterOuterAlt(localctx, 1) - self.state = 1236 + self.state = 1228 self._errHandler.sync(self) _la = self._input.LA(1) if _la==118 or _la==139: - self.state = 1235 + self.state = 1227 _la = self._input.LA(1) if not(_la==118 or _la==139): self._errHandler.recoverInline(self) @@ -9019,36 +8986,36 @@ def numberLiteral(self): self.consume() - self.state = 1244 + self.state = 1236 self._errHandler.sync(self) - la_ = self._interp.adaptivePredict(self._input,159,self._ctx) + la_ = self._interp.adaptivePredict(self._input,158,self._ctx) if la_ == 1: - self.state = 1238 + self.state = 1230 self.floatingLiteral() pass elif la_ == 2: - self.state = 1239 + self.state = 1231 self.match(HogQLParser.OCTAL_LITERAL) pass elif la_ == 3: - self.state = 1240 + self.state = 1232 self.match(HogQLParser.DECIMAL_LITERAL) pass elif la_ == 4: - self.state = 1241 + self.state = 1233 self.match(HogQLParser.HEXADECIMAL_LITERAL) pass elif la_ == 5: - self.state = 1242 + self.state = 1234 self.match(HogQLParser.INF) pass elif la_ == 6: - self.state = 1243 + self.state = 1235 self.match(HogQLParser.NAN_SQL) pass @@ -9094,24 +9061,24 @@ def accept(self, visitor:ParseTreeVisitor): def literal(self): localctx = HogQLParser.LiteralContext(self, self._ctx, self.state) - self.enterRule(localctx, 150, self.RULE_literal) + self.enterRule(localctx, 146, self.RULE_literal) try: - self.state = 1249 + self.state = 1241 self._errHandler.sync(self) token = self._input.LA(1) if token in [43, 57, 106, 107, 108, 109, 118, 120, 139]: self.enterOuterAlt(localctx, 1) - self.state = 1246 + self.state = 1238 self.numberLiteral() pass elif token in [110]: self.enterOuterAlt(localctx, 2) - self.state = 1247 + self.state = 1239 self.match(HogQLParser.STRING_LITERAL) pass elif token in [59]: self.enterOuterAlt(localctx, 3) - self.state = 1248 + self.state = 1240 self.match(HogQLParser.NULL_SQL) pass else: @@ -9172,11 +9139,11 @@ def accept(self, visitor:ParseTreeVisitor): def interval(self): localctx = HogQLParser.IntervalContext(self, self._ctx, self.state) - self.enterRule(localctx, 152, self.RULE_interval) + self.enterRule(localctx, 148, self.RULE_interval) self._la = 0 # Token type try: self.enterOuterAlt(localctx, 1) - self.state = 1251 + self.state = 1243 _la = self._input.LA(1) if not((((_la) & ~0x3f) == 0 and ((1 << _la) & 108086665936896000) != 0) or ((((_la - 70)) & ~0x3f) == 0 and ((1 << (_la - 70)) & 8724152577) != 0)): self._errHandler.recoverInline(self) @@ -9469,11 +9436,11 @@ def accept(self, visitor:ParseTreeVisitor): def keyword(self): localctx = HogQLParser.KeywordContext(self, self._ctx, self.state) - self.enterRule(localctx, 154, self.RULE_keyword) + self.enterRule(localctx, 150, self.RULE_keyword) self._la = 0 # Token type try: self.enterOuterAlt(localctx, 1) - self.state = 1253 + self.state = 1245 _la = self._input.LA(1) if not((((_la) & ~0x3f) == 0 and ((1 << _la) & -833175004720939010) != 0) or ((((_la - 64)) & ~0x3f) == 0 and ((1 << (_la - 64)) & 471908466623) != 0)): self._errHandler.recoverInline(self) @@ -9523,11 +9490,11 @@ def accept(self, visitor:ParseTreeVisitor): def keywordForAlias(self): localctx = HogQLParser.KeywordForAliasContext(self, self._ctx, self.state) - self.enterRule(localctx, 156, self.RULE_keywordForAlias) + self.enterRule(localctx, 152, self.RULE_keywordForAlias) self._la = 0 # Token type try: self.enterOuterAlt(localctx, 1) - self.state = 1255 + self.state = 1247 _la = self._input.LA(1) if not((((_la) & ~0x3f) == 0 and ((1 << _la) & 282025807314944) != 0)): self._errHandler.recoverInline(self) @@ -9572,19 +9539,19 @@ def accept(self, visitor:ParseTreeVisitor): def alias(self): localctx = HogQLParser.AliasContext(self, self._ctx, self.state) - self.enterRule(localctx, 158, self.RULE_alias) + self.enterRule(localctx, 154, self.RULE_alias) try: - self.state = 1259 + self.state = 1251 self._errHandler.sync(self) token = self._input.LA(1) if token in [105]: self.enterOuterAlt(localctx, 1) - self.state = 1257 + self.state = 1249 self.match(HogQLParser.IDENTIFIER) pass elif token in [20, 30, 39, 48]: self.enterOuterAlt(localctx, 2) - self.state = 1258 + self.state = 1250 self.keywordForAlias() pass else: @@ -9632,24 +9599,24 @@ def accept(self, visitor:ParseTreeVisitor): def identifier(self): localctx = HogQLParser.IdentifierContext(self, self._ctx, self.state) - self.enterRule(localctx, 160, self.RULE_identifier) + self.enterRule(localctx, 156, self.RULE_identifier) try: - self.state = 1264 + self.state = 1256 self._errHandler.sync(self) token = self._input.LA(1) if token in [105]: self.enterOuterAlt(localctx, 1) - self.state = 1261 + self.state = 1253 self.match(HogQLParser.IDENTIFIER) pass elif token in [21, 38, 55, 56, 70, 78, 97, 103]: self.enterOuterAlt(localctx, 2) - self.state = 1262 + self.state = 1254 self.interval() pass elif token in [1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 15, 16, 17, 18, 19, 20, 22, 23, 24, 25, 26, 27, 28, 30, 32, 33, 34, 35, 36, 37, 39, 40, 41, 42, 44, 45, 46, 47, 48, 49, 50, 51, 53, 54, 58, 60, 61, 62, 63, 64, 65, 66, 67, 68, 69, 71, 72, 73, 74, 75, 76, 77, 79, 80, 81, 82, 83, 85, 86, 87, 88, 89, 90, 91, 92, 94, 95, 96, 98, 99, 101, 102]: self.enterOuterAlt(localctx, 3) - self.state = 1263 + self.state = 1255 self.keyword() pass else: @@ -9697,14 +9664,14 @@ def accept(self, visitor:ParseTreeVisitor): def enumValue(self): localctx = HogQLParser.EnumValueContext(self, self._ctx, self.state) - self.enterRule(localctx, 162, self.RULE_enumValue) + self.enterRule(localctx, 158, self.RULE_enumValue) try: self.enterOuterAlt(localctx, 1) - self.state = 1266 + self.state = 1258 self.string() - self.state = 1267 + self.state = 1259 self.match(HogQLParser.EQ_SINGLE) - self.state = 1268 + self.state = 1260 self.numberLiteral() except RecognitionException as re: localctx.exception = re @@ -9747,14 +9714,14 @@ def accept(self, visitor:ParseTreeVisitor): def placeholder(self): localctx = HogQLParser.PlaceholderContext(self, self._ctx, self.state) - self.enterRule(localctx, 164, self.RULE_placeholder) + self.enterRule(localctx, 160, self.RULE_placeholder) try: self.enterOuterAlt(localctx, 1) - self.state = 1270 + self.state = 1262 self.match(HogQLParser.LBRACE) - self.state = 1271 + self.state = 1263 self.nestedIdentifier() - self.state = 1272 + self.state = 1264 self.match(HogQLParser.RBRACE) except RecognitionException as re: localctx.exception = re @@ -9794,19 +9761,19 @@ def accept(self, visitor:ParseTreeVisitor): def string(self): localctx = HogQLParser.StringContext(self, self._ctx, self.state) - self.enterRule(localctx, 166, self.RULE_string) + self.enterRule(localctx, 162, self.RULE_string) try: - self.state = 1276 + self.state = 1268 self._errHandler.sync(self) token = self._input.LA(1) if token in [110]: self.enterOuterAlt(localctx, 1) - self.state = 1274 + self.state = 1266 self.match(HogQLParser.STRING_LITERAL) pass elif token in [142]: self.enterOuterAlt(localctx, 2) - self.state = 1275 + self.state = 1267 self.templateString() pass else: @@ -9856,23 +9823,23 @@ def accept(self, visitor:ParseTreeVisitor): def templateString(self): localctx = HogQLParser.TemplateStringContext(self, self._ctx, self.state) - self.enterRule(localctx, 168, self.RULE_templateString) + self.enterRule(localctx, 164, self.RULE_templateString) self._la = 0 # Token type try: self.enterOuterAlt(localctx, 1) - self.state = 1278 + self.state = 1270 self.match(HogQLParser.QUOTE_SINGLE_TEMPLATE) - self.state = 1282 + self.state = 1274 self._errHandler.sync(self) _la = self._input.LA(1) while _la==156 or _la==157: - self.state = 1279 + self.state = 1271 self.stringContents() - self.state = 1284 + self.state = 1276 self._errHandler.sync(self) _la = self._input.LA(1) - self.state = 1285 + self.state = 1277 self.match(HogQLParser.QUOTE_SINGLE) except RecognitionException as re: localctx.exception = re @@ -9918,23 +9885,23 @@ def accept(self, visitor:ParseTreeVisitor): def stringContents(self): localctx = HogQLParser.StringContentsContext(self, self._ctx, self.state) - self.enterRule(localctx, 170, self.RULE_stringContents) + self.enterRule(localctx, 166, self.RULE_stringContents) try: - self.state = 1292 + self.state = 1284 self._errHandler.sync(self) token = self._input.LA(1) if token in [157]: self.enterOuterAlt(localctx, 1) - self.state = 1287 + self.state = 1279 self.match(HogQLParser.STRING_ESCAPE_TRIGGER) - self.state = 1288 + self.state = 1280 self.columnExpr(0) - self.state = 1289 + self.state = 1281 self.match(HogQLParser.RBRACE) pass elif token in [156]: self.enterOuterAlt(localctx, 2) - self.state = 1291 + self.state = 1283 self.match(HogQLParser.STRING_TEXT) pass else: @@ -9984,23 +9951,23 @@ def accept(self, visitor:ParseTreeVisitor): def fullTemplateString(self): localctx = HogQLParser.FullTemplateStringContext(self, self._ctx, self.state) - self.enterRule(localctx, 172, self.RULE_fullTemplateString) + self.enterRule(localctx, 168, self.RULE_fullTemplateString) self._la = 0 # Token type try: self.enterOuterAlt(localctx, 1) - self.state = 1294 + self.state = 1286 self.match(HogQLParser.QUOTE_SINGLE_TEMPLATE_FULL) - self.state = 1298 + self.state = 1290 self._errHandler.sync(self) _la = self._input.LA(1) while _la==158 or _la==159: - self.state = 1295 + self.state = 1287 self.stringContentsFull() - self.state = 1300 + self.state = 1292 self._errHandler.sync(self) _la = self._input.LA(1) - self.state = 1301 + self.state = 1293 self.match(HogQLParser.EOF) except RecognitionException as re: localctx.exception = re @@ -10046,23 +10013,23 @@ def accept(self, visitor:ParseTreeVisitor): def stringContentsFull(self): localctx = HogQLParser.StringContentsFullContext(self, self._ctx, self.state) - self.enterRule(localctx, 174, self.RULE_stringContentsFull) + self.enterRule(localctx, 170, self.RULE_stringContentsFull) try: - self.state = 1308 + self.state = 1300 self._errHandler.sync(self) token = self._input.LA(1) if token in [159]: self.enterOuterAlt(localctx, 1) - self.state = 1303 + self.state = 1295 self.match(HogQLParser.FULL_STRING_ESCAPE_TRIGGER) - self.state = 1304 + self.state = 1296 self.columnExpr(0) - self.state = 1305 + self.state = 1297 self.match(HogQLParser.RBRACE) pass elif token in [158]: self.enterOuterAlt(localctx, 2) - self.state = 1307 + self.state = 1299 self.match(HogQLParser.FULL_STRING_TEXT) pass else: @@ -10083,7 +10050,7 @@ def sempred(self, localctx:RuleContext, ruleIndex:int, predIndex:int): self._predicates = dict() self._predicates[39] = self.joinExpr_sempred self._predicates[58] = self.columnExpr_sempred - self._predicates[68] = self.tableExpr_sempred + self._predicates[66] = self.tableExpr_sempred pred = self._predicates.get(ruleIndex, None) if pred is None: raise Exception("No predicate with index:" + str(ruleIndex)) @@ -10101,71 +10068,75 @@ def joinExpr_sempred(self, localctx:JoinExprContext, predIndex:int): def columnExpr_sempred(self, localctx:ColumnExprContext, predIndex:int): if predIndex == 2: - return self.precpred(self._ctx, 18) + return self.precpred(self._ctx, 19) if predIndex == 3: - return self.precpred(self._ctx, 17) + return self.precpred(self._ctx, 18) if predIndex == 4: - return self.precpred(self._ctx, 16) + return self.precpred(self._ctx, 17) if predIndex == 5: - return self.precpred(self._ctx, 14) + return self.precpred(self._ctx, 15) if predIndex == 6: - return self.precpred(self._ctx, 12) + return self.precpred(self._ctx, 13) if predIndex == 7: - return self.precpred(self._ctx, 11) + return self.precpred(self._ctx, 12) if predIndex == 8: - return self.precpred(self._ctx, 10) + return self.precpred(self._ctx, 11) if predIndex == 9: - return self.precpred(self._ctx, 9) + return self.precpred(self._ctx, 10) if predIndex == 10: - return self.precpred(self._ctx, 25) + return self.precpred(self._ctx, 30) if predIndex == 11: - return self.precpred(self._ctx, 24) + return self.precpred(self._ctx, 26) if predIndex == 12: - return self.precpred(self._ctx, 23) + return self.precpred(self._ctx, 25) if predIndex == 13: - return self.precpred(self._ctx, 22) + return self.precpred(self._ctx, 24) if predIndex == 14: - return self.precpred(self._ctx, 21) + return self.precpred(self._ctx, 23) if predIndex == 15: - return self.precpred(self._ctx, 20) + return self.precpred(self._ctx, 22) if predIndex == 16: - return self.precpred(self._ctx, 15) + return self.precpred(self._ctx, 21) if predIndex == 17: - return self.precpred(self._ctx, 8) + return self.precpred(self._ctx, 16) - def tableExpr_sempred(self, localctx:TableExprContext, predIndex:int): if predIndex == 18: + return self.precpred(self._ctx, 9) + + + def tableExpr_sempred(self, localctx:TableExprContext, predIndex:int): + if predIndex == 19: return self.precpred(self._ctx, 3) diff --git a/posthog/hogql/grammar/HogQLParserVisitor.py b/posthog/hogql/grammar/HogQLParserVisitor.py index bcd327d6abc68..be0ba9f0e29da 100644 --- a/posthog/hogql/grammar/HogQLParserVisitor.py +++ b/posthog/hogql/grammar/HogQLParserVisitor.py @@ -1,4 +1,4 @@ -# Generated from HogQLParser.g4 by ANTLR 4.13.1 +# Generated from HogQLParser.g4 by ANTLR 4.13.2 from antlr4 import * if "." in __name__: from .HogQLParser import HogQLParser @@ -459,6 +459,11 @@ def visitColumnExprTuple(self, ctx:HogQLParser.ColumnExprTupleContext): return self.visitChildren(ctx) + # Visit a parse tree produced by HogQLParser#ColumnExprCall. + def visitColumnExprCall(self, ctx:HogQLParser.ColumnExprCallContext): + return self.visitChildren(ctx) + + # Visit a parse tree produced by HogQLParser#ColumnExprArrayAccess. def visitColumnExprArrayAccess(self, ctx:HogQLParser.ColumnExprArrayAccessContext): return self.visitChildren(ctx) @@ -524,6 +529,11 @@ def visitColumnExprWinFunction(self, ctx:HogQLParser.ColumnExprWinFunctionContex return self.visitChildren(ctx) + # Visit a parse tree produced by HogQLParser#ColumnExprLambda. + def visitColumnExprLambda(self, ctx:HogQLParser.ColumnExprLambdaContext): + return self.visitChildren(ctx) + + # Visit a parse tree produced by HogQLParser#ColumnExprIdentifier. def visitColumnExprIdentifier(self, ctx:HogQLParser.ColumnExprIdentifierContext): return self.visitChildren(ctx) @@ -539,16 +549,6 @@ def visitColumnExprAsterisk(self, ctx:HogQLParser.ColumnExprAsteriskContext): return self.visitChildren(ctx) - # Visit a parse tree produced by HogQLParser#columnArgList. - def visitColumnArgList(self, ctx:HogQLParser.ColumnArgListContext): - return self.visitChildren(ctx) - - - # Visit a parse tree produced by HogQLParser#columnArgExpr. - def visitColumnArgExpr(self, ctx:HogQLParser.ColumnArgExprContext): - return self.visitChildren(ctx) - - # Visit a parse tree produced by HogQLParser#columnLambdaExpr. def visitColumnLambdaExpr(self, ctx:HogQLParser.ColumnLambdaExprContext): return self.visitChildren(ctx) diff --git a/posthog/hogql/grammar/README.md b/posthog/hogql/grammar/README.md index 4022ba71825a7..1b9837a2077ac 100644 --- a/posthog/hogql/grammar/README.md +++ b/posthog/hogql/grammar/README.md @@ -2,16 +2,18 @@ Grammar is located inside `HogQLLexer.g4` and `HogQLParser.g4` files. -To generate source code you need to install locally the `antlr` binary: +To generate source code you need to install locally the `antlr` binary. Run this on macOS: ```bash brew install antlr ``` -or this piece of art if you're using bash on ubuntu for quick access: +In case this installs a newer version than 4.13.2, update [ci-hog.yml](https://github.com/PostHog/posthog/blob/master/.github/workflows/ci-hog.yml) to reflect the changes. + +Run this if you're using bash on ubuntu: ```bash -export ANTLR_VERSION=4.11.1 +export ANTLR_VERSION=4.13.2 sudo apt-get install default-jre mkdir antlr diff --git a/posthog/hogql/parser.py b/posthog/hogql/parser.py index 96afe5ae15bc5..71708d1987032 100644 --- a/posthog/hogql/parser.py +++ b/posthog/hogql/parser.py @@ -907,16 +907,16 @@ def visitColumnExprNot(self, ctx: HogQLParser.ColumnExprNotContext): def visitColumnExprWinFunctionTarget(self, ctx: HogQLParser.ColumnExprWinFunctionTargetContext): return ast.WindowFunction( name=self.visit(ctx.identifier(0)), - exprs=self.visit(ctx.columnExprList()) if ctx.columnExprList() else [], - args=self.visit(ctx.columnArgList()) if ctx.columnArgList() else [], + exprs=self.visit(ctx.columnExprs) if ctx.columnExprs else [], + args=self.visit(ctx.columnArgList) if ctx.columnArgList else [], over_identifier=self.visit(ctx.identifier(1)), ) def visitColumnExprWinFunction(self, ctx: HogQLParser.ColumnExprWinFunctionContext): return ast.WindowFunction( name=self.visit(ctx.identifier()), - exprs=self.visit(ctx.columnExprList()) if ctx.columnExprList() else [], - args=self.visit(ctx.columnArgList()) if ctx.columnArgList() else [], + exprs=self.visit(ctx.columnExprs) if ctx.columnExprs else [], + args=self.visit(ctx.columnArgList) if ctx.columnArgList else [], over_expr=self.visit(ctx.windowExpr()) if ctx.windowExpr() else None, ) @@ -925,10 +925,13 @@ def visitColumnExprIdentifier(self, ctx: HogQLParser.ColumnExprIdentifierContext def visitColumnExprFunction(self, ctx: HogQLParser.ColumnExprFunctionContext): name = self.visit(ctx.identifier()) - column_expr_list = ctx.columnExprList() - parameters = self.visit(column_expr_list) if column_expr_list is not None else None - column_arg_list = ctx.columnArgList() - args = self.visit(column_arg_list) if column_arg_list is not None else [] + + parameters: list[ast.Expr] | None = self.visit(ctx.columnExprs) if ctx.columnExprs is not None else None + # two sets of parameters fn()(), return an empty list for the first even if no parameters + if ctx.LPAREN(1) and parameters is None: + parameters = [] + + args: list[ast.Expr] = self.visit(ctx.columnArgList) if ctx.columnArgList is not None else [] distinct = True if ctx.DISTINCT() else False return ast.Call(name=name, params=parameters, args=args, distinct=distinct) @@ -941,16 +944,10 @@ def visitColumnExprAsterisk(self, ctx: HogQLParser.ColumnExprAsteriskContext): def visitColumnExprTagElement(self, ctx: HogQLParser.ColumnExprTagElementContext): return self.visit(ctx.hogqlxTagElement()) - def visitColumnArgList(self, ctx: HogQLParser.ColumnArgListContext): - return [self.visit(arg) for arg in ctx.columnArgExpr()] - - def visitColumnArgExpr(self, ctx: HogQLParser.ColumnArgExprContext): - return self.visitChildren(ctx) - def visitColumnLambdaExpr(self, ctx: HogQLParser.ColumnLambdaExprContext): return ast.Lambda( args=[self.visit(identifier) for identifier in ctx.identifier()], - expr=self.visit(ctx.columnExpr()), + expr=self.visit(ctx.columnExpr() or ctx.block()), ) def visitWithExprList(self, ctx: HogQLParser.WithExprListContext): @@ -1084,6 +1081,11 @@ def visitColumnExprNullish(self, ctx: HogQLParser.ColumnExprNullishContext): args=[self.visit(ctx.columnExpr(0)), self.visit(ctx.columnExpr(1))], ) + def visitColumnExprCall(self, ctx: HogQLParser.ColumnExprCallContext): + return ast.ExprCall( + expr=self.visit(ctx.columnExpr()), args=self.visit(ctx.columnExprList()) if ctx.columnExprList() else [] + ) + def visitHogqlxTagElementClosed(self, ctx: HogQLParser.HogqlxTagElementClosedContext): kind = self.visit(ctx.identifier()) attributes = [self.visit(a) for a in ctx.hogqlxTagAttribute()] if ctx.hogqlxTagAttribute() else [] diff --git a/posthog/hogql/resolver.py b/posthog/hogql/resolver.py index 332e81324871f..1ff76fc46613b 100644 --- a/posthog/hogql/resolver.py +++ b/posthog/hogql/resolver.py @@ -518,6 +518,12 @@ def visit_call(self, node: ast.Call): ) return node + def visit_expr_call(self, node: ast.ExprCall): + raise QueryError("You can only call simple functions in HogQL, not expressions") + + def visit_block(self, node: ast.Block): + raise QueryError("You can not use blocks in HogQL") + def visit_lambda(self, node: ast.Lambda): """Visit each SELECT query or subquery.""" diff --git a/posthog/hogql/test/test_metadata.py b/posthog/hogql/test/test_metadata.py index 1c0eb3ad20377..e19778e6f3f20 100644 --- a/posthog/hogql/test/test_metadata.py +++ b/posthog/hogql/test/test_metadata.py @@ -2,7 +2,7 @@ from posthog.hogql.metadata import get_hogql_metadata from posthog.models import PropertyDefinition, Cohort -from posthog.schema import HogQLMetadata, HogQLMetadataResponse, HogQLQuery +from posthog.schema import HogQLMetadata, HogQLMetadataResponse, HogQLQuery, HogLanguage from posthog.test.base import APIBaseTest, ClickhouseTestMixin from django.test import override_settings @@ -14,7 +14,7 @@ def _expr(self, query: str, table: str = "events", debug=True) -> HogQLMetadataR return get_hogql_metadata( query=HogQLMetadata( kind="HogQLMetadata", - language="hogQLExpr", + language=HogLanguage.HOG_QL_EXPR, query=query, sourceQuery=HogQLQuery(query=f"select * from {table}"), response=None, @@ -25,19 +25,21 @@ def _expr(self, query: str, table: str = "events", debug=True) -> HogQLMetadataR def _select(self, query: str) -> HogQLMetadataResponse: return get_hogql_metadata( - query=HogQLMetadata(kind="HogQLMetadata", language="hogQL", query=query, response=None), + query=HogQLMetadata(kind="HogQLMetadata", language=HogLanguage.HOG_QL, query=query, response=None), team=self.team, ) def _program(self, query: str, globals: Optional[dict] = None) -> HogQLMetadataResponse: return get_hogql_metadata( - query=HogQLMetadata(kind="HogQLMetadata", language="hog", query=query, globals=globals, response=None), + query=HogQLMetadata( + kind="HogQLMetadata", language=HogLanguage.HOG, query=query, globals=globals, response=None + ), team=self.team, ) def _template(self, query: str) -> HogQLMetadataResponse: return get_hogql_metadata( - query=HogQLMetadata(kind="HogQLMetadata", language="hogTemplate", query=query, response=None), + query=HogQLMetadata(kind="HogQLMetadata", language=HogLanguage.HOG_TEMPLATE, query=query, response=None), team=self.team, ) diff --git a/posthog/hogql/test/test_printer.py b/posthog/hogql/test/test_printer.py index 83efcb2aa2129..1ab8444294e27 100644 --- a/posthog/hogql/test/test_printer.py +++ b/posthog/hogql/test/test_printer.py @@ -444,12 +444,13 @@ def test_expr_parse_errors_poe_off(self): def test_expr_syntax_errors(self): self._assert_expr_error("(", "no viable alternative at input '('") - self._assert_expr_error("())", "no viable alternative at input '()'") + self._assert_expr_error("())", "mismatched input ')' expecting '->'") self._assert_expr_error("(3 57", "no viable alternative at input '(3 57'") self._assert_expr_error("select query from events", "mismatched input 'query' expecting ") self._assert_expr_error("this makes little sense", "mismatched input 'makes' expecting ") self._assert_expr_error("1;2", "mismatched input ';' expecting ") - self._assert_expr_error("b.a(bla)", "mismatched input '(' expecting ") + self._assert_expr_error("b.a(bla)", "You can only call simple functions in HogQL, not expressions") + self._assert_expr_error("a -> { print(2) }", "You can not use blocks in HogQL") def test_logic(self): self.assertEqual( diff --git a/posthog/hogql/visitor.py b/posthog/hogql/visitor.py index 025ecc5f52e92..2a628181ae225 100644 --- a/posthog/hogql/visitor.py +++ b/posthog/hogql/visitor.py @@ -102,6 +102,11 @@ def visit_call(self, node: ast.Call): for expr in node.params: self.visit(expr) + def visit_expr_call(self, node: ast.ExprCall): + self.visit(node.expr) + for expr in node.args: + self.visit(expr) + def visit_sample_expr(self, node: ast.SampleExpr): self.visit(node.sample_value) self.visit(node.offset_value) @@ -507,6 +512,15 @@ def visit_call(self, node: ast.Call): distinct=node.distinct, ) + def visit_expr_call(self, node: ast.ExprCall): + return ast.ExprCall( + start=None if self.clear_locations else node.start, + end=None if self.clear_locations else node.end, + type=None if self.clear_types else node.type, + expr=self.visit(node.expr), + args=[self.visit(arg) for arg in node.args], + ) + def visit_ratio_expr(self, node: ast.RatioExpr): return ast.RatioExpr( start=None if self.clear_locations else node.start, From 2a9fe90d1799e63d0853533a898ee41efa8a5e9c Mon Sep 17 00:00:00 2001 From: Marius Andra Date: Mon, 26 Aug 2024 16:38:38 +0200 Subject: [PATCH 05/21] few more tests --- posthog/hogql/test/_test_parser.py | 92 ++++++++++++++++++++++++++++++ 1 file changed, 92 insertions(+) diff --git a/posthog/hogql/test/_test_parser.py b/posthog/hogql/test/_test_parser.py index b1140be100b5d..280ee65ecf3cf 100644 --- a/posthog/hogql/test/_test_parser.py +++ b/posthog/hogql/test/_test_parser.py @@ -199,6 +199,50 @@ def test_tuples(self): self.assertEqual(self._expr("(1)"), ast.Constant(value=1)) def test_lambdas(self): + self.assertEqual( + self._expr("(x, y) -> x * y"), + ast.Lambda( + args=["x", "y"], + expr=ast.ArithmeticOperation( + op=ast.ArithmeticOperationOp.Mult, + left=ast.Field(chain=["x"]), + right=ast.Field(chain=["y"]), + ), + ), + ) + self.assertEqual( + self._expr("x, y -> x * y"), + ast.Lambda( + args=["x", "y"], + expr=ast.ArithmeticOperation( + op=ast.ArithmeticOperationOp.Mult, + left=ast.Field(chain=["x"]), + right=ast.Field(chain=["y"]), + ), + ), + ) + self.assertEqual( + self._expr("(x) -> x * y"), + ast.Lambda( + args=["x"], + expr=ast.ArithmeticOperation( + op=ast.ArithmeticOperationOp.Mult, + left=ast.Field(chain=["x"]), + right=ast.Field(chain=["y"]), + ), + ), + ) + self.assertEqual( + self._expr("x -> x * y"), + ast.Lambda( + args=["x"], + expr=ast.ArithmeticOperation( + op=ast.ArithmeticOperationOp.Mult, + left=ast.Field(chain=["x"]), + right=ast.Field(chain=["y"]), + ), + ), + ) self.assertEqual( self._expr("arrayMap(x -> x * 2)"), ast.Call( @@ -248,6 +292,54 @@ def test_lambdas(self): ), ) + def test_lambda_blocks(self): + self.assertEqual( + self._expr("(x, y) -> { print('hello'); return x * y }"), + ast.Lambda( + args=["x", "y"], + expr=ast.Block( + declarations=[ + ast.ExprStatement(expr=ast.Call(name="print", args=[ast.Constant(value="hello")])), + ast.ReturnStatement( + expr=ast.ArithmeticOperation( + op=ast.ArithmeticOperationOp.Mult, + left=ast.Field(chain=["x"]), + right=ast.Field(chain=["y"]), + ) + ), + ] + ), + ), + ) + + def test_call_expr(self): + self.assertEqual( + self._expr("asd.asd(123)"), + ast.ExprCall( + expr=ast.Field(chain=["asd", "asd"]), + args=[ast.Constant(value=123)], + ), + ) + self.assertEqual( + self._expr("asd['asd'](123)"), + ast.ExprCall( + expr=ast.ArrayAccess(array=ast.Field(chain=["asd"]), property=ast.Constant(value="asd")), + args=[ast.Constant(value=123)], + ), + ) + self.assertEqual( + self._expr("(x -> x * 2)(3)"), + ast.ExprCall( + expr=ast.Lambda( + args=["x"], + expr=ast.ArithmeticOperation( + op=ast.ArithmeticOperationOp.Mult, left=ast.Field(chain=["x"]), right=ast.Constant(value=2) + ), + ), + args=[ast.Constant(value=3)], + ), + ) + def test_strings(self): self.assertEqual(self._expr("'null'"), ast.Constant(value="null")) self.assertEqual(self._expr("'n''ull'"), ast.Constant(value="n'ull")) From c2a9644a896773ad5ec8cd1ae11531d6a2908232 Mon Sep 17 00:00:00 2001 From: Marius Andra Date: Mon, 26 Aug 2024 16:55:01 +0200 Subject: [PATCH 06/21] can be a block --- posthog/hogql/ast.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/posthog/hogql/ast.py b/posthog/hogql/ast.py index 30602da11df05..5758fbe891187 100644 --- a/posthog/hogql/ast.py +++ b/posthog/hogql/ast.py @@ -683,7 +683,7 @@ class Tuple(Expr): @dataclass(kw_only=True) class Lambda(Expr): args: list[str] - expr: Expr + expr: Expr | Block @dataclass(kw_only=True) From 5fafd52a0b388d45752d32d187512ee57bd49104 Mon Sep 17 00:00:00 2001 From: Marius Andra Date: Mon, 26 Aug 2024 17:37:54 +0200 Subject: [PATCH 07/21] blergh --- posthog/hogql/resolver.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/posthog/hogql/resolver.py b/posthog/hogql/resolver.py index 1ff76fc46613b..c427ae08bb2e3 100644 --- a/posthog/hogql/resolver.py +++ b/posthog/hogql/resolver.py @@ -538,7 +538,7 @@ def visit_lambda(self, node: ast.Lambda): new_node = cast(ast.Lambda, clone_expr(node)) new_node.type = node_type - new_node.expr = self.visit(new_node.expr) + new_node.expr = cast(ast.Expr | ast.Block, self.visit(new_node.expr)) self.scopes.pop() From faf5442a44b16492901817bdf20ee819ef9fb777 Mon Sep 17 00:00:00 2001 From: Marius Andra Date: Mon, 26 Aug 2024 18:02:59 +0200 Subject: [PATCH 08/21] fix typing --- posthog/hogql/resolver.py | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/posthog/hogql/resolver.py b/posthog/hogql/resolver.py index c427ae08bb2e3..54b5f5f298756 100644 --- a/posthog/hogql/resolver.py +++ b/posthog/hogql/resolver.py @@ -112,7 +112,7 @@ def __init__( self.database = context.database self.cte_counter = 0 - def visit(self, node: ast.Expr | None) -> ast.Expr: + def visit(self, node: ast.AST | None): if isinstance(node, ast.Expr) and node.type is not None: raise ResolutionError( f"Type already resolved for {type(node).__name__} ({type(node.type).__name__}). Can't run again." @@ -538,7 +538,7 @@ def visit_lambda(self, node: ast.Lambda): new_node = cast(ast.Lambda, clone_expr(node)) new_node.type = node_type - new_node.expr = cast(ast.Expr | ast.Block, self.visit(new_node.expr)) + new_node.expr = self.visit(new_node.expr) self.scopes.pop() From 9c4bfa16ce30f935721f2515db4a9ccb2cdb40de Mon Sep 17 00:00:00 2001 From: Marius Andra Date: Mon, 26 Aug 2024 19:00:28 +0200 Subject: [PATCH 09/21] update --- mypy-baseline.txt | 93 +++++++++++++----------------- posthog/hogql/test/test_printer.py | 2 +- 2 files changed, 41 insertions(+), 54 deletions(-) diff --git a/mypy-baseline.txt b/mypy-baseline.txt index bf03484babdbf..4ec481c6b94fa 100644 --- a/mypy-baseline.txt +++ b/mypy-baseline.txt @@ -141,36 +141,23 @@ posthog/hogql_queries/utils/query_date_range.py:0: error: Incompatible default f posthog/hogql_queries/utils/query_date_range.py:0: note: PEP 484 prohibits implicit Optional. Accordingly, mypy has changed its default to no_implicit_optional=True posthog/hogql_queries/utils/query_date_range.py:0: note: Use https://github.com/hauntsaninja/no_implicit_optional to automatically upgrade your codebase posthog/hogql_queries/utils/query_date_range.py:0: error: Item "None" of "IntervalType | None" has no attribute "name" [union-attr] -posthog/hogql/resolver.py:0: error: Argument 1 of "visit" is incompatible with supertype "Visitor"; supertype defines the argument type as "AST | None" [override] -posthog/hogql/resolver.py:0: note: This violates the Liskov substitution principle -posthog/hogql/resolver.py:0: note: See https://mypy.readthedocs.io/en/stable/common_issues.html#incompatible-overrides posthog/hogql/resolver.py:0: error: List comprehension has incompatible type List[SelectQueryType | None]; expected List[SelectQueryType] [misc] -posthog/hogql/resolver.py:0: error: Incompatible types in assignment (expression has type "Expr", variable has type "JoinExpr | None") [assignment] posthog/hogql/resolver.py:0: error: Need type annotation for "columns_with_visible_alias" (hint: "columns_with_visible_alias: dict[, ] = ...") [var-annotated] -posthog/hogql/resolver.py:0: error: Incompatible types in assignment (expression has type "Type | None", target has type "Type") [assignment] -posthog/hogql/resolver.py:0: error: Incompatible types in assignment (expression has type "Type | None", target has type "Type") [assignment] -posthog/hogql/resolver.py:0: error: List comprehension has incompatible type List[Expr]; expected List[OrderExpr] [misc] -posthog/hogql/resolver.py:0: error: Value expression in dictionary comprehension has incompatible type "Expr"; expected type "WindowExpr" [misc] posthog/hogql/resolver.py:0: error: Statement is unreachable [unreachable] posthog/hogql/resolver.py:0: error: Incompatible types in assignment (expression has type "Expr", variable has type "SelectQuery | SelectUnionQuery | Field | None") [assignment] posthog/hogql/resolver.py:0: error: Item "None" of "Database | None" has no attribute "get_table" [union-attr] -posthog/hogql/resolver.py:0: error: Incompatible types in assignment (expression has type "Expr", variable has type "JoinExpr") [assignment] posthog/hogql/resolver.py:0: error: Incompatible types in assignment (expression has type "TableType", variable has type "LazyTableType") [assignment] posthog/hogql/resolver.py:0: error: Argument "table_type" to "TableAliasType" has incompatible type "LazyTableType"; expected "TableType" [arg-type] posthog/hogql/resolver.py:0: error: Incompatible types in assignment (expression has type "LazyTableType", variable has type "TableAliasType") [assignment] posthog/hogql/resolver.py:0: error: Argument 1 to "clone_expr" has incompatible type "SelectQuery | SelectUnionQuery | Field | None"; expected "Expr" [arg-type] -posthog/hogql/resolver.py:0: error: Incompatible types in assignment (expression has type "Expr", variable has type "JoinExpr | None") [assignment] posthog/hogql/resolver.py:0: error: Statement is unreachable [unreachable] posthog/hogql/resolver.py:0: error: Item "None" of "JoinExpr | None" has no attribute "join_type" [union-attr] -posthog/hogql/resolver.py:0: error: Incompatible types in assignment (expression has type "Expr", variable has type "SampleExpr | None") [assignment] posthog/hogql/resolver.py:0: error: Argument "select_query_type" to "SelectViewType" has incompatible type "SelectQueryType | None"; expected "SelectQueryType | SelectUnionQueryType" [arg-type] posthog/hogql/resolver.py:0: error: Item "None" of "SelectQuery | SelectUnionQuery | Field | None" has no attribute "type" [union-attr] posthog/hogql/resolver.py:0: error: Argument "select_query_type" to "SelectQueryAliasType" has incompatible type "Type | Any | None"; expected "SelectQueryType | SelectUnionQueryType" [arg-type] posthog/hogql/resolver.py:0: error: Item "None" of "SelectQuery | SelectUnionQuery | Field | None" has no attribute "type" [union-attr] posthog/hogql/resolver.py:0: error: Incompatible types in assignment (expression has type "Type | Any | None", variable has type "BaseTableType | SelectUnionQueryType | SelectQueryType | SelectQueryAliasType | SelectViewType | None") [assignment] posthog/hogql/resolver.py:0: error: Argument 1 to "append" of "list" has incompatible type "BaseTableType | SelectUnionQueryType | SelectQueryType | SelectQueryAliasType | SelectViewType | None"; expected "SelectQueryType | SelectUnionQueryType" [arg-type] -posthog/hogql/resolver.py:0: error: Incompatible types in assignment (expression has type "Expr", variable has type "JoinExpr | None") [assignment] -posthog/hogql/resolver.py:0: error: Incompatible types in assignment (expression has type "Expr", variable has type "SampleExpr | None") [assignment] posthog/hogql/resolver.py:0: error: Statement is unreachable [unreachable] posthog/hogql/resolver.py:0: error: Statement is unreachable [unreachable] posthog/hogql/resolver.py:0: error: Item "None" of "Type | None" has no attribute "resolve_constant_type" [union-attr] @@ -277,8 +264,6 @@ posthog/demo/matrix/taxonomy_inference.py:0: error: Name "timezone.datetime" is posthog/demo/matrix/matrix.py:0: error: Name "timezone.datetime" is not defined [name-defined] posthog/demo/matrix/matrix.py:0: error: Name "timezone.datetime" is not defined [name-defined] posthog/demo/matrix/matrix.py:0: error: Name "timezone.datetime" is not defined [name-defined] -posthog/api/utils.py:0: error: Incompatible types in assignment (expression has type "type[EventDefinition]", variable has type "type[EnterpriseEventDefinition]") [assignment] -posthog/api/utils.py:0: error: Argument 1 to "UUID" has incompatible type "int | str"; expected "str | None" [arg-type] posthog/api/shared.py:0: error: Incompatible return value type (got "int | None", expected "Level | None") [return-value] ee/billing/quota_limiting.py:0: error: Argument 2 to "feature_enabled" has incompatible type "UUID"; expected "str" [arg-type] ee/billing/quota_limiting.py:0: error: List comprehension has incompatible type List[int]; expected List[str] [misc] @@ -306,7 +291,6 @@ posthog/tasks/email.py:0: error: Module "django.utils.timezone" does not explici posthog/tasks/email.py:0: error: Argument "email" to "add_recipient" of "EmailMessage" has incompatible type "str | None"; expected "str" [arg-type] posthog/tasks/email.py:0: error: Argument 1 to "capture" has incompatible type "str | None"; expected "str" [arg-type] posthog/tasks/email.py:0: error: Incompatible types in assignment (expression has type "Team | None", variable has type "Team") [assignment] -posthog/api/routing.py:0: error: Incompatible return value type (got "Project | None", expected "Project") [return-value] posthog/api/documentation.py:0: error: Signature of "run_validation" incompatible with supertype "Field" [override] posthog/api/documentation.py:0: note: Superclass: posthog/api/documentation.py:0: note: def run_validation(self, data: Any = ...) -> Any @@ -326,21 +310,24 @@ posthog/models/property/util.py:0: error: Argument 3 to "format_cohort_subquery" posthog/models/property/util.py:0: error: Argument 1 to "append" of "list" has incompatible type "str | int"; expected "str" [arg-type] posthog/models/property/util.py:0: error: Argument 1 to "append" of "list" has incompatible type "str | int"; expected "str" [arg-type] posthog/models/property/util.py:0: error: Argument 1 to "append" of "list" has incompatible type "str | int"; expected "str" [arg-type] -posthog/api/organization.py:0: error: Incompatible return value type (got "int | None", expected "Level | None") [return-value] +posthog/api/utils.py:0: error: Incompatible types in assignment (expression has type "type[EventDefinition]", variable has type "type[EnterpriseEventDefinition]") [assignment] +posthog/api/utils.py:0: error: Argument 1 to "UUID" has incompatible type "int | str"; expected "str | None" [arg-type] posthog/api/email_verification.py:0: error: Argument 2 to "feature_enabled" has incompatible type "UUID"; expected "str" [arg-type] -posthog/api/capture.py:0: error: Module has no attribute "utc" [attr-defined] posthog/queries/trends/util.py:0: error: Argument 1 to "translate_hogql" has incompatible type "str | None"; expected "str" [arg-type] posthog/hogql/property.py:0: error: Incompatible type for lookup 'id': (got "str | int | list[str]", expected "str | int") [misc] posthog/hogql/property.py:0: error: Incompatible type for lookup 'pk': (got "str | float", expected "str | int") [misc] -posthog/api/action.py:0: error: Argument 1 to has incompatible type "*tuple[str, ...]"; expected "type[BaseRenderer]" [arg-type] +posthog/api/routing.py:0: error: Incompatible return value type (got "Project | None", expected "Project") [return-value] +posthog/api/capture.py:0: error: Module has no attribute "utc" [attr-defined] posthog/hogql/filters.py:0: error: Incompatible default for argument "team" (default has type "None", argument has type "Team") [assignment] posthog/hogql/filters.py:0: note: PEP 484 prohibits implicit Optional. Accordingly, mypy has changed its default to no_implicit_optional=True posthog/hogql/filters.py:0: note: Use https://github.com/hauntsaninja/no_implicit_optional to automatically upgrade your codebase +posthog/api/organization.py:0: error: Incompatible return value type (got "int | None", expected "Level | None") [return-value] posthog/hogql/query.py:0: error: Incompatible types in assignment (expression has type "None", variable has type "str | SelectQuery | SelectUnionQuery") [assignment] posthog/hogql/query.py:0: error: Incompatible types in assignment (expression has type "Expr", variable has type "SelectQuery | SelectUnionQuery") [assignment] posthog/hogql/query.py:0: error: Argument 1 to "get_default_limit_for_context" has incompatible type "LimitContext | None"; expected "LimitContext" [arg-type] posthog/hogql/query.py:0: error: "SelectQuery" has no attribute "select_queries" [attr-defined] posthog/hogql/query.py:0: error: Subclass of "SelectQuery" and "SelectUnionQuery" cannot exist: would have incompatible method signatures [unreachable] +posthog/api/action.py:0: error: Argument 1 to has incompatible type "*tuple[str, ...]"; expected "type[BaseRenderer]" [arg-type] posthog/queries/person_query.py:0: error: Incompatible type for lookup 'pk': (got "str | int | list[str]", expected "str | int") [misc] posthog/queries/event_query/event_query.py:0: error: Incompatible type for lookup 'pk': (got "str | int | list[str]", expected "str | int") [misc] posthog/hogql_queries/sessions_timeline_query_runner.py:0: error: Statement is unreachable [unreachable] @@ -806,24 +793,6 @@ posthog/queries/app_metrics/historical_exports.py:0: error: Argument 1 to "loads posthog/api/test/test_decide.py:0: error: Item "None" of "User | None" has no attribute "toolbar_mode" [union-attr] posthog/api/test/test_decide.py:0: error: Item "None" of "User | None" has no attribute "save" [union-attr] posthog/api/test/test_authentication.py:0: error: Module has no attribute "utc" [attr-defined] -posthog/api/plugin.py:0: error: Item "None" of "Team | None" has no attribute "organization" [union-attr] -posthog/api/plugin.py:0: error: Argument "organization_id" to "log_activity" has incompatible type "UUID | Any"; expected "UUIDT | None" [arg-type] -posthog/api/plugin.py:0: error: Item "None" of "Team | None" has no attribute "id" [union-attr] -posthog/api/plugin.py:0: error: Item "None" of "Team | None" has no attribute "organization" [union-attr] -posthog/api/plugin.py:0: error: Argument "organization_id" to "log_activity" has incompatible type "UUID | Any"; expected "UUIDT | None" [arg-type] -posthog/api/plugin.py:0: error: Item "None" of "Team | None" has no attribute "id" [union-attr] -posthog/api/plugin.py:0: error: Incompatible types in assignment (expression has type "str | None", variable has type "str | int | Combinable") [assignment] -posthog/api/plugin.py:0: error: Incompatible types in assignment (expression has type "str | None", variable has type "str | int | Combinable") [assignment] -posthog/api/plugin.py:0: error: Incompatible types in assignment (expression has type "int | None", variable has type "float | int | str | Combinable") [assignment] -posthog/api/plugin.py:0: error: Item "None" of "IO[Any] | None" has no attribute "read" [union-attr] -posthog/api/plugin.py:0: error: Incompatible type for "file_name" of "PluginAttachment" (got "str | None", expected "str | int | Combinable") [misc] -posthog/api/plugin.py:0: error: Incompatible type for "file_size" of "PluginAttachment" (got "int | None", expected "float | int | str | Combinable") [misc] -posthog/api/plugin.py:0: error: Item "None" of "IO[Any] | None" has no attribute "read" [union-attr] -posthog/api/plugin.py:0: error: Item "None" of "Team | None" has no attribute "organization" [union-attr] -posthog/api/plugin.py:0: error: Argument "organization_id" to "log_activity" has incompatible type "UUID | Any"; expected "UUIDT | None" [arg-type] -posthog/api/plugin.py:0: error: Item "None" of "Team | None" has no attribute "id" [union-attr] -posthog/api/plugin.py:0: error: Argument "organization_id" to "log_activity" has incompatible type "UUID"; expected "UUIDT | None" [arg-type] -posthog/api/plugin.py:0: error: Argument "organization_id" to "log_activity" has incompatible type "UUID"; expected "UUIDT | None" [arg-type] posthog/admin/admins/plugin_config_admin.py:0: error: Item "None" of "Team | None" has no attribute "name" [union-attr] posthog/warehouse/api/external_data_schema.py:0: error: Incompatible return value type (got "str | None", expected "SyncType | None") [return-value] posthog/warehouse/api/external_data_schema.py:0: error: Argument 1 to "get_sql_schemas_for_source_type" has incompatible type "str"; expected "Type" [arg-type] @@ -846,16 +815,30 @@ posthog/temporal/data_imports/workflow_activities/import_data.py:0: error: Argum posthog/temporal/data_imports/workflow_activities/import_data.py:0: error: Argument "source_type" to "sql_source_for_type" has incompatible type "str"; expected "Type" [arg-type] posthog/migrations/0237_remove_timezone_from_teams.py:0: error: Argument 2 to "RunPython" has incompatible type "Callable[[Migration, Any], None]"; expected "_CodeCallable | None" [arg-type] posthog/migrations/0228_fix_tile_layouts.py:0: error: Argument 2 to "RunPython" has incompatible type "Callable[[Migration, Any], None]"; expected "_CodeCallable | None" [arg-type] -posthog/api/plugin_log_entry.py:0: error: Name "timezone.datetime" is not defined [name-defined] -posthog/api/plugin_log_entry.py:0: error: Module "django.utils.timezone" does not explicitly export attribute "datetime" [attr-defined] -posthog/api/plugin_log_entry.py:0: error: Name "timezone.datetime" is not defined [name-defined] -posthog/api/plugin_log_entry.py:0: error: Module "django.utils.timezone" does not explicitly export attribute "datetime" [attr-defined] posthog/warehouse/external_data_source/source.py:0: error: Incompatible types in assignment (expression has type "int", target has type "str") [assignment] posthog/warehouse/external_data_source/source.py:0: error: Incompatible types in assignment (expression has type "int", target has type "str") [assignment] posthog/warehouse/external_data_source/source.py:0: error: Incompatible types in assignment (expression has type "dict[str, Collection[str]]", variable has type "StripeSourcePayload") [assignment] posthog/warehouse/external_data_source/source.py:0: error: Argument 1 to "_create_source" has incompatible type "StripeSourcePayload"; expected "dict[Any, Any]" [arg-type] posthog/temporal/tests/batch_exports/test_redshift_batch_export_workflow.py:0: error: Incompatible types in assignment (expression has type "str | int", variable has type "int") [assignment] posthog/api/sharing.py:0: error: Item "None" of "list[Any] | None" has no attribute "__iter__" (not iterable) [union-attr] +posthog/api/plugin.py:0: error: Item "None" of "Team | None" has no attribute "organization" [union-attr] +posthog/api/plugin.py:0: error: Argument "organization_id" to "log_activity" has incompatible type "UUID | Any"; expected "UUIDT | None" [arg-type] +posthog/api/plugin.py:0: error: Item "None" of "Team | None" has no attribute "id" [union-attr] +posthog/api/plugin.py:0: error: Item "None" of "Team | None" has no attribute "organization" [union-attr] +posthog/api/plugin.py:0: error: Argument "organization_id" to "log_activity" has incompatible type "UUID | Any"; expected "UUIDT | None" [arg-type] +posthog/api/plugin.py:0: error: Item "None" of "Team | None" has no attribute "id" [union-attr] +posthog/api/plugin.py:0: error: Incompatible types in assignment (expression has type "str | None", variable has type "str | int | Combinable") [assignment] +posthog/api/plugin.py:0: error: Incompatible types in assignment (expression has type "str | None", variable has type "str | int | Combinable") [assignment] +posthog/api/plugin.py:0: error: Incompatible types in assignment (expression has type "int | None", variable has type "float | int | str | Combinable") [assignment] +posthog/api/plugin.py:0: error: Item "None" of "IO[Any] | None" has no attribute "read" [union-attr] +posthog/api/plugin.py:0: error: Incompatible type for "file_name" of "PluginAttachment" (got "str | None", expected "str | int | Combinable") [misc] +posthog/api/plugin.py:0: error: Incompatible type for "file_size" of "PluginAttachment" (got "int | None", expected "float | int | str | Combinable") [misc] +posthog/api/plugin.py:0: error: Item "None" of "IO[Any] | None" has no attribute "read" [union-attr] +posthog/api/plugin.py:0: error: Item "None" of "Team | None" has no attribute "organization" [union-attr] +posthog/api/plugin.py:0: error: Argument "organization_id" to "log_activity" has incompatible type "UUID | Any"; expected "UUIDT | None" [arg-type] +posthog/api/plugin.py:0: error: Item "None" of "Team | None" has no attribute "id" [union-attr] +posthog/api/plugin.py:0: error: Argument "organization_id" to "log_activity" has incompatible type "UUID"; expected "UUIDT | None" [arg-type] +posthog/api/plugin.py:0: error: Argument "organization_id" to "log_activity" has incompatible type "UUID"; expected "UUIDT | None" [arg-type] posthog/temporal/tests/external_data/test_external_data_job.py:0: error: Invalid index type "str" for "dict[Type, Sequence[str]]"; expected type "Type" [index] posthog/temporal/tests/external_data/test_external_data_job.py:0: error: Invalid index type "str" for "dict[Type, Sequence[str]]"; expected type "Type" [index] posthog/temporal/tests/external_data/test_external_data_job.py:0: error: Invalid index type "str" for "dict[Type, Sequence[str]]"; expected type "Type" [index] @@ -867,21 +850,13 @@ posthog/api/test/batch_exports/conftest.py:0: note: def run(self) -> Coroutine[A posthog/api/test/batch_exports/conftest.py:0: note: Subclass: posthog/api/test/batch_exports/conftest.py:0: note: def run(self, loop: Any) -> Any posthog/api/test/batch_exports/conftest.py:0: error: Argument "activities" to "ThreadedWorker" has incompatible type "list[function]"; expected "Sequence[Callable[..., Any]]" [arg-type] +posthog/api/plugin_log_entry.py:0: error: Name "timezone.datetime" is not defined [name-defined] +posthog/api/plugin_log_entry.py:0: error: Module "django.utils.timezone" does not explicitly export attribute "datetime" [attr-defined] +posthog/api/plugin_log_entry.py:0: error: Name "timezone.datetime" is not defined [name-defined] +posthog/api/plugin_log_entry.py:0: error: Module "django.utils.timezone" does not explicitly export attribute "datetime" [attr-defined] posthog/temporal/tests/data_imports/test_end_to_end.py:0: error: Unused "type: ignore" comment [unused-ignore] posthog/api/test/test_team.py:0: error: "HttpResponse" has no attribute "json" [attr-defined] posthog/api/test/test_team.py:0: error: "HttpResponse" has no attribute "json" [attr-defined] -posthog/api/test/test_capture.py:0: error: Statement is unreachable [unreachable] -posthog/api/test/test_capture.py:0: error: Incompatible return value type (got "_MonkeyPatchedWSGIResponse", expected "HttpResponse") [return-value] -posthog/api/test/test_capture.py:0: error: Module has no attribute "utc" [attr-defined] -posthog/api/test/test_capture.py:0: error: Unpacked dict entry 0 has incompatible type "Collection[str]"; expected "SupportsKeysAndGetItem[str, dict[Never, Never]]" [dict-item] -posthog/api/test/test_capture.py:0: error: Unpacked dict entry 0 has incompatible type "Collection[str]"; expected "SupportsKeysAndGetItem[str, dict[Never, Never]]" [dict-item] -posthog/api/test/test_capture.py:0: error: Unpacked dict entry 0 has incompatible type "Collection[str]"; expected "SupportsKeysAndGetItem[str, dict[Never, Never]]" [dict-item] -posthog/api/test/test_capture.py:0: error: Dict entry 0 has incompatible type "str": "float"; expected "str": "int" [dict-item] -posthog/api/test/test_capture.py:0: error: Dict entry 0 has incompatible type "str": "float"; expected "str": "int" [dict-item] -posthog/api/test/test_capture.py:0: error: Dict entry 0 has incompatible type "str": "float"; expected "str": "int" [dict-item] -posthog/api/test/test_capture.py:0: error: Dict entry 0 has incompatible type "str": "float"; expected "str": "int" [dict-item] -posthog/api/test/test_capture.py:0: error: Dict entry 0 has incompatible type "str": "float"; expected "str": "int" [dict-item] -posthog/api/test/test_capture.py:0: error: Dict entry 0 has incompatible type "str": "float"; expected "str": "int" [dict-item] posthog/test/test_middleware.py:0: error: Incompatible types in assignment (expression has type "_MonkeyPatchedWSGIResponse", variable has type "_MonkeyPatchedResponse") [assignment] posthog/management/commands/test/test_create_batch_export_from_app.py:0: error: Incompatible return value type (got "dict[str, Collection[str]]", expected "dict[str, str]") [return-value] posthog/management/commands/test/test_create_batch_export_from_app.py:0: error: Incompatible types in assignment (expression has type "dict[str, Collection[str]]", variable has type "dict[str, str]") [assignment] @@ -917,6 +892,18 @@ posthog/management/commands/test/test_create_batch_export_from_app.py:0: error: posthog/management/commands/test/test_create_batch_export_from_app.py:0: note: Possible overload variants: posthog/management/commands/test/test_create_batch_export_from_app.py:0: note: def __getitem__(self, SupportsIndex, /) -> str posthog/management/commands/test/test_create_batch_export_from_app.py:0: note: def __getitem__(self, slice, /) -> list[str] +posthog/api/test/test_capture.py:0: error: Statement is unreachable [unreachable] +posthog/api/test/test_capture.py:0: error: Incompatible return value type (got "_MonkeyPatchedWSGIResponse", expected "HttpResponse") [return-value] +posthog/api/test/test_capture.py:0: error: Module has no attribute "utc" [attr-defined] +posthog/api/test/test_capture.py:0: error: Unpacked dict entry 0 has incompatible type "Collection[str]"; expected "SupportsKeysAndGetItem[str, dict[Never, Never]]" [dict-item] +posthog/api/test/test_capture.py:0: error: Unpacked dict entry 0 has incompatible type "Collection[str]"; expected "SupportsKeysAndGetItem[str, dict[Never, Never]]" [dict-item] +posthog/api/test/test_capture.py:0: error: Unpacked dict entry 0 has incompatible type "Collection[str]"; expected "SupportsKeysAndGetItem[str, dict[Never, Never]]" [dict-item] +posthog/api/test/test_capture.py:0: error: Dict entry 0 has incompatible type "str": "float"; expected "str": "int" [dict-item] +posthog/api/test/test_capture.py:0: error: Dict entry 0 has incompatible type "str": "float"; expected "str": "int" [dict-item] +posthog/api/test/test_capture.py:0: error: Dict entry 0 has incompatible type "str": "float"; expected "str": "int" [dict-item] +posthog/api/test/test_capture.py:0: error: Dict entry 0 has incompatible type "str": "float"; expected "str": "int" [dict-item] +posthog/api/test/test_capture.py:0: error: Dict entry 0 has incompatible type "str": "float"; expected "str": "int" [dict-item] +posthog/api/test/test_capture.py:0: error: Dict entry 0 has incompatible type "str": "float"; expected "str": "int" [dict-item] posthog/api/test/batch_exports/test_update.py:0: error: Unsupported target for indexed assignment ("Collection[str]") [index] posthog/api/test/batch_exports/test_update.py:0: error: Unsupported target for indexed assignment ("Collection[str]") [index] posthog/api/test/batch_exports/test_update.py:0: error: Dict entry 1 has incompatible type "str": "dict[str, Collection[str]]"; expected "str": "str" [dict-item] diff --git a/posthog/hogql/test/test_printer.py b/posthog/hogql/test/test_printer.py index 1ab8444294e27..9088ed73a88d1 100644 --- a/posthog/hogql/test/test_printer.py +++ b/posthog/hogql/test/test_printer.py @@ -398,7 +398,7 @@ def test_expr_parse_errors(self): ) self._assert_expr_error( "quantile()(event)", - "Aggregation 'quantile' requires parameters in addition to arguments", + "Aggregation 'quantile' expects 1 parameter, found 0", ) self._assert_expr_error( "quantile(0.5, 2)(event)", From 7a93c8a10cbcad29ca3d8323da99c66250f93ad3 Mon Sep 17 00:00:00 2001 From: Marius Andra Date: Mon, 26 Aug 2024 21:57:51 +0200 Subject: [PATCH 10/21] feat(hog): bytecode versions --- ee/api/test/test_hooks.py | 6 +- ee/clickhouse/models/test/test_action.py | 21 +-- hogvm/README.md | 2 +- hogvm/__tests__/__snapshots__/arrays.hoge | 26 ++-- hogvm/__tests__/__snapshots__/catch.hoge | 22 +-- hogvm/__tests__/__snapshots__/catch2.hoge | 28 ++-- hogvm/__tests__/__snapshots__/crypto.hoge | 8 +- hogvm/__tests__/__snapshots__/date.hoge | 50 +++---- hogvm/__tests__/__snapshots__/dateFormat.hoge | 64 ++++----- hogvm/__tests__/__snapshots__/dicts.hoge | 12 +- hogvm/__tests__/__snapshots__/dicts.stdout | 1 - hogvm/__tests__/__snapshots__/exceptions.hoge | 24 ++-- hogvm/__tests__/__snapshots__/functions.hoge | 28 ++-- hogvm/__tests__/__snapshots__/ifElse.hoge | 2 +- hogvm/__tests__/__snapshots__/ifJump.hoge | 4 +- hogvm/__tests__/__snapshots__/json.hoge | 2 +- hogvm/__tests__/__snapshots__/keysValues.hoge | 2 +- hogvm/__tests__/__snapshots__/loops.hoge | 44 +++--- hogvm/__tests__/__snapshots__/loops.stdout | 1 - hogvm/__tests__/__snapshots__/mandelbrot.hoge | 16 +-- hogvm/__tests__/__snapshots__/operations.hoge | 33 +++-- .../__tests__/__snapshots__/operations.stdout | 4 - hogvm/__tests__/__snapshots__/printLoops.hoge | 6 +- .../__tests__/__snapshots__/printLoops2.hoge | 4 +- hogvm/__tests__/__snapshots__/properties.hoge | 2 +- hogvm/__tests__/__snapshots__/stl.hoge | 52 ++++---- hogvm/__tests__/__snapshots__/strings.hoge | 22 +-- hogvm/__tests__/__snapshots__/tuples.hoge | 4 +- hogvm/__tests__/__snapshots__/variables.hoge | 6 +- hogvm/__tests__/dicts.hog | 1 - hogvm/__tests__/loops.hog | 3 +- hogvm/__tests__/mandelbrot.hog | 2 +- hogvm/__tests__/operations.hog | 126 +++++++++--------- hogvm/python/debugger.py | 12 +- hogvm/python/execute.py | 46 ++++--- hogvm/python/operation.py | 10 +- hogvm/python/test/test_execute.py | 88 +++++++----- .../typescript/src/__tests__/execute.test.ts | 125 ++++++++++------- hogvm/typescript/src/execute.ts | 35 +++-- hogvm/typescript/src/operation.ts | 2 +- posthog/hogql/bytecode.py | 36 ++--- posthog/hogql/test/test_bytecode.py | 2 +- 42 files changed, 526 insertions(+), 458 deletions(-) diff --git a/ee/api/test/test_hooks.py b/ee/api/test/test_hooks.py index 2870b2ecce10b..0017079f4a77d 100644 --- a/ee/api/test/test_hooks.py +++ b/ee/api/test/test_hooks.py @@ -4,6 +4,7 @@ from ee.api.hooks import valid_domain from ee.api.test.base import APILicensedTest from ee.models.hook import Hook +from hogvm.python.operation import HOGQL_BYTECODE_VERSION from posthog.models.action.action import Action from posthog.models.hog_functions.hog_function import HogFunction from posthog.test.base import ClickhouseTestMixin @@ -113,7 +114,7 @@ def test_create_hog_function_via_hook(self): assert hog_function.filters == { "actions": [{"id": str(self.action.id), "name": "", "type": "actions", "order": 0}], - "bytecode": ["_h", 32, "$pageview", 32, "event", 1, 1, 11, 3, 1, 4, 1], + "bytecode": ["_H", HOGQL_BYTECODE_VERSION, 32, "$pageview", 32, "event", 1, 1, 11, 3, 1, 4, 1], } assert hog_function.inputs == { @@ -142,7 +143,8 @@ def test_create_hog_function_via_hook(self): "debug": {}, "hook": { "bytecode": [ - "_h", + "_H", + HOGQL_BYTECODE_VERSION, 32, "hooks/standard/1234/abcd", ], diff --git a/ee/clickhouse/models/test/test_action.py b/ee/clickhouse/models/test/test_action.py index 1c32ece5e1e94..7495d3eddc4e5 100644 --- a/ee/clickhouse/models/test/test_action.py +++ b/ee/clickhouse/models/test/test_action.py @@ -13,7 +13,7 @@ _create_event, _create_person, ) -from hogvm.python.operation import Operation as op, HOGQL_BYTECODE_IDENTIFIER as _H +from hogvm.python.operation import Operation as op, HOGQL_BYTECODE_IDENTIFIER as _H, HOGQL_BYTECODE_VERSION @dataclasses.dataclass @@ -289,6 +289,15 @@ def test_filter_with_hogql(self): action1.bytecode, [ _H, + HOGQL_BYTECODE_VERSION, + # event = 'insight viewed' + op.STRING, + "insight viewed", + op.STRING, + "event", + op.GET_GLOBAL, + 1, + op.EQ, # toInt(properties.filters_count) > 10 op.INTEGER, 10, @@ -298,18 +307,10 @@ def test_filter_with_hogql(self): "properties", op.GET_GLOBAL, 2, - op.CALL, + op.CALL_GLOBAL, "toInt", 1, op.GT, - # event = 'insight viewed' - op.STRING, - "insight viewed", - op.STRING, - "event", - op.GET_GLOBAL, - 1, - op.EQ, # and op.AND, 2, diff --git a/hogvm/README.md b/hogvm/README.md index 9c44d22a518d9..a2eeab5f0f6d6 100644 --- a/hogvm/README.md +++ b/hogvm/README.md @@ -12,7 +12,7 @@ HogQL Bytecode is a compact representation of a subset of the HogQL AST nodes. I 1 or 2 # [_H, op.INTEGER, 2, op.INTEGER, 1, op.OR, 2] not true # [_H, op.TRUE, op.NOT] properties.bla # [_H, op.STRING, "bla", op.STRING, "properties", op.GET_GLOBAL, 2] -call('arg', 'another') # [_H, op.STRING, "another", op.STRING, "arg", op.CALL, "call", 2] +call('arg', 'another') # [_H, op.STRING, "another", op.STRING, "arg", op.CALL_GLOBAL, "call", 2] 1 = 2 # [_H, op.INTEGER, 2, op.INTEGER, 1, op.EQ] 'bla' !~ 'a' # [_H, op.STRING, 'a', op.STRING, 'bla', op.NOT_REGEX] ``` diff --git a/hogvm/__tests__/__snapshots__/arrays.hoge b/hogvm/__tests__/__snapshots__/arrays.hoge index 6a8603832d3c1..4afcc23ad537a 100644 --- a/hogvm/__tests__/__snapshots__/arrays.hoge +++ b/hogvm/__tests__/__snapshots__/arrays.hoge @@ -1,4 +1,4 @@ -["_h", 43, 0, 2, "print", 1, 35, 33, 1, 33, 2, 33, 3, 43, 3, 2, "print", 1, 35, 33, 1, 32, "2", 33, 3, 43, 3, 2, +["_H", 1, 43, 0, 2, "print", 1, 35, 33, 1, 33, 2, 33, 3, 43, 3, 2, "print", 1, 35, 33, 1, 32, "2", 33, 3, 43, 3, 2, "print", 1, 35, 33, 1, 33, 2, 33, 3, 43, 2, 33, 4, 43, 3, 2, "print", 1, 35, 33, 1, 33, 2, 33, 3, 33, 4, 43, 2, 43, 2, 33, 5, 43, 3, 2, "print", 1, 35, 33, 1, 33, 2, 33, 3, 43, 3, 36, 0, 33, 2, 45, 2, "print", 1, 35, 36, 0, 33, 2, 48, 2, "print", 1, 35, 36, 0, 33, 2, 48, 2, "print", 1, 35, 36, 0, 33, 7, 48, 2, "print", 1, 35, 36, 0, 33, 7, 48, 2, "print", @@ -11,17 +11,17 @@ 35, 33, 1, 33, 2, 33, 3, 33, 4, 43, 2, 43, 2, 33, 5, 43, 3, 33, 2, 45, 33, 2, 45, 33, 2, 45, 2, "print", 1, 35, 32, "------", 2, "print", 1, 35, 33, 1, 33, 2, 33, 1, 33, 2, 33, 3, 43, 3, 43, 3, 36, 1, 33, 2, 33, 4, 46, 36, 1, 33, 1, 45, 2, "print", 1, 35, 36, 1, 33, 2, 45, 2, "print", 1, 35, 36, 1, 33, 3, 45, 2, "print", 1, 35, 36, 1, 33, 3, 45, 33, 3, -33, 8, 46, 36, 1, 2, "print", 1, 35, 32, "------", 2, "print", 1, 35, 33, 4, 33, 1, 33, 2, 33, 3, 43, 3, 2, -"arrayPushBack", 2, 2, "print", 1, 35, 33, 0, 33, 1, 33, 2, 33, 3, 43, 3, 2, "arrayPushFront", 2, 2, "print", 1, 35, 33, +33, 8, 46, 36, 1, 2, "print", 1, 35, 32, "------", 2, "print", 1, 35, 33, 1, 33, 2, 33, 3, 43, 3, 33, 4, 2, +"arrayPushBack", 2, 2, "print", 1, 35, 33, 1, 33, 2, 33, 3, 43, 3, 33, 0, 2, "arrayPushFront", 2, 2, "print", 1, 35, 33, 1, 33, 2, 33, 3, 43, 3, 2, "arrayPopBack", 1, 2, "print", 1, 35, 33, 1, 33, 2, 33, 3, 43, 3, 2, "arrayPopFront", 1, 2, "print", 1, 35, 33, 3, 33, 2, 33, 1, 43, 3, 2, "arraySort", 1, 2, "print", 1, 35, 33, 1, 33, 2, 33, 3, 43, 3, 2, -"arrayReverse", 1, 2, "print", 1, 35, 33, 3, 33, 2, 33, 1, 43, 3, 2, "arrayReverseSort", 1, 2, "print", 1, 35, 32, ",", -33, 1, 33, 2, 33, 3, 43, 3, 2, "arrayStringConcat", 2, 2, "print", 1, 35, 32, "-----", 2, "print", 1, 35, 33, 1, 33, 2, -33, 3, 33, 4, 43, 4, 36, 2, 2, "print", 1, 35, 33, 5, 36, 2, 2, "arrayPushBack", 2, 35, 36, 2, 2, "print", 1, 35, 33, 0, -36, 2, 2, "arrayPushFront", 2, 35, 36, 2, 2, "print", 1, 35, 36, 2, 2, "arrayPopBack", 1, 35, 36, 2, 2, "print", 1, 35, -36, 2, 2, "arrayPopFront", 1, 35, 36, 2, 2, "print", 1, 35, 36, 2, 2, "arraySort", 1, 35, 36, 2, 2, "print", 1, 35, 36, -2, 2, "arrayReverse", 1, 35, 36, 2, 2, "print", 1, 35, 36, 2, 2, "arrayReverseSort", 1, 35, 36, 2, 2, "print", 1, 35, -32, "------", 2, "print", 1, 35, 33, 0, 36, 2, 2, "has", 2, 2, "print", 1, 35, 33, 2, 36, 2, 2, "has", 2, 2, "print", 1, -35, 32, "banana", 36, 2, 2, "has", 2, 2, "print", 1, 35, 32, "banana", 32, "banananas", 2, "has", 2, 2, "print", 1, 35, -32, "foo", 32, "banananas", 2, "has", 2, 2, "print", 1, 35, 32, "1", 32, "1", 32, "2", 43, 2, 2, "has", 2, 2, "print", -1, 35, 35, 35, 35] +"arrayReverse", 1, 2, "print", 1, 35, 33, 3, 33, 2, 33, 1, 43, 3, 2, "arrayReverseSort", 1, 2, "print", 1, 35, 33, 1, +33, 2, 33, 3, 43, 3, 32, ",", 2, "arrayStringConcat", 2, 2, "print", 1, 35, 32, "-----", 2, "print", 1, 35, 33, 1, 33, +2, 33, 3, 33, 4, 43, 4, 36, 2, 2, "print", 1, 35, 36, 2, 33, 5, 2, "arrayPushBack", 2, 35, 36, 2, 2, "print", 1, 35, 36, +2, 33, 0, 2, "arrayPushFront", 2, 35, 36, 2, 2, "print", 1, 35, 36, 2, 2, "arrayPopBack", 1, 35, 36, 2, 2, "print", 1, +35, 36, 2, 2, "arrayPopFront", 1, 35, 36, 2, 2, "print", 1, 35, 36, 2, 2, "arraySort", 1, 35, 36, 2, 2, "print", 1, 35, +36, 2, 2, "arrayReverse", 1, 35, 36, 2, 2, "print", 1, 35, 36, 2, 2, "arrayReverseSort", 1, 35, 36, 2, 2, "print", 1, +35, 32, "------", 2, "print", 1, 35, 36, 2, 33, 0, 2, "has", 2, 2, "print", 1, 35, 36, 2, 33, 2, 2, "has", 2, 2, +"print", 1, 35, 36, 2, 32, "banana", 2, "has", 2, 2, "print", 1, 35, 32, "banananas", 32, "banana", 2, "has", 2, 2, +"print", 1, 35, 32, "banananas", 32, "foo", 2, "has", 2, 2, "print", 1, 35, 32, "1", 32, "2", 43, 2, 32, "1", 2, "has", +2, 2, "print", 1, 35, 35, 35, 35] diff --git a/hogvm/__tests__/__snapshots__/catch.hoge b/hogvm/__tests__/__snapshots__/catch.hoge index 3fbbdda162693..e3588d7a1cdf9 100644 --- a/hogvm/__tests__/__snapshots__/catch.hoge +++ b/hogvm/__tests__/__snapshots__/catch.hoge @@ -1,11 +1,11 @@ -["_h", 41, "FishError", 1, 9, 31, 36, 0, 32, "FishError", 2, "HogError", 3, 38, 41, "FoodError", 1, 9, 31, 36, 0, 32, -"FoodError", 2, "HogError", 3, 38, 50, 10, 32, "You forgot to feed your fish", 2, "FishError", 1, 49, 51, 39, 55, 36, 0, -32, "type", 45, 32, "FoodError", 36, 1, 11, 40, 16, 36, 0, 32, "message", 45, 32, "Problem with your food: ", 2, -"concat", 2, 2, "print", 1, 35, 39, 25, 32, "FishError", 36, 1, 11, 40, 16, 36, 0, 32, "message", 45, 32, -"Problem with your fish: ", 2, "concat", 2, 2, "print", 1, 35, 39, 2, 35, 49, 35, 35, 50, 10, 32, -"Your fish are hungry", 2, "FoodError", 1, 49, 51, 39, 55, 36, 0, 32, "type", 45, 32, "FoodError", 36, 1, 11, 40, 16, -36, 0, 32, "message", 45, 32, "Problem with your food: ", 2, "concat", 2, 2, "print", 1, 35, 39, 25, 32, "FishError", -36, 1, 11, 40, 16, 36, 0, 32, "message", 45, 32, "Problem with your fish: ", 2, "concat", 2, 2, "print", 1, 35, 39, 2, -35, 49, 35, 35, 50, 11, 31, 32, "Your fish are hungry", 2, "NotImplementedError", 2, 49, 51, 39, 45, 36, 0, 32, "type", -45, 32, "FoodError", 36, 1, 11, 40, 16, 36, 0, 32, "message", 45, 32, "Problem with your food: ", 2, "concat", 2, 2, -"print", 1, 35, 39, 15, 36, 0, 32, "Unknown problem: ", 2, "concat", 2, 2, "print", 1, 35, 39, 2, 35, 49, 35, 35] +["_H", 1, 41, "FishError", 1, 9, 32, "FishError", 36, 0, 31, 2, "HogError", 3, 38, 41, "FoodError", 1, 9, 32, +"FoodError", 36, 0, 31, 2, "HogError", 3, 38, 50, 10, 32, "You forgot to feed your fish", 2, "FishError", 1, 49, 51, 39, +55, 36, 0, 32, "type", 45, 32, "FoodError", 36, 1, 11, 40, 16, 32, "Problem with your food: ", 36, 0, 32, "message", 45, +2, "concat", 2, 2, "print", 1, 35, 39, 25, 32, "FishError", 36, 1, 11, 40, 16, 32, "Problem with your fish: ", 36, 0, +32, "message", 45, 2, "concat", 2, 2, "print", 1, 35, 39, 2, 35, 49, 35, 35, 50, 10, 32, "Your fish are hungry", 2, +"FoodError", 1, 49, 51, 39, 55, 36, 0, 32, "type", 45, 32, "FoodError", 36, 1, 11, 40, 16, 32, +"Problem with your food: ", 36, 0, 32, "message", 45, 2, "concat", 2, 2, "print", 1, 35, 39, 25, 32, "FishError", 36, 1, +11, 40, 16, 32, "Problem with your fish: ", 36, 0, 32, "message", 45, 2, "concat", 2, 2, "print", 1, 35, 39, 2, 35, 49, +35, 35, 50, 11, 32, "Your fish are hungry", 31, 2, "NotImplementedError", 2, 49, 51, 39, 45, 36, 0, 32, "type", 45, 32, +"FoodError", 36, 1, 11, 40, 16, 32, "Problem with your food: ", 36, 0, 32, "message", 45, 2, "concat", 2, 2, "print", 1, +35, 39, 15, 32, "Unknown problem: ", 36, 0, 2, "concat", 2, 2, "print", 1, 35, 39, 2, 35, 49, 35, 35] diff --git a/hogvm/__tests__/__snapshots__/catch2.hoge b/hogvm/__tests__/__snapshots__/catch2.hoge index 52aa53597834c..d99e3cd75ae3a 100644 --- a/hogvm/__tests__/__snapshots__/catch2.hoge +++ b/hogvm/__tests__/__snapshots__/catch2.hoge @@ -1,15 +1,15 @@ -["_h", 50, 50, 50, 13, 31, 32, "You forgot to feed your fish", 32, "FishError", 2, "HogError", 3, 49, 51, 39, 32, 36, 0, -32, "type", 45, 32, "FoodError", 36, 1, 11, 40, 16, 36, 0, 32, "message", 45, 32, "Problem with your food: ", 2, +["_H", 1, 50, 50, 50, 13, 32, "FishError", 32, "You forgot to feed your fish", 31, 2, "HogError", 3, 49, 51, 39, 32, 36, +0, 32, "type", 45, 32, "FoodError", 36, 1, 11, 40, 16, 32, "Problem with your food: ", 36, 0, 32, "message", 45, 2, "concat", 2, 2, "print", 1, 35, 39, 2, 35, 49, 35, 35, 51, 39, 48, 36, 0, 32, "type", 45, 32, "FishError", 36, 1, 11, -40, 16, 36, 0, 32, "message", 45, 32, "FishError: ", 2, "concat", 2, 2, "print", 1, 35, 39, 18, 36, 0, 32, "message", -45, 32, "Error: ", 2, "concat", 2, 2, "print", 1, 35, 39, 2, 35, 49, 35, 35, 50, 50, 50, 13, 31, 32, -"You forgot to feed your fish", 32, "FunkyError", 2, "HogError", 3, 49, 51, 39, 32, 36, 0, 32, "type", 45, 32, -"FoodError", 36, 1, 11, 40, 16, 36, 0, 32, "message", 45, 32, "Problem with your food: ", 2, "concat", 2, 2, "print", 1, -35, 39, 2, 35, 49, 35, 35, 51, 39, 55, 36, 0, 32, "type", 45, 32, "FishError", 36, 1, 11, 40, 16, 36, 0, 32, "message", -45, 32, "FishError: ", 2, "concat", 2, 2, "print", 1, 35, 39, 25, 36, 0, 32, "message", 45, 32, ": ", 36, 0, 32, "name", -45, 32, "Error of type ", 2, "concat", 4, 2, "print", 1, 35, 39, 2, 35, 49, 35, 35, 50, 50, 50, 13, 31, 32, -"You forgot to feed your fish", 32, "FishError", 2, "HogError", 3, 49, 51, 39, 32, 36, 0, 32, "type", 45, 32, -"FoodError", 36, 1, 11, 40, 16, 36, 0, 32, "message", 45, 32, "Problem with your food: ", 2, "concat", 2, 2, "print", 1, -35, 39, 2, 35, 49, 35, 35, 51, 39, 55, 36, 0, 32, "type", 45, 36, 0, 32, "message", 45, 32, ": ", 36, 0, 32, "name", 45, -32, "Error of type ", 2, "concat", 4, 2, "print", 1, 35, 39, 25, 32, "FishError", 36, 1, 11, 40, 16, 36, 0, 32, -"message", 45, 32, "FishError: ", 2, "concat", 2, 2, "print", 1, 35, 39, 2, 35, 49, 35, 35] +40, 16, 32, "FishError: ", 36, 0, 32, "message", 45, 2, "concat", 2, 2, "print", 1, 35, 39, 18, 32, "Error: ", 36, 0, +32, "message", 45, 2, "concat", 2, 2, "print", 1, 35, 39, 2, 35, 49, 35, 35, 50, 50, 50, 13, 32, "FunkyError", 32, +"You forgot to feed your fish", 31, 2, "HogError", 3, 49, 51, 39, 32, 36, 0, 32, "type", 45, 32, "FoodError", 36, 1, 11, +40, 16, 32, "Problem with your food: ", 36, 0, 32, "message", 45, 2, "concat", 2, 2, "print", 1, 35, 39, 2, 35, 49, 35, +35, 51, 39, 55, 36, 0, 32, "type", 45, 32, "FishError", 36, 1, 11, 40, 16, 32, "FishError: ", 36, 0, 32, "message", 45, +2, "concat", 2, 2, "print", 1, 35, 39, 25, 32, "Error of type ", 36, 0, 32, "name", 45, 32, ": ", 36, 0, 32, "message", +45, 2, "concat", 4, 2, "print", 1, 35, 39, 2, 35, 49, 35, 35, 50, 50, 50, 13, 32, "FishError", 32, +"You forgot to feed your fish", 31, 2, "HogError", 3, 49, 51, 39, 32, 36, 0, 32, "type", 45, 32, "FoodError", 36, 1, 11, +40, 16, 32, "Problem with your food: ", 36, 0, 32, "message", 45, 2, "concat", 2, 2, "print", 1, 35, 39, 2, 35, 49, 35, +35, 51, 39, 55, 36, 0, 32, "type", 45, 32, "Error of type ", 36, 0, 32, "name", 45, 32, ": ", 36, 0, 32, "message", 45, +2, "concat", 4, 2, "print", 1, 35, 39, 25, 32, "FishError", 36, 1, 11, 40, 16, 32, "FishError: ", 36, 0, 32, "message", +45, 2, "concat", 2, 2, "print", 1, 35, 39, 2, 35, 49, 35, 35] diff --git a/hogvm/__tests__/__snapshots__/crypto.hoge b/hogvm/__tests__/__snapshots__/crypto.hoge index 5100cc860009a..e273437821c50 100644 --- a/hogvm/__tests__/__snapshots__/crypto.hoge +++ b/hogvm/__tests__/__snapshots__/crypto.hoge @@ -1,4 +1,4 @@ -["_h", 32, "this is a secure string", 36, 0, 32, "string:", 2, "print", 2, 35, 36, 0, 2, "md5Hex", 1, 32, -"md5Hex(string):", 2, "print", 2, 35, 36, 0, 2, "sha256Hex", 1, 32, "sha256Hex(string):", 2, "print", 2, 35, 32, "1", -32, "string", 32, "more", 32, "keys", 43, 4, 36, 1, 32, "data:", 2, "print", 2, 35, 36, 1, 2, "sha256HmacChainHex", 1, -32, "sha256HmacChainHex(data):", 2, "print", 2, 35, 35, 35] +["_H", 1, 32, "this is a secure string", 32, "string:", 36, 0, 2, "print", 2, 35, 32, "md5Hex(string):", 36, 0, 2, +"md5Hex", 1, 2, "print", 2, 35, 32, "sha256Hex(string):", 36, 0, 2, "sha256Hex", 1, 2, "print", 2, 35, 32, "1", 32, +"string", 32, "more", 32, "keys", 43, 4, 32, "data:", 36, 1, 2, "print", 2, 35, 32, "sha256HmacChainHex(data):", 36, 1, +2, "sha256HmacChainHex", 1, 2, "print", 2, 35, 35, 35] diff --git a/hogvm/__tests__/__snapshots__/date.hoge b/hogvm/__tests__/__snapshots__/date.hoge index a655406038a05..ab77e9efa77b3 100644 --- a/hogvm/__tests__/__snapshots__/date.hoge +++ b/hogvm/__tests__/__snapshots__/date.hoge @@ -1,28 +1,28 @@ -["_h", 33, 1234334543, 2, "fromUnixTimestamp", 1, 36, 0, 2, "print", 1, 35, 36, 0, 2, "toString", 1, 2, "print", 1, 35, -36, 0, 2, "toUnixTimestamp", 1, 2, "toInt", 1, 2, "print", 1, 35, 32, "-", 2, "print", 1, 35, 32, "2024-05-03", 2, +["_H", 1, 33, 1234334543, 2, "fromUnixTimestamp", 1, 36, 0, 2, "print", 1, 35, 36, 0, 2, "toString", 1, 2, "print", 1, +35, 36, 0, 2, "toUnixTimestamp", 1, 2, "toInt", 1, 2, "print", 1, 35, 32, "-", 2, "print", 1, 35, 32, "2024-05-03", 2, "toDate", 1, 36, 1, 2, "print", 1, 35, 36, 1, 2, "toString", 1, 2, "print", 1, 35, 36, 1, 2, "toUnixTimestamp", 1, 2, "toInt", 1, 2, "print", 1, 35, 32, "-", 2, "print", 1, 35, 32, "2024-05-03T12:34:56Z", 2, "toDateTime", 1, 36, 2, 2, "print", 1, 35, 36, 2, 2, "toString", 1, 2, "print", 1, 35, 36, 2, 2, "toUnixTimestamp", 1, 2, "toInt", 1, 2, "print", -1, 35, 32, "------", 2, "print", 1, 35, 32, "Europe/Brussels", 36, 2, 2, "toTimeZone", 2, 2, "print", 1, 35, 32, -"Europe/Brussels", 36, 2, 2, "toTimeZone", 2, 2, "toString", 1, 2, "print", 1, 35, 32, "-", 2, "print", 1, 35, 32, -"Europe/Tallinn", 36, 2, 2, "toTimeZone", 2, 2, "print", 1, 35, 32, "Europe/Tallinn", 36, 2, 2, "toTimeZone", 2, 2, -"toString", 1, 2, "print", 1, 35, 32, "-", 2, "print", 1, 35, 32, "America/New_York", 36, 2, 2, "toTimeZone", 2, 2, -"print", 1, 35, 32, "America/New_York", 36, 2, 2, "toTimeZone", 2, 2, "toString", 1, 2, "print", 1, 35, 32, "------", 2, -"print", 1, 35, 34, 1234334543.123, 2, "fromUnixTimestamp", 1, 36, 3, 32, "timestamp: ", -2, "print", 2, 35, 36, 3, 2, "toString", 1, 32, "toString(timestamp): ", 2, "print", 2, 35, 36, 3, -2, "toInt", 1, 32, "toInt(timestamp): ", 2, "print", 2, 35, 36, 3, 2, "toInt", 1, 2, -"toDateTime", 1, 32, "toDateTime(toInt(timestamp)): ", 2, "print", 2, 35, 36, 3, 2, "toInt", 1, 2, -"toDateTime", 1, 2, "toInt", 1, 32, "toInt(toDateTime(toInt(timestamp))): ", 2, "print", 2, 35, 36, 3, 2, "toInt", -1, 2, "toDateTime", 1, 2, "toString", 1, 32, "toString(toDateTime(toInt(timestamp))): ", 2, "print", 2, 35, 36, 3, 2, -"toFloat", 1, 32, "toFloat(timestamp): ", 2, "print", 2, 35, 36, 3, 2, "toFloat", 1, 2, -"toDateTime", 1, 32, "toDateTime(toFloat(timestamp)): ", 2, "print", 2, 35, 36, 3, 2, "toFloat", 1, 2, -"toDateTime", 1, 2, "toFloat", 1, 32, "toFloat(toDateTime(toFloat(timestamp))): ", 2, "print", 2, 35, 36, 3, 2, -"toFloat", 1, 2, "toDateTime", 1, 2, "toString", 1, 32, "toString(toDateTime(toFloat(timestamp))): ", 2, "print", 2, 35, -32, "------", 2, "print", 1, 35, 33, 1234334543123, 2, "fromUnixTimestampMilli", 1, 36, 4, 2, "toString", 1, 32, -"millisTs: ", 2, "print", 2, 35, 36, 4, 2, "toString", 1, 32, -"toString(millisTs): ", 2, "print", 2, 35, 36, 4, 2, "toInt", 1, 32, -"toInt(millisTs): ", 2, "print", 2, 35, 36, 4, 2, "toFloat", 1, 32, -"toFloat(millisTs): ", 2, "print", 2, 35, 36, 4, 2, "toUnixTimestampMilli", 1, 32, -"toUnixTimestampMilli(millisTs): ", 2, "print", 2, 35, 32, "------", 2, "print", 1, 35, 32, "2024-05-03", 2, -"toDate", 1, 36, 5, 2, "print", 1, 35, 36, 5, 2, "toString", 1, 2, "print", 1, 35, 36, 5, 2, "toInt", 1, 2, "print", 1, -35, 35, 35, 35, 35, 35, 35] +1, 35, 32, "------", 2, "print", 1, 35, 36, 2, 32, "Europe/Brussels", 2, "toTimeZone", 2, 2, "print", 1, 35, 36, 2, 32, +"Europe/Brussels", 2, "toTimeZone", 2, 2, "toString", 1, 2, "print", 1, 35, 32, "-", 2, "print", 1, 35, 36, 2, 32, +"Europe/Tallinn", 2, "toTimeZone", 2, 2, "print", 1, 35, 36, 2, 32, "Europe/Tallinn", 2, "toTimeZone", 2, 2, "toString", +1, 2, "print", 1, 35, 32, "-", 2, "print", 1, 35, 36, 2, 32, "America/New_York", 2, "toTimeZone", 2, 2, "print", 1, 35, +36, 2, 32, "America/New_York", 2, "toTimeZone", 2, 2, "toString", 1, 2, "print", 1, 35, 32, "------", 2, "print", 1, 35, +34, 1234334543.123, 2, "fromUnixTimestamp", 1, 32, "timestamp: ", 36, 3, 2, "print", 2, +35, 32, "toString(timestamp): ", 36, 3, 2, "toString", 1, 2, "print", 2, 35, 32, +"toInt(timestamp): ", 36, 3, 2, "toInt", 1, 2, "print", 2, 35, 32, +"toDateTime(toInt(timestamp)): ", 36, 3, 2, "toInt", 1, 2, "toDateTime", 1, 2, "print", 2, 35, 32, +"toInt(toDateTime(toInt(timestamp))): ", 36, 3, 2, "toInt", 1, 2, "toDateTime", 1, 2, "toInt", 1, 2, "print", 2, +35, 32, "toString(toDateTime(toInt(timestamp))): ", 36, 3, 2, "toInt", 1, 2, "toDateTime", 1, 2, "toString", 1, 2, +"print", 2, 35, 32, "toFloat(timestamp): ", 36, 3, 2, "toFloat", 1, 2, "print", 2, 35, 32, +"toDateTime(toFloat(timestamp)): ", 36, 3, 2, "toFloat", 1, 2, "toDateTime", 1, 2, "print", 2, 35, 32, +"toFloat(toDateTime(toFloat(timestamp))): ", 36, 3, 2, "toFloat", 1, 2, "toDateTime", 1, 2, "toFloat", 1, 2, "print", +2, 35, 32, "toString(toDateTime(toFloat(timestamp))): ", 36, 3, 2, "toFloat", 1, 2, "toDateTime", 1, 2, "toString", 1, +2, "print", 2, 35, 32, "------", 2, "print", 1, 35, 33, 1234334543123, 2, "fromUnixTimestampMilli", 1, 32, +"millisTs: ", 36, 4, 2, "toString", 1, 2, "print", 2, 35, 32, +"toString(millisTs): ", 36, 4, 2, "toString", 1, 2, "print", 2, 35, 32, +"toInt(millisTs): ", 36, 4, 2, "toInt", 1, 2, "print", 2, 35, 32, +"toFloat(millisTs): ", 36, 4, 2, "toFloat", 1, 2, "print", 2, 35, 32, +"toUnixTimestampMilli(millisTs): ", 36, 4, 2, "toUnixTimestampMilli", 1, 2, "print", 2, 35, 32, "------", 2, +"print", 1, 35, 32, "2024-05-03", 2, "toDate", 1, 36, 5, 2, "print", 1, 35, 36, 5, 2, "toString", 1, 2, "print", 1, 35, +36, 5, 2, "toInt", 1, 2, "print", 1, 35, 35, 35, 35, 35, 35, 35] diff --git a/hogvm/__tests__/__snapshots__/dateFormat.hoge b/hogvm/__tests__/__snapshots__/dateFormat.hoge index eea4f091c7fbd..98706577e6cb1 100644 --- a/hogvm/__tests__/__snapshots__/dateFormat.hoge +++ b/hogvm/__tests__/__snapshots__/dateFormat.hoge @@ -1,32 +1,32 @@ -["_h", 34, 1234377543.123456, 2, "fromUnixTimestamp", 1, 32, "%Y-%m-%d %H:%i:%S", 36, 0, 2, "formatDateTime", 2, 2, -"print", 1, 35, 32, "Europe/Brussels", 32, "%Y-%m-%d %H:%i:%S", 36, 0, 2, "formatDateTime", 3, 2, "print", 1, 35, 32, -"America/New_York", 32, "%Y-%m-%d %H:%i:%S", 36, 0, 2, "formatDateTime", 3, 2, "print", 1, 35, 32, "%Y%m%dT%H%i%sZ", 36, -0, 2, "formatDateTime", 2, 2, "print", 1, 35, 32, "-----", 2, "print", 1, 35, 32, "%a", 36, 0, 2, "formatDateTime", 2, -32, "%a: ", 2, "concat", 2, 2, "print", 1, 35, 32, "%b", 36, 0, 2, "formatDateTime", 2, 32, "%b: ", 2, "concat", 2, 2, -"print", 1, 35, 32, "%c", 36, 0, 2, "formatDateTime", 2, 32, "%c: ", 2, "concat", 2, 2, "print", 1, 35, 32, "%C", 36, 0, -2, "formatDateTime", 2, 32, "%C: ", 2, "concat", 2, 2, "print", 1, 35, 32, "%d", 36, 0, 2, "formatDateTime", 2, 32, -"%d: ", 2, "concat", 2, 2, "print", 1, 35, 32, "%D", 36, 0, 2, "formatDateTime", 2, 32, "%D: ", 2, "concat", 2, 2, -"print", 1, 35, 32, "%e", 36, 0, 2, "formatDateTime", 2, 32, "%e: ", 2, "concat", 2, 2, "print", 1, 35, 32, "%F", 36, 0, -2, "formatDateTime", 2, 32, "%F: ", 2, "concat", 2, 2, "print", 1, 35, 32, "%g", 36, 0, 2, "formatDateTime", 2, 32, -"%g: ", 2, "concat", 2, 2, "print", 1, 35, 32, "%G", 36, 0, 2, "formatDateTime", 2, 32, "%G: ", 2, "concat", 2, 2, -"print", 1, 35, 32, "%h", 36, 0, 2, "formatDateTime", 2, 32, "%h: ", 2, "concat", 2, 2, "print", 1, 35, 32, "%H", 36, 0, -2, "formatDateTime", 2, 32, "%H: ", 2, "concat", 2, 2, "print", 1, 35, 32, "%i", 36, 0, 2, "formatDateTime", 2, 32, -"%i: ", 2, "concat", 2, 2, "print", 1, 35, 32, "%I", 36, 0, 2, "formatDateTime", 2, 32, "%I: ", 2, "concat", 2, 2, -"print", 1, 35, 32, "%j", 36, 0, 2, "formatDateTime", 2, 32, "%j: ", 2, "concat", 2, 2, "print", 1, 35, 32, "%k", 36, 0, -2, "formatDateTime", 2, 32, "%k: ", 2, "concat", 2, 2, "print", 1, 35, 32, "%l", 36, 0, 2, "formatDateTime", 2, 32, -"%l: ", 2, "concat", 2, 2, "print", 1, 35, 32, "%m", 36, 0, 2, "formatDateTime", 2, 32, "%m: ", 2, "concat", 2, 2, -"print", 1, 35, 32, "%M", 36, 0, 2, "formatDateTime", 2, 32, "%M: ", 2, "concat", 2, 2, "print", 1, 35, 32, "%n", 36, 0, -2, "formatDateTime", 2, 32, "%n: ", 2, "concat", 2, 2, "print", 1, 35, 32, "%p", 36, 0, 2, "formatDateTime", 2, 32, -"%p: ", 2, "concat", 2, 2, "print", 1, 35, 32, "%r", 36, 0, 2, "formatDateTime", 2, 32, "%r: ", 2, "concat", 2, 2, -"print", 1, 35, 32, "%R", 36, 0, 2, "formatDateTime", 2, 32, "%R: ", 2, "concat", 2, 2, "print", 1, 35, 32, "%s", 36, 0, -2, "formatDateTime", 2, 32, "%s: ", 2, "concat", 2, 2, "print", 1, 35, 32, "%S", 36, 0, 2, "formatDateTime", 2, 32, -"%S: ", 2, "concat", 2, 2, "print", 1, 35, 32, "%t", 36, 0, 2, "formatDateTime", 2, 32, "%t: ", 2, "concat", 2, 2, -"print", 1, 35, 32, "%T", 36, 0, 2, "formatDateTime", 2, 32, "%T: ", 2, "concat", 2, 2, "print", 1, 35, 32, "%u", 36, 0, -2, "formatDateTime", 2, 32, "%u: ", 2, "concat", 2, 2, "print", 1, 35, 32, "%V", 36, 0, 2, "formatDateTime", 2, 32, -"%V: ", 2, "concat", 2, 2, "print", 1, 35, 32, "%w", 36, 0, 2, "formatDateTime", 2, 32, "%w: ", 2, "concat", 2, 2, -"print", 1, 35, 32, "%W", 36, 0, 2, "formatDateTime", 2, 32, "%W: ", 2, "concat", 2, 2, "print", 1, 35, 32, "%y", 36, 0, -2, "formatDateTime", 2, 32, "%y: ", 2, "concat", 2, 2, "print", 1, 35, 32, "%Y", 36, 0, 2, "formatDateTime", 2, 32, -"%Y: ", 2, "concat", 2, 2, "print", 1, 35, 32, "%z", 36, 0, 2, "formatDateTime", 2, 32, "%z: ", 2, "concat", 2, 2, -"print", 1, 35, 32, "%%", 36, 0, 2, "formatDateTime", 2, 32, "%%: ", 2, "concat", 2, 2, "print", 1, 35, 32, "-----", 2, -"print", 1, 35, 32, "one banana", 36, 0, 2, "formatDateTime", 2, 2, "print", 1, 35, 32, -"%Y no way %m is this %d a %H real %i time %S", 36, 0, 2, "formatDateTime", 2, 2, "print", 1, 35, 35] +["_H", 1, 34, 1234377543.123456, 2, "fromUnixTimestamp", 1, 36, 0, 32, "%Y-%m-%d %H:%i:%S", 2, "formatDateTime", 2, 2, +"print", 1, 35, 36, 0, 32, "%Y-%m-%d %H:%i:%S", 32, "Europe/Brussels", 2, "formatDateTime", 3, 2, "print", 1, 35, 36, 0, +32, "%Y-%m-%d %H:%i:%S", 32, "America/New_York", 2, "formatDateTime", 3, 2, "print", 1, 35, 36, 0, 32, "%Y%m%dT%H%i%sZ", +2, "formatDateTime", 2, 2, "print", 1, 35, 32, "-----", 2, "print", 1, 35, 32, "%a: ", 36, 0, 32, "%a", 2, +"formatDateTime", 2, 2, "concat", 2, 2, "print", 1, 35, 32, "%b: ", 36, 0, 32, "%b", 2, "formatDateTime", 2, 2, +"concat", 2, 2, "print", 1, 35, 32, "%c: ", 36, 0, 32, "%c", 2, "formatDateTime", 2, 2, "concat", 2, 2, "print", 1, 35, +32, "%C: ", 36, 0, 32, "%C", 2, "formatDateTime", 2, 2, "concat", 2, 2, "print", 1, 35, 32, "%d: ", 36, 0, 32, "%d", 2, +"formatDateTime", 2, 2, "concat", 2, 2, "print", 1, 35, 32, "%D: ", 36, 0, 32, "%D", 2, "formatDateTime", 2, 2, +"concat", 2, 2, "print", 1, 35, 32, "%e: ", 36, 0, 32, "%e", 2, "formatDateTime", 2, 2, "concat", 2, 2, "print", 1, 35, +32, "%F: ", 36, 0, 32, "%F", 2, "formatDateTime", 2, 2, "concat", 2, 2, "print", 1, 35, 32, "%g: ", 36, 0, 32, "%g", 2, +"formatDateTime", 2, 2, "concat", 2, 2, "print", 1, 35, 32, "%G: ", 36, 0, 32, "%G", 2, "formatDateTime", 2, 2, +"concat", 2, 2, "print", 1, 35, 32, "%h: ", 36, 0, 32, "%h", 2, "formatDateTime", 2, 2, "concat", 2, 2, "print", 1, 35, +32, "%H: ", 36, 0, 32, "%H", 2, "formatDateTime", 2, 2, "concat", 2, 2, "print", 1, 35, 32, "%i: ", 36, 0, 32, "%i", 2, +"formatDateTime", 2, 2, "concat", 2, 2, "print", 1, 35, 32, "%I: ", 36, 0, 32, "%I", 2, "formatDateTime", 2, 2, +"concat", 2, 2, "print", 1, 35, 32, "%j: ", 36, 0, 32, "%j", 2, "formatDateTime", 2, 2, "concat", 2, 2, "print", 1, 35, +32, "%k: ", 36, 0, 32, "%k", 2, "formatDateTime", 2, 2, "concat", 2, 2, "print", 1, 35, 32, "%l: ", 36, 0, 32, "%l", 2, +"formatDateTime", 2, 2, "concat", 2, 2, "print", 1, 35, 32, "%m: ", 36, 0, 32, "%m", 2, "formatDateTime", 2, 2, +"concat", 2, 2, "print", 1, 35, 32, "%M: ", 36, 0, 32, "%M", 2, "formatDateTime", 2, 2, "concat", 2, 2, "print", 1, 35, +32, "%n: ", 36, 0, 32, "%n", 2, "formatDateTime", 2, 2, "concat", 2, 2, "print", 1, 35, 32, "%p: ", 36, 0, 32, "%p", 2, +"formatDateTime", 2, 2, "concat", 2, 2, "print", 1, 35, 32, "%r: ", 36, 0, 32, "%r", 2, "formatDateTime", 2, 2, +"concat", 2, 2, "print", 1, 35, 32, "%R: ", 36, 0, 32, "%R", 2, "formatDateTime", 2, 2, "concat", 2, 2, "print", 1, 35, +32, "%s: ", 36, 0, 32, "%s", 2, "formatDateTime", 2, 2, "concat", 2, 2, "print", 1, 35, 32, "%S: ", 36, 0, 32, "%S", 2, +"formatDateTime", 2, 2, "concat", 2, 2, "print", 1, 35, 32, "%t: ", 36, 0, 32, "%t", 2, "formatDateTime", 2, 2, +"concat", 2, 2, "print", 1, 35, 32, "%T: ", 36, 0, 32, "%T", 2, "formatDateTime", 2, 2, "concat", 2, 2, "print", 1, 35, +32, "%u: ", 36, 0, 32, "%u", 2, "formatDateTime", 2, 2, "concat", 2, 2, "print", 1, 35, 32, "%V: ", 36, 0, 32, "%V", 2, +"formatDateTime", 2, 2, "concat", 2, 2, "print", 1, 35, 32, "%w: ", 36, 0, 32, "%w", 2, "formatDateTime", 2, 2, +"concat", 2, 2, "print", 1, 35, 32, "%W: ", 36, 0, 32, "%W", 2, "formatDateTime", 2, 2, "concat", 2, 2, "print", 1, 35, +32, "%y: ", 36, 0, 32, "%y", 2, "formatDateTime", 2, 2, "concat", 2, 2, "print", 1, 35, 32, "%Y: ", 36, 0, 32, "%Y", 2, +"formatDateTime", 2, 2, "concat", 2, 2, "print", 1, 35, 32, "%z: ", 36, 0, 32, "%z", 2, "formatDateTime", 2, 2, +"concat", 2, 2, "print", 1, 35, 32, "%%: ", 36, 0, 32, "%%", 2, "formatDateTime", 2, 2, "concat", 2, 2, "print", 1, 35, +32, "-----", 2, "print", 1, 35, 36, 0, 32, "one banana", 2, "formatDateTime", 2, 2, "print", 1, 35, 36, 0, 32, +"%Y no way %m is this %d a %H real %i time %S", 2, "formatDateTime", 2, 2, "print", 1, 35, 35] diff --git a/hogvm/__tests__/__snapshots__/dicts.hoge b/hogvm/__tests__/__snapshots__/dicts.hoge index 91aee718f176b..f0c4895e60b94 100644 --- a/hogvm/__tests__/__snapshots__/dicts.hoge +++ b/hogvm/__tests__/__snapshots__/dicts.hoge @@ -1,6 +1,6 @@ -["_h", 42, 0, 2, "print", 1, 35, 32, "key", 32, "value", 42, 1, 2, "print", 1, 35, 32, "key", 32, "value", 32, "other", -32, "thing", 42, 2, 2, "print", 1, 35, 32, "key", 32, "otherKey", 32, "value", 42, 1, 42, 1, 2, "print", 1, 35, 32, -"key", 1, 1, 32, "value", 42, 1, 2, "print", 1, 35, 33, 3, 36, 0, 32, "value", 42, 1, 2, "print", 1, 35, 32, "key", 32, -"value", 42, 1, 32, "key", 45, 2, "print", 1, 35, 32, "key", 32, "value", 42, 1, 32, "key", 45, 2, "print", 1, 35, 32, -"key", 32, "otherKey", 32, "value", 42, 1, 42, 1, 32, "key", 45, 32, "otherKey", 45, 2, "print", 1, 35, 32, "key", 32, -"otherKey", 32, "value", 42, 1, 42, 1, 32, "key", 45, 32, "otherKey", 45, 2, "print", 1, 35, 35] +["_H", 1, 42, 0, 2, "print", 1, 35, 32, "key", 32, "value", 42, 1, 2, "print", 1, 35, 32, "key", 32, "value", 32, +"other", 32, "thing", 42, 2, 2, "print", 1, 35, 32, "key", 32, "otherKey", 32, "value", 42, 1, 42, 1, 2, "print", 1, 35, +33, 3, 36, 0, 32, "value", 42, 1, 2, "print", 1, 35, 32, "key", 32, "value", 42, 1, 32, "key", 45, 2, "print", 1, 35, +32, "key", 32, "value", 42, 1, 32, "key", 45, 2, "print", 1, 35, 32, "key", 32, "otherKey", 32, "value", 42, 1, 42, 1, +32, "key", 45, 32, "otherKey", 45, 2, "print", 1, 35, 32, "key", 32, "otherKey", 32, "value", 42, 1, 42, 1, 32, "key", +45, 32, "otherKey", 45, 2, "print", 1, 35, 35] diff --git a/hogvm/__tests__/__snapshots__/dicts.stdout b/hogvm/__tests__/__snapshots__/dicts.stdout index 6a8cdfef1b6eb..33e60af57d4e5 100644 --- a/hogvm/__tests__/__snapshots__/dicts.stdout +++ b/hogvm/__tests__/__snapshots__/dicts.stdout @@ -2,7 +2,6 @@ {'key': 'value'} {'key': 'value', 'other': 'thing'} {'key': {'otherKey': 'value'}} -{null: 'value'} {3: 'value'} value value diff --git a/hogvm/__tests__/__snapshots__/exceptions.hoge b/hogvm/__tests__/__snapshots__/exceptions.hoge index 41aa587028ab3..a4a5b1d16a4b2 100644 --- a/hogvm/__tests__/__snapshots__/exceptions.hoge +++ b/hogvm/__tests__/__snapshots__/exceptions.hoge @@ -1,14 +1,14 @@ -["_h", 32, "start", 2, "print", 1, 35, 50, 10, 32, "try", 2, "print", 1, 35, 51, 39, 22, 36, 0, 32, "type", 45, 32, -" was the exception", 36, 0, 2, "concat", 2, 2, "print", 1, 35, 39, 2, 35, 49, 35, 35, 32, "------------------", 2, +["_H", 1, 32, "start", 2, "print", 1, 35, 50, 10, 32, "try", 2, "print", 1, 35, 51, 39, 22, 36, 0, 32, "type", 45, 36, +0, 32, " was the exception", 2, "concat", 2, 2, "print", 1, 35, 39, 2, 35, 49, 35, 35, 32, "------------------", 2, "print", 1, 35, 32, "start", 2, "print", 1, 35, 50, 10, 32, "try", 2, "print", 1, 35, 51, 39, 17, 36, 0, 32, "type", 45, 32, "No var for error, but no error", 2, "print", 1, 35, 39, 2, 35, 49, 35, 35, 32, "------------------", 2, "print", 1, -35, 50, 16, 32, "try again", 2, "print", 1, 35, 31, 31, 2, "Error", 2, 49, 51, 39, 22, 36, 0, 32, "type", 45, 32, -" was the exception", 36, 0, 2, "concat", 2, 2, "print", 1, 35, 39, 2, 35, 49, 35, 35, 32, "------------------", 2, -"print", 1, 35, 50, 16, 32, "try again", 2, "print", 1, 35, 31, 31, 2, "Error", 2, 49, 51, 39, 17, 36, 0, 32, "type", -45, 32, "No var for error", 2, "print", 1, 35, 39, 2, 35, 49, 35, 35, 32, "------------------", 2, "print", 1, 35, 41, -"third", 0, 15, 32, "Throwing in third", 2, "print", 1, 35, 31, 32, "Threw in third", 2, "Error", 2, 49, 31, 38, 41, -"second", 0, 12, 32, "second", 2, "print", 1, 35, 2, "third", 0, 35, 31, 38, 41, "first", 0, 12, 32, "first", 2, -"print", 1, 35, 2, "second", 0, 35, 31, 38, 41, "base", 0, 42, 32, "base", 2, "print", 1, 35, 50, 8, 2, "first", 0, 35, -51, 39, 25, 36, 0, 32, "type", 45, 36, 0, 32, "Caught in base: ", 2, "concat", 2, 2, "print", 1, 35, 36, 0, 49, 39, 2, -35, 49, 35, 35, 31, 38, 50, 8, 2, "base", 0, 35, 51, 39, 22, 36, 0, 32, "type", 45, 36, 0, 32, "Caught in root: ", 2, -"concat", 2, 2, "print", 1, 35, 39, 2, 35, 49, 35, 35, 32, "The end", 2, "print", 1, 35] +35, 50, 16, 32, "try again", 2, "print", 1, 35, 31, 31, 2, "Error", 2, 49, 51, 39, 22, 36, 0, 32, "type", 45, 36, 0, 32, +" was the exception", 2, "concat", 2, 2, "print", 1, 35, 39, 2, 35, 49, 35, 35, 32, "------------------", 2, "print", 1, +35, 50, 16, 32, "try again", 2, "print", 1, 35, 31, 31, 2, "Error", 2, 49, 51, 39, 17, 36, 0, 32, "type", 45, 32, +"No var for error", 2, "print", 1, 35, 39, 2, 35, 49, 35, 35, 32, "------------------", 2, "print", 1, 35, 41, "third", +0, 15, 32, "Throwing in third", 2, "print", 1, 35, 32, "Threw in third", 31, 2, "Error", 2, 49, 31, 38, 41, "second", 0, +12, 32, "second", 2, "print", 1, 35, 2, "third", 0, 35, 31, 38, 41, "first", 0, 12, 32, "first", 2, "print", 1, 35, 2, +"second", 0, 35, 31, 38, 41, "base", 0, 42, 32, "base", 2, "print", 1, 35, 50, 8, 2, "first", 0, 35, 51, 39, 25, 36, 0, +32, "type", 45, 32, "Caught in base: ", 36, 0, 2, "concat", 2, 2, "print", 1, 35, 36, 0, 49, 39, 2, 35, 49, 35, 35, 31, +38, 50, 8, 2, "base", 0, 35, 51, 39, 22, 36, 0, 32, "type", 45, 32, "Caught in root: ", 36, 0, 2, "concat", 2, 2, +"print", 1, 35, 39, 2, 35, 49, 35, 35, 32, "The end", 2, "print", 1, 35] diff --git a/hogvm/__tests__/__snapshots__/functions.hoge b/hogvm/__tests__/__snapshots__/functions.hoge index aa61602e4a1c7..0351cb7ce179d 100644 --- a/hogvm/__tests__/__snapshots__/functions.hoge +++ b/hogvm/__tests__/__snapshots__/functions.hoge @@ -1,14 +1,14 @@ -["_h", 32, "-- test functions --", 2, "print", 1, 35, 41, "add", 2, 6, 36, 0, 36, 1, 6, 38, 41, "add2", 2, 9, 36, 0, 36, -1, 6, 36, 2, 38, 35, 41, "mult", 2, 6, 36, 0, 36, 1, 8, 38, 41, "noArgs", 0, 12, 32, "basdfasdf", 33, 3, 33, 2, 6, 36, -1, 38, 35, 35, 41, "empty", 0, 2, 31, 38, 41, "empty2", 0, 2, 31, 38, 41, "empty3", 0, 2, 31, 38, 41, "noReturn", 0, 14, -33, 1, 33, 2, 36, 1, 36, 0, 6, 31, 38, 35, 35, 35, 41, "emptyReturn", 0, 2, 31, 38, 41, "emptyReturnBeforeOtherStuff", -0, 10, 31, 38, 33, 2, 33, 2, 6, 35, 31, 38, 41, "emptyReturnBeforeOtherStuffNoSemicolon", 0, 6, 33, 2, 33, 2, 6, 38, 41, -"ifThenReturn", 0, 8, 30, 40, 2, 31, 38, 33, 4, 38, 33, 4, 33, 3, 2, "add", 2, 2, "print", 1, 35, 33, 1, 33, 1, 2, -"add", 2, 33, 100, 33, 4, 33, 3, 2, "add", 2, 6, 6, 2, "print", 1, 35, 2, "noArgs", 0, 47, 3, 35, 33, -1, 2, "print", 1, -35, 2, "empty", 0, 47, 3, 35, 33, -1, 2, "print", 1, 35, 2, "empty2", 0, 47, 3, 35, 33, -1, 2, "print", 1, 35, 2, -"empty3", 0, 47, 3, 35, 33, -1, 2, "print", 1, 35, 2, "noReturn", 0, 47, 3, 35, 33, -1, 2, "print", 1, 35, 2, -"emptyReturn", 0, 47, 3, 35, 33, -1, 2, "print", 1, 35, 2, "emptyReturnBeforeOtherStuff", 0, 47, 3, 35, 33, -1, 2, -"print", 1, 35, 2, "emptyReturnBeforeOtherStuffNoSemicolon", 0, 47, 3, 35, 33, -1, 2, "print", 1, 35, 2, "ifThenReturn", -0, 47, 3, 35, 33, -1, 2, "print", 1, 35, 33, 2, 33, 1, 33, 2, 2, "add", 2, 33, 100, 33, 4, 33, 3, 2, "add", 2, 6, 6, 2, -"mult", 2, 2, "print", 1, 35, 33, 10, 33, 1, 33, 2, 2, "add2", 2, 33, 100, 33, 4, 33, 3, 2, "add2", 2, 6, 6, 2, "mult", -2, 2, "print", 1, 35] +["_H", 1, 32, "-- test functions --", 2, "print", 1, 35, 41, "add", 2, 6, 36, 1, 36, 0, 6, 38, 41, "add2", 2, 9, 36, 1, +36, 0, 6, 36, 2, 38, 35, 41, "mult", 2, 6, 36, 1, 36, 0, 8, 38, 41, "noArgs", 0, 12, 32, "basdfasdf", 33, 3, 33, 2, 6, +36, 1, 38, 35, 35, 41, "empty", 0, 2, 31, 38, 41, "empty2", 0, 2, 31, 38, 41, "empty3", 0, 2, 31, 38, 41, "noReturn", 0, +14, 33, 1, 33, 2, 36, 1, 36, 0, 6, 31, 38, 35, 35, 35, 41, "emptyReturn", 0, 2, 31, 38, 41, +"emptyReturnBeforeOtherStuff", 0, 10, 31, 38, 33, 2, 33, 2, 6, 35, 31, 38, 41, "emptyReturnBeforeOtherStuffNoSemicolon", +0, 6, 33, 2, 33, 2, 6, 38, 41, "ifThenReturn", 0, 8, 30, 40, 2, 31, 38, 33, 4, 38, 33, 3, 33, 4, 2, "add", 2, 2, +"print", 1, 35, 33, 1, 33, 1, 2, "add", 2, 33, 100, 33, 3, 33, 4, 2, "add", 2, 6, 6, 2, "print", 1, 35, 2, "noArgs", 0, +47, 3, 35, 33, -1, 2, "print", 1, 35, 2, "empty", 0, 47, 3, 35, 33, -1, 2, "print", 1, 35, 2, "empty2", 0, 47, 3, 35, +33, -1, 2, "print", 1, 35, 2, "empty3", 0, 47, 3, 35, 33, -1, 2, "print", 1, 35, 2, "noReturn", 0, 47, 3, 35, 33, -1, 2, +"print", 1, 35, 2, "emptyReturn", 0, 47, 3, 35, 33, -1, 2, "print", 1, 35, 2, "emptyReturnBeforeOtherStuff", 0, 47, 3, +35, 33, -1, 2, "print", 1, 35, 2, "emptyReturnBeforeOtherStuffNoSemicolon", 0, 47, 3, 35, 33, -1, 2, "print", 1, 35, 2, +"ifThenReturn", 0, 47, 3, 35, 33, -1, 2, "print", 1, 35, 33, 2, 33, 1, 2, "add", 2, 33, 100, 33, 3, 33, 4, 2, "add", 2, +6, 6, 33, 2, 2, "mult", 2, 2, "print", 1, 35, 33, 2, 33, 1, 2, "add2", 2, 33, 100, 33, 3, 33, 4, 2, "add2", 2, 6, 6, 33, +10, 2, "mult", 2, 2, "print", 1, 35] diff --git a/hogvm/__tests__/__snapshots__/ifElse.hoge b/hogvm/__tests__/__snapshots__/ifElse.hoge index 0aaef24a74f80..b5deffdd6f5f7 100644 --- a/hogvm/__tests__/__snapshots__/ifElse.hoge +++ b/hogvm/__tests__/__snapshots__/ifElse.hoge @@ -1,4 +1,4 @@ -["_h", 32, "-- test if else --", 2, "print", 1, 35, 29, 40, 8, 33, 1, 2, "print", 1, 35, 39, 6, 33, 2, 2, "print", 1, +["_H", 1, 32, "-- test if else --", 2, "print", 1, 35, 29, 40, 8, 33, 1, 2, "print", 1, 35, 39, 6, 33, 2, 2, "print", 1, 35, 29, 40, 8, 33, 1, 2, "print", 1, 35, 39, 6, 33, 2, 2, "print", 1, 35, 30, 40, 8, 33, 1, 2, "print", 1, 35, 39, 6, 33, 2, 2, "print", 1, 35, 29, 40, 8, 33, 1, 2, "print", 1, 35, 39, 6, 33, 2, 2, "print", 1, 35, 29, 36, 0, 40, 14, 33, 3, 33, 2, 36, 1, 6, 2, "print", 1, 35, 35, 39, 6, 33, 2, 2, "print", 1, 35, 35] diff --git a/hogvm/__tests__/__snapshots__/ifJump.hoge b/hogvm/__tests__/__snapshots__/ifJump.hoge index 0e946f4101f07..f90184dea86fd 100644 --- a/hogvm/__tests__/__snapshots__/ifJump.hoge +++ b/hogvm/__tests__/__snapshots__/ifJump.hoge @@ -1,3 +1,3 @@ -["_h", 42, 0, 36, 0, 32, "email", 45, 32, "", 36, 1, 11, 40, 12, 32, "ERROR - Email not found!", 2, "print", 1, 35, 32, -"3", 2, "print", 1, 35, 32, "1", 2, "print", 1, 35, 32, "", 36, 1, 11, 40, 14, 32, "ERROR - Email not found!", 2, +["_H", 1, 42, 0, 36, 0, 32, "email", 45, 32, "", 36, 1, 11, 40, 12, 32, "ERROR - Email not found!", 2, "print", 1, 35, +32, "3", 2, "print", 1, 35, 32, "1", 2, "print", 1, 35, 32, "", 36, 1, 11, 40, 14, 32, "ERROR - Email not found!", 2, "print", 1, 35, 32, "3", 2, "print", 1, 35, 39, 6, 32, "else", 2, "print", 1, 35, 32, "1", 2, "print", 1, 35, 35, 35] diff --git a/hogvm/__tests__/__snapshots__/json.hoge b/hogvm/__tests__/__snapshots__/json.hoge index df9948388e519..e23e7a772b6b9 100644 --- a/hogvm/__tests__/__snapshots__/json.hoge +++ b/hogvm/__tests__/__snapshots__/json.hoge @@ -1,3 +1,3 @@ -["_h", 32, "[1,2,3]", 2, "jsonParse", 1, 2, "print", 1, 35, 32, "event", 32, "$pageview", 32, "properties", 32, +["_H", 1, 32, "[1,2,3]", 2, "jsonParse", 1, 2, "print", 1, 35, 32, "event", 32, "$pageview", 32, "properties", 32, "$browser", 32, "Chrome", 32, "$os", 32, "Windows", 42, 2, 42, 2, 36, 0, 2, "jsonStringify", 1, 36, 1, 2, "jsonParse", 1, 2, "print", 1, 35, 35, 35] diff --git a/hogvm/__tests__/__snapshots__/keysValues.hoge b/hogvm/__tests__/__snapshots__/keysValues.hoge index 594b0869a792b..83f13a3825362 100644 --- a/hogvm/__tests__/__snapshots__/keysValues.hoge +++ b/hogvm/__tests__/__snapshots__/keysValues.hoge @@ -1,4 +1,4 @@ -["_h", 33, 3, 33, 4, 33, 5, 43, 3, 33, 3, 33, 4, 33, 5, 44, 3, 32, "key", 32, "value", 32, "other", 32, "val", 42, 2, +["_H", 1, 33, 3, 33, 4, 33, 5, 43, 3, 33, 3, 33, 4, 33, 5, 44, 3, 32, "key", 32, "value", 32, "other", 32, "val", 42, 2, 32, ">> A", 2, "print", 1, 35, 36, 0, 2, "keys", 1, 2, "print", 1, 35, 36, 0, 2, "values", 1, 2, "print", 1, 35, 32, ">> B", 2, "print", 1, 35, 36, 1, 2, "keys", 1, 2, "print", 1, 35, 36, 1, 2, "values", 1, 2, "print", 1, 35, 32, ">> C", 2, "print", 1, 35, 36, 2, 2, "keys", 1, 2, "print", 1, 35, 36, 2, 2, "values", 1, 2, "print", 1, 35, 35, 35, 35] diff --git a/hogvm/__tests__/__snapshots__/loops.hoge b/hogvm/__tests__/__snapshots__/loops.hoge index a3328220d6bd9..51d41fb4ceadd 100644 --- a/hogvm/__tests__/__snapshots__/loops.hoge +++ b/hogvm/__tests__/__snapshots__/loops.hoge @@ -1,22 +1,22 @@ -["_h", 32, "-- test while loop --", 2, "print", 1, 35, 33, 0, 33, 3, 36, 0, 15, 40, 15, 33, 1, 36, 0, 6, 37, 0, 36, 0, -2, "print", 1, 35, 39, -22, 36, 0, 2, "print", 1, 35, 35, 32, "-- test for loop --", 2, "print", 1, 35, 33, 0, 33, 3, -36, 0, 15, 40, 15, 36, 0, 2, "print", 1, 35, 33, 1, 36, 0, 6, 37, 0, 39, -22, 35, 32, "i", 1, 1, 2, "print", 1, 35, 32, -"-- test emptier for loop --", 2, "print", 1, 35, 33, 0, 33, 3, 36, 0, 15, 40, 15, 32, "woo", 2, "print", 1, 35, 33, 1, -36, 0, 6, 37, 0, 39, -22, 32, "hoo", 2, "print", 1, 35, 35, 32, "-- for in loop with arrays --", 2, "print", 1, 35, 33, -1, 33, 2, 33, 3, 43, 3, 36, 0, 36, 1, 2, "values", 1, 33, 1, 36, 2, 2, "length", 1, 31, 36, 4, 36, 3, 16, 40, 22, 36, 2, -36, 3, 45, 37, 5, 36, 5, 2, "print", 1, 35, 36, 3, 33, 1, 6, 37, 3, 39, -29, 35, 35, 35, 35, 35, 35, 32, -"-- for in loop with arrays and keys --", 2, "print", 1, 35, 33, 1, 33, 2, 33, 3, 43, 3, 36, 0, 36, 1, 2, "keys", 1, 36, -1, 2, "values", 1, 33, 1, 36, 3, 2, "length", 1, 31, 31, 36, 5, 36, 4, 16, 40, 31, 36, 2, 36, 4, 45, 37, 6, 36, 3, 36, -4, 45, 37, 7, 36, 7, 36, 6, 2, "print", 2, 35, 36, 4, 33, 1, 6, 37, 4, 39, -38, 35, 35, 35, 35, 35, 35, 35, 35, 32, -"-- for in loop with tuples --", 2, "print", 1, 35, 33, 1, 33, 2, 33, 3, 44, 3, 36, 0, 36, 1, 2, "values", 1, 33, 1, 36, -2, 2, "length", 1, 31, 36, 4, 36, 3, 16, 40, 22, 36, 2, 36, 3, 45, 37, 5, 36, 5, 2, "print", 1, 35, 36, 3, 33, 1, 6, 37, -3, 39, -29, 35, 35, 35, 35, 35, 35, 32, "-- for in loop with tuples and keys --", 2, "print", 1, 35, 33, 1, 33, 2, 33, -3, 44, 3, 36, 0, 36, 1, 2, "keys", 1, 36, 1, 2, "values", 1, 33, 1, 36, 3, 2, "length", 1, 31, 31, 36, 5, 36, 4, 16, 40, -31, 36, 2, 36, 4, 45, 37, 6, 36, 3, 36, 4, 45, 37, 7, 36, 7, 36, 6, 2, "print", 2, 35, 36, 4, 33, 1, 6, 37, 4, 39, -38, -35, 35, 35, 35, 35, 35, 35, 35, 32, "-- for in loop with dicts --", 2, "print", 1, 35, 32, "first", 32, "v1", 32, -"second", 32, "v2", 32, "third", 32, "v3", 42, 3, 36, 0, 36, 1, 2, "values", 1, 33, 1, 36, 2, 2, "length", 1, 31, 36, 4, -36, 3, 16, 40, 22, 36, 2, 36, 3, 45, 37, 5, 36, 5, 2, "print", 1, 35, 36, 3, 33, 1, 6, 37, 3, 39, -29, 35, 35, 35, 35, -35, 35, 32, "-- for in loop with dicts and keys --", 2, "print", 1, 35, 32, "first", 32, "v1", 32, "second", 32, "v2", -32, "third", 32, "v3", 42, 3, 36, 0, 36, 1, 2, "keys", 1, 36, 1, 2, "values", 1, 33, 1, 36, 3, 2, "length", 1, 31, 31, -36, 5, 36, 4, 16, 40, 31, 36, 2, 36, 4, 45, 37, 6, 36, 3, 36, 4, 45, 37, 7, 36, 7, 36, 6, 2, "print", 2, 35, 36, 4, 33, -1, 6, 37, 4, 39, -38, 35, 35, 35, 35, 35, 35, 35, 35] +["_H", 1, 32, "-- test while loop --", 2, "print", 1, 35, 33, 0, 33, 3, 36, 0, 15, 40, 15, 33, 1, 36, 0, 6, 37, 0, 36, +0, 2, "print", 1, 35, 39, -22, 36, 0, 2, "print", 1, 35, 35, 32, "-- test for loop --", 2, "print", 1, 35, 33, 0, 33, 3, +36, 0, 15, 40, 15, 36, 0, 2, "print", 1, 35, 33, 1, 36, 0, 6, 37, 0, 39, -22, 35, 32, "-- test emptier for loop --", 2, +"print", 1, 35, 33, 0, 33, 3, 36, 0, 15, 40, 15, 32, "woo", 2, "print", 1, 35, 33, 1, 36, 0, 6, 37, 0, 39, -22, 32, +"hoo", 2, "print", 1, 35, 35, 32, "-- for in loop with arrays --", 2, "print", 1, 35, 33, 1, 33, 2, 33, 3, 43, 3, 36, 0, +36, 1, 2, "values", 1, 33, 1, 36, 2, 2, "length", 1, 31, 36, 4, 36, 3, 16, 40, 22, 36, 2, 36, 3, 45, 37, 5, 36, 5, 2, +"print", 1, 35, 36, 3, 33, 1, 6, 37, 3, 39, -29, 35, 35, 35, 35, 35, 35, 32, "-- for in loop with arrays and keys --", +2, "print", 1, 35, 33, 1, 33, 2, 33, 3, 43, 3, 36, 0, 36, 1, 2, "keys", 1, 36, 1, 2, "values", 1, 33, 1, 36, 3, 2, +"length", 1, 31, 31, 36, 5, 36, 4, 16, 40, 31, 36, 2, 36, 4, 45, 37, 6, 36, 3, 36, 4, 45, 37, 7, 36, 6, 36, 7, 2, +"print", 2, 35, 36, 4, 33, 1, 6, 37, 4, 39, -38, 35, 35, 35, 35, 35, 35, 35, 35, 32, "-- for in loop with tuples --", 2, +"print", 1, 35, 33, 1, 33, 2, 33, 3, 44, 3, 36, 0, 36, 1, 2, "values", 1, 33, 1, 36, 2, 2, "length", 1, 31, 36, 4, 36, +3, 16, 40, 22, 36, 2, 36, 3, 45, 37, 5, 36, 5, 2, "print", 1, 35, 36, 3, 33, 1, 6, 37, 3, 39, -29, 35, 35, 35, 35, 35, +35, 32, "-- for in loop with tuples and keys --", 2, "print", 1, 35, 33, 1, 33, 2, 33, 3, 44, 3, 36, 0, 36, 1, 2, +"keys", 1, 36, 1, 2, "values", 1, 33, 1, 36, 3, 2, "length", 1, 31, 31, 36, 5, 36, 4, 16, 40, 31, 36, 2, 36, 4, 45, 37, +6, 36, 3, 36, 4, 45, 37, 7, 36, 6, 36, 7, 2, "print", 2, 35, 36, 4, 33, 1, 6, 37, 4, 39, -38, 35, 35, 35, 35, 35, 35, +35, 35, 32, "-- for in loop with dicts --", 2, "print", 1, 35, 32, "first", 32, "v1", 32, "second", 32, "v2", 32, +"third", 32, "v3", 42, 3, 36, 0, 36, 1, 2, "values", 1, 33, 1, 36, 2, 2, "length", 1, 31, 36, 4, 36, 3, 16, 40, 22, 36, +2, 36, 3, 45, 37, 5, 36, 5, 2, "print", 1, 35, 36, 3, 33, 1, 6, 37, 3, 39, -29, 35, 35, 35, 35, 35, 35, 32, +"-- for in loop with dicts and keys --", 2, "print", 1, 35, 32, "first", 32, "v1", 32, "second", 32, "v2", 32, "third", +32, "v3", 42, 3, 36, 0, 36, 1, 2, "keys", 1, 36, 1, 2, "values", 1, 33, 1, 36, 3, 2, "length", 1, 31, 31, 36, 5, 36, 4, +16, 40, 31, 36, 2, 36, 4, 45, 37, 6, 36, 3, 36, 4, 45, 37, 7, 36, 6, 36, 7, 2, "print", 2, 35, 36, 4, 33, 1, 6, 37, 4, +39, -38, 35, 35, 35, 35, 35, 35, 35, 35] diff --git a/hogvm/__tests__/__snapshots__/loops.stdout b/hogvm/__tests__/__snapshots__/loops.stdout index 270cb30b7ea47..0f4ad9c7493c5 100644 --- a/hogvm/__tests__/__snapshots__/loops.stdout +++ b/hogvm/__tests__/__snapshots__/loops.stdout @@ -7,7 +7,6 @@ 0 1 2 -null -- test emptier for loop -- woo woo diff --git a/hogvm/__tests__/__snapshots__/mandelbrot.hoge b/hogvm/__tests__/__snapshots__/mandelbrot.hoge index 211995efe2bc9..51895c2281458 100644 --- a/hogvm/__tests__/__snapshots__/mandelbrot.hoge +++ b/hogvm/__tests__/__snapshots__/mandelbrot.hoge @@ -1,8 +1,8 @@ -["_h", 41, "mandelbrot", 3, 93, 34, 0.0, 34, 0.0, 33, 0, 36, 0, 36, 5, 15, 33, 4, 36, 4, 36, 4, 8, 36, 3, 36, 3, 8, 6, -16, 3, 2, 40, 44, 36, 2, 36, 4, 36, 4, 8, 36, 3, 36, 3, 8, 7, 6, 36, 1, 36, 4, 36, 3, 33, 2, 8, 8, 6, 36, 6, 37, 3, 36, -7, 37, 4, 33, 1, 36, 5, 6, 37, 5, 35, 35, 39, -67, 36, 0, 36, 5, 11, 40, 5, 32, " ", 38, 39, 3, 32, "#", 38, 31, 38, 35, -35, 35, 41, "main", 0, 119, 33, 80, 33, 24, 34, -2.0, 34, 1.0, 34, -1.0, 34, 1.0, 33, 30, 33, 0, 36, 1, 36, 7, 15, 40, -86, 32, "", 33, 0, 36, 0, 36, 9, 15, 40, 58, 36, 2, 36, 2, 36, 3, 7, 36, 0, 36, 9, 9, 8, 6, 36, 4, 36, 4, 36, 5, 7, 36, -1, 36, 7, 9, 8, 6, 36, 6, 36, 11, 36, 10, 2, "mandelbrot", 3, 36, 12, 36, 8, 2, "concat", 2, 37, 8, 33, 1, 36, 9, 6, 37, -9, 35, 35, 35, 39, -65, 36, 8, 2, "print", 1, 35, 33, 1, 36, 7, 6, 37, 7, 35, 35, 39, -93, 31, 38, 35, 35, 35, 35, 35, -35, 35, 35, 2, "main", 0, 35] +["_H", 1, 41, "mandelbrot", 3, 93, 34, 0.0, 34, 0.0, 33, 0, 33, 4, 36, 4, 36, 4, 8, 36, 3, 36, 3, 8, 6, 16, 36, 2, 36, +5, 15, 3, 2, 40, 44, 36, 0, 36, 4, 36, 4, 8, 36, 3, 36, 3, 8, 7, 6, 36, 1, 36, 4, 36, 3, 33, 2, 8, 8, 6, 36, 6, 37, 3, +36, 7, 37, 4, 33, 1, 36, 5, 6, 37, 5, 35, 35, 39, -67, 36, 2, 36, 5, 11, 40, 5, 32, " ", 38, 39, 3, 32, "#", 38, 31, 38, +35, 35, 35, 41, "main", 0, 119, 33, 80, 33, 24, 34, -2.0, 34, 1.0, 34, -1.0, 34, 1.0, 33, 30, 33, 0, 36, 1, 36, 7, 15, +40, 86, 32, "", 33, 0, 36, 0, 36, 9, 15, 40, 58, 36, 2, 36, 2, 36, 3, 7, 36, 0, 36, 9, 9, 8, 6, 36, 4, 36, 4, 36, 5, 7, +36, 1, 36, 7, 9, 8, 6, 36, 10, 36, 11, 36, 6, 2, "mandelbrot", 3, 36, 8, 36, 12, 2, "concat", 2, 37, 8, 33, 1, 36, 9, 6, +37, 9, 35, 35, 35, 39, -65, 36, 8, 2, "print", 1, 35, 33, 1, 36, 7, 6, 37, 7, 35, 35, 39, -93, 31, 38, 35, 35, 35, 35, +35, 35, 35, 35, 2, "main", 0, 35] diff --git a/hogvm/__tests__/__snapshots__/operations.hoge b/hogvm/__tests__/__snapshots__/operations.hoge index 82156f1818f45..3abc0604f4040 100644 --- a/hogvm/__tests__/__snapshots__/operations.hoge +++ b/hogvm/__tests__/__snapshots__/operations.hoge @@ -1,26 +1,23 @@ -["_h", 41, "test", 1, 11, 36, 0, 2, "jsonStringify", 1, 2, "print", 1, 35, 31, 38, 32, +["_H", 1, 41, "test", 1, 11, 36, 0, 2, "jsonStringify", 1, 2, "print", 1, 35, 31, 38, 32, "-- test the most common expressions --", 2, "print", 1, 35, 33, 2, 33, 1, 6, 2, "test", 1, 35, 33, 2, 33, 1, 7, 2, "test", 1, 35, 33, 2, 33, 3, 8, 2, "test", 1, 35, 33, 2, 33, 3, 9, 2, "test", 1, 35, 33, 2, 33, 3, 10, 2, "test", 1, 35, -33, 2, 33, 1, 3, 2, 2, "test", 1, 35, 33, 0, 33, 1, 4, 2, 2, "test", 1, 35, 33, 0, 33, 1, 3, 2, 2, "test", 1, 35, 33, 2, -33, 1, 33, 0, 3, 2, 33, 1, 4, 3, 2, "test", 1, 35, 33, 1, 33, 0, 33, 1, 3, 3, 2, "test", 1, 35, 33, 2, 33, 1, 4, 2, 33, -2, 33, 1, 4, 2, 3, 2, 2, "test", 1, 35, 29, 2, "test", 1, 35, 29, 5, 2, "test", 1, 35, 30, 2, "test", 1, 35, 31, 2, +33, 1, 33, 2, 3, 2, 2, "test", 1, 35, 33, 1, 33, 0, 4, 2, 2, "test", 1, 35, 33, 1, 33, 0, 3, 2, 2, "test", 1, 35, 33, 1, +33, 0, 33, 1, 3, 2, 33, 2, 4, 3, 2, "test", 1, 35, 33, 1, 33, 0, 33, 1, 3, 3, 2, "test", 1, 35, 33, 1, 33, 2, 4, 2, 33, +1, 33, 2, 4, 2, 3, 2, 2, "test", 1, 35, 29, 2, "test", 1, 35, 29, 5, 2, "test", 1, 35, 30, 2, "test", 1, 35, 31, 2, "test", 1, 35, 34, 3.14, 2, "test", 1, 35, 33, 2, 33, 1, 11, 2, "test", 1, 35, 33, 2, 33, 1, 11, 2, "test", 1, 35, 33, 2, 33, 1, 12, 2, "test", 1, 35, 33, 2, 33, 1, 15, 2, "test", 1, 35, 33, 2, 33, 1, 16, 2, "test", 1, 35, 33, 2, 33, 1, 13, 2, "test", 1, 35, 33, 2, 33, 1, 14, 2, "test", 1, 35, 32, "b", 32, "a", 17, 2, "test", 1, 35, 32, "%a%", 32, "baa", 17, 2, "test", 1, 35, 32, "%x%", 32, "baa", 17, 2, "test", 1, 35, 32, "%A%", 32, "baa", 18, 2, "test", 1, 35, 32, "%C%", 32, "baa", 18, 2, "test", 1, 35, 32, "b", 32, "a", 18, 2, "test", 1, 35, 32, "b", 32, "a", 19, 2, "test", 1, 35, 32, "b", 32, "a", 20, 2, "test", 1, 35, 32, "car", 32, "a", 21, 2, "test", 1, 35, 32, "foo", 32, "a", 21, 2, "test", 1, 35, -32, "car", 32, "a", 22, 2, "test", 1, 35, 32, "bla", 32, "properties", 1, 2, 2, "test", 1, 35, 32, "foo", 32, -"properties", 1, 2, 2, "test", 1, 35, 32, "foo", 32, "properties", 1, 2, 47, 2, 35, 30, 2, "test", 1, 35, 32, -"nullValue", 32, "properties", 1, 2, 47, 2, 35, 30, 2, "test", 1, 35, 32, "another", 32, "arg", 2, "concat", 2, 2, -"test", 1, 35, 31, 33, 1, 2, "concat", 2, 2, "test", 1, 35, 30, 29, 2, "concat", 2, 2, "test", 1, 35, 32, "e.*", 32, -"test", 2, "match", 2, 2, "test", 1, 35, 32, "^e.*", 32, "test", 2, "match", 2, 2, "test", 1, 35, 32, "x.*", 32, "test", -2, "match", 2, 2, "test", 1, 35, 32, "e.*", 32, "test", 23, 2, "test", 1, 35, 32, "e.*", 32, "test", 24, 2, "test", 1, -35, 32, "^e.*", 32, "test", 23, 2, "test", 1, 35, 32, "^e.*", 32, "test", 24, 2, "test", 1, 35, 32, "x.*", 32, "test", -23, 2, "test", 1, 35, 32, "x.*", 32, "test", 24, 2, "test", 1, 35, 32, "EST", 32, "test", 25, 2, "test", 1, 35, 32, -"EST", 32, "test", 25, 2, "test", 1, 35, 32, "EST", 32, "test", 26, 2, "test", 1, 35, 33, 1, 2, "toString", 1, 2, -"test", 1, 35, 34, 1.5, 2, "toString", 1, 2, "test", 1, 35, 29, 2, "toString", 1, 2, "test", 1, 35, 31, 2, "toString", -1, 2, "test", 1, 35, 32, "string", 2, "toString", 1, 2, "test", 1, 35, 32, "1", 2, "toInt", 1, 2, "test", 1, 35, 32, -"bla", 2, "toInt", 1, 2, "test", 1, 35, 32, "1.2", 2, "toFloat", 1, 2, "test", 1, 35, 32, "bla", 2, "toFloat", 1, 2, -"test", 1, 35, 32, "asd", 2, "toUUID", 1, 2, "test", 1, 35, 31, 33, 1, 11, 2, "test", 1, 35, 31, 33, 1, 12, 2, "test", -1, 35] +32, "car", 32, "a", 22, 2, "test", 1, 35, 32, "arg", 32, "another", 2, "concat", 2, 2, "test", 1, 35, 33, 1, 31, 2, +"concat", 2, 2, "test", 1, 35, 29, 30, 2, "concat", 2, 2, "test", 1, 35, 32, "test", 32, "e.*", 2, "match", 2, 2, +"test", 1, 35, 32, "test", 32, "^e.*", 2, "match", 2, 2, "test", 1, 35, 32, "test", 32, "x.*", 2, "match", 2, 2, "test", +1, 35, 32, "e.*", 32, "test", 23, 2, "test", 1, 35, 32, "e.*", 32, "test", 24, 2, "test", 1, 35, 32, "^e.*", 32, "test", +23, 2, "test", 1, 35, 32, "^e.*", 32, "test", 24, 2, "test", 1, 35, 32, "x.*", 32, "test", 23, 2, "test", 1, 35, 32, +"x.*", 32, "test", 24, 2, "test", 1, 35, 32, "EST", 32, "test", 25, 2, "test", 1, 35, 32, "EST", 32, "test", 25, 2, +"test", 1, 35, 32, "EST", 32, "test", 26, 2, "test", 1, 35, 33, 1, 2, "toString", 1, 2, "test", 1, 35, 34, 1.5, 2, +"toString", 1, 2, "test", 1, 35, 29, 2, "toString", 1, 2, "test", 1, 35, 31, 2, "toString", 1, 2, "test", 1, 35, 32, +"string", 2, "toString", 1, 2, "test", 1, 35, 32, "1", 2, "toInt", 1, 2, "test", 1, 35, 32, "bla", 2, "toInt", 1, 2, +"test", 1, 35, 32, "1.2", 2, "toFloat", 1, 2, "test", 1, 35, 32, "bla", 2, "toFloat", 1, 2, "test", 1, 35, 32, "asd", 2, +"toUUID", 1, 2, "test", 1, 35, 31, 33, 1, 11, 2, "test", 1, 35, 31, 33, 1, 12, 2, "test", 1, 35] diff --git a/hogvm/__tests__/__snapshots__/operations.stdout b/hogvm/__tests__/__snapshots__/operations.stdout index 26b21bc43634d..5017b0e3005c7 100644 --- a/hogvm/__tests__/__snapshots__/operations.stdout +++ b/hogvm/__tests__/__snapshots__/operations.stdout @@ -33,10 +33,6 @@ true true false false -null -null -false -false "arganother" "1" "truefalse" diff --git a/hogvm/__tests__/__snapshots__/printLoops.hoge b/hogvm/__tests__/__snapshots__/printLoops.hoge index a53576adf8f3e..db0bc1d43e494 100644 --- a/hogvm/__tests__/__snapshots__/printLoops.hoge +++ b/hogvm/__tests__/__snapshots__/printLoops.hoge @@ -1,4 +1,4 @@ -["_h", 32, "key", 32, "value", 32, "key2", 32, "value2", 42, 2, 32, "na", 33, 0, 33, 100, 36, 2, 15, 40, 45, 32, "na", -36, 1, 2, "concat", 2, 37, 1, 36, 0, 36, 2, 32, "key_", 2, "concat", 2, 32, "wasted", 32, " batman!", 36, 1, 32, -"memory: ", 2, "concat", 3, 32, "something", 36, 0, 42, 2, 46, 33, 1, 36, 2, 6, 37, 2, 39, -52, 35, 36, 0, 2, "print", +["_H", 1, 32, "key", 32, "value", 32, "key2", 32, "value2", 42, 2, 32, "na", 33, 0, 33, 100, 36, 2, 15, 40, 45, 36, 1, +32, "na", 2, "concat", 2, 37, 1, 36, 0, 32, "key_", 36, 2, 2, "concat", 2, 32, "wasted", 32, "memory: ", 36, 1, 32, +" batman!", 2, "concat", 3, 32, "something", 36, 0, 42, 2, 46, 33, 1, 36, 2, 6, 37, 2, 39, -52, 35, 36, 0, 2, "print", 1, 35, 36, 0, 2, "jsonStringify", 1, 36, 2, 2, "jsonParse", 1, 2, "print", 1, 35, 35, 35, 35] diff --git a/hogvm/__tests__/__snapshots__/printLoops2.hoge b/hogvm/__tests__/__snapshots__/printLoops2.hoge index 487604661c03e..071363c073c55 100644 --- a/hogvm/__tests__/__snapshots__/printLoops2.hoge +++ b/hogvm/__tests__/__snapshots__/printLoops2.hoge @@ -1,4 +1,4 @@ -["_h", 32, "key", 32, "value", 32, "key2", 32, "value2", 42, 2, 32, "key", 32, "value", 32, "key2", 32, "value2", 42, 2, -33, 0, 33, 30, 36, 2, 15, 40, 25, 36, 0, 36, 2, 32, "key_", 2, "concat", 2, 32, "something", 36, 1, 42, 1, 46, 33, 1, +["_H", 1, 32, "key", 32, "value", 32, "key2", 32, "value2", 42, 2, 32, "key", 32, "value", 32, "key2", 32, "value2", 42, +2, 33, 0, 33, 30, 36, 2, 15, 40, 25, 36, 0, 32, "key_", 36, 2, 2, "concat", 2, 32, "something", 36, 1, 42, 1, 46, 33, 1, 36, 2, 6, 37, 2, 39, -32, 35, 36, 0, 2, "print", 1, 35, 36, 0, 2, "jsonStringify", 1, 2, "jsonParse", 1, 2, "print", 1, 35, 35, 35] diff --git a/hogvm/__tests__/__snapshots__/properties.hoge b/hogvm/__tests__/__snapshots__/properties.hoge index 39ec0648c4063..4ce7c2821449d 100644 --- a/hogvm/__tests__/__snapshots__/properties.hoge +++ b/hogvm/__tests__/__snapshots__/properties.hoge @@ -1,4 +1,4 @@ -["_h", 33, 1, 33, 2, 32, "d", 33, 1, 33, 3, 33, 42, 33, 6, 44, 4, 42, 1, 43, 3, 36, 0, 33, 3, 45, 32, "d", 45, 33, 2, +["_H", 1, 33, 1, 33, 2, 32, "d", 33, 1, 33, 3, 33, 42, 33, 6, 44, 4, 42, 1, 43, 3, 36, 0, 33, 3, 45, 32, "d", 45, 33, 2, 45, 2, "print", 1, 35, 35, 33, 1, 33, 2, 32, "d", 33, 1, 33, 3, 33, 42, 33, 6, 44, 4, 42, 1, 43, 3, 36, 0, 33, 3, 45, 32, "d", 45, 33, 3, 45, 2, "print", 1, 35, 35, 33, 1, 33, 2, 32, "d", 33, 1, 33, 3, 33, 42, 33, 6, 44, 4, 42, 1, 43, 3, 36, 0, 33, 3, 45, 32, "d", 45, 33, 4, 45, 2, "print", 1, 35, 35, 32, "d", 33, 1, 33, 3, 33, 42, 33, 6, 44, 4, 42, 1, 36, diff --git a/hogvm/__tests__/__snapshots__/stl.hoge b/hogvm/__tests__/__snapshots__/stl.hoge index d9e6ec9c41f51..3f842a7d4156f 100644 --- a/hogvm/__tests__/__snapshots__/stl.hoge +++ b/hogvm/__tests__/__snapshots__/stl.hoge @@ -1,26 +1,26 @@ -["_h", 32, "-- empty, notEmpty, length, lower, upper, reverse --", 2, "print", 1, 35, 32, "234", 2, "notEmpty", 1, 32, -"", 2, "empty", 1, 3, 2, 40, 9, 32, "123", 2, "length", 1, 2, "print", 1, 35, 32, "tdd4gh", 32, "Tdd4gh", 2, "lower", 1, -11, 40, 9, 32, "test", 2, "upper", 1, 2, "print", 1, 35, 32, "spinner", 2, "reverse", 1, 2, "print", 1, 35, 32, "", 2, -"print", 1, 35, 32, "-- encodeURLComponent, decodeURLComponent --", 2, "print", 1, 35, 32, "http://www.google.com", 2, -"encodeURLComponent", 1, 2, "print", 1, 35, 32, "tom & jerry", 2, "encodeURLComponent", 1, 2, "print", 1, 35, 32, -"http://www.google.com", 2, "encodeURLComponent", 1, 2, "decodeURLComponent", 1, 2, "print", 1, 35, 32, "tom & jerry", -2, "encodeURLComponent", 1, 2, "decodeURLComponent", 1, 2, "print", 1, 35, 32, "", 2, "print", 1, 35, 32, -"-- base64Encode, base64Decode --", 2, "print", 1, 35, 32, "http://www.google.com", 2, "base64Encode", 1, 2, "print", 1, -35, 32, "tom & jerry", 2, "base64Encode", 1, 2, "print", 1, 35, 32, "http://www.google.com", 2, "base64Encode", 1, 2, -"base64Decode", 1, 2, "print", 1, 35, 32, "tom & jerry", 2, "base64Encode", 1, 2, "base64Decode", 1, 2, "print", 1, 35, -32, "", 2, "print", 1, 35, 32, "-- empty --", 2, "print", 1, 35, 31, 2, "empty", 1, 2, "print", 1, 35, 33, 0, 2, -"empty", 1, 2, "print", 1, 35, 33, 1, 2, "empty", 1, 2, "print", 1, 35, 33, -1, 2, "empty", 1, 2, "print", 1, 35, 34, -0.0, 2, "empty", 1, 2, "print", 1, 35, 34, 0.01, 2, "empty", 1, 2, "print", 1, 35, 32, "", 2, "empty", 1, 2, "print", 1, -35, 32, "string", 2, "empty", 1, 2, "print", 1, 35, 32, "0", 2, "empty", 1, 2, "print", 1, 35, 43, 0, 2, "empty", 1, 2, -"print", 1, 35, 42, 0, 2, "empty", 1, 2, "print", 1, 35, 2, "tuple", 0, 2, "empty", 1, 2, "print", 1, 35, 33, 0, 2, -"tuple", 1, 2, "empty", 1, 2, "print", 1, 35, 33, 2, 33, 1, 2, "tuple", 2, 2, "empty", 1, 2, "print", 1, 35, 32, "", 2, -"print", 1, 35, 32, "-- notEmpty --", 2, "print", 1, 35, 31, 2, "notEmpty", 1, 2, "print", 1, 35, 33, 0, 2, "notEmpty", -1, 2, "print", 1, 35, 33, 1, 2, "notEmpty", 1, 2, "print", 1, 35, 33, -1, 2, "notEmpty", 1, 2, "print", 1, 35, 34, 0.0, -2, "notEmpty", 1, 2, "print", 1, 35, 34, 0.01, 2, "notEmpty", 1, 2, "print", 1, 35, 32, "", 2, "notEmpty", 1, 2, -"print", 1, 35, 32, "string", 2, "notEmpty", 1, 2, "print", 1, 35, 32, "0", 2, "notEmpty", 1, 2, "print", 1, 35, 43, 0, -2, "notEmpty", 1, 2, "print", 1, 35, 42, 0, 2, "notEmpty", 1, 2, "print", 1, 35, 2, "tuple", 0, 2, "notEmpty", 1, 2, -"print", 1, 35, 33, 0, 2, "tuple", 1, 2, "notEmpty", 1, 2, "print", 1, 35, 33, 2, 33, 1, 2, "tuple", 2, 2, "notEmpty", -1, 2, "print", 1, 35, 32, "", 2, "print", 1, 35, 32, "-- replaceAll, replaceOne --", 2, "print", 1, 35, 32, "L", 32, -"l", 32, "hello world", 2, "replaceAll", 3, 2, "print", 1, 35, 32, "L", 32, "l", 32, "hello world", 2, "replaceOne", 3, -2, "print", 1, 35, 32, "", 2, "print", 1, 35, 32, "-- generateUUIDv4 --", 2, "print", 1, 35, 2, "generateUUIDv4", 0, 2, -"length", 1, 2, "print", 1, 35] +["_H", 1, 32, "-- empty, notEmpty, length, lower, upper, reverse --", 2, "print", 1, 35, 32, "", 2, "empty", 1, 32, +"234", 2, "notEmpty", 1, 3, 2, 40, 9, 32, "123", 2, "length", 1, 2, "print", 1, 35, 32, "tdd4gh", 32, "Tdd4gh", 2, +"lower", 1, 11, 40, 9, 32, "test", 2, "upper", 1, 2, "print", 1, 35, 32, "spinner", 2, "reverse", 1, 2, "print", 1, 35, +32, "", 2, "print", 1, 35, 32, "-- encodeURLComponent, decodeURLComponent --", 2, "print", 1, 35, 32, +"http://www.google.com", 2, "encodeURLComponent", 1, 2, "print", 1, 35, 32, "tom & jerry", 2, "encodeURLComponent", 1, +2, "print", 1, 35, 32, "http://www.google.com", 2, "encodeURLComponent", 1, 2, "decodeURLComponent", 1, 2, "print", 1, +35, 32, "tom & jerry", 2, "encodeURLComponent", 1, 2, "decodeURLComponent", 1, 2, "print", 1, 35, 32, "", 2, "print", 1, +35, 32, "-- base64Encode, base64Decode --", 2, "print", 1, 35, 32, "http://www.google.com", 2, "base64Encode", 1, 2, +"print", 1, 35, 32, "tom & jerry", 2, "base64Encode", 1, 2, "print", 1, 35, 32, "http://www.google.com", 2, +"base64Encode", 1, 2, "base64Decode", 1, 2, "print", 1, 35, 32, "tom & jerry", 2, "base64Encode", 1, 2, "base64Decode", +1, 2, "print", 1, 35, 32, "", 2, "print", 1, 35, 32, "-- empty --", 2, "print", 1, 35, 31, 2, "empty", 1, 2, "print", 1, +35, 33, 0, 2, "empty", 1, 2, "print", 1, 35, 33, 1, 2, "empty", 1, 2, "print", 1, 35, 33, -1, 2, "empty", 1, 2, "print", +1, 35, 34, 0.0, 2, "empty", 1, 2, "print", 1, 35, 34, 0.01, 2, "empty", 1, 2, "print", 1, 35, 32, "", 2, "empty", 1, 2, +"print", 1, 35, 32, "string", 2, "empty", 1, 2, "print", 1, 35, 32, "0", 2, "empty", 1, 2, "print", 1, 35, 43, 0, 2, +"empty", 1, 2, "print", 1, 35, 42, 0, 2, "empty", 1, 2, "print", 1, 35, 2, "tuple", 0, 2, "empty", 1, 2, "print", 1, 35, +33, 0, 2, "tuple", 1, 2, "empty", 1, 2, "print", 1, 35, 33, 1, 33, 2, 2, "tuple", 2, 2, "empty", 1, 2, "print", 1, 35, +32, "", 2, "print", 1, 35, 32, "-- notEmpty --", 2, "print", 1, 35, 31, 2, "notEmpty", 1, 2, "print", 1, 35, 33, 0, 2, +"notEmpty", 1, 2, "print", 1, 35, 33, 1, 2, "notEmpty", 1, 2, "print", 1, 35, 33, -1, 2, "notEmpty", 1, 2, "print", 1, +35, 34, 0.0, 2, "notEmpty", 1, 2, "print", 1, 35, 34, 0.01, 2, "notEmpty", 1, 2, "print", 1, 35, 32, "", 2, "notEmpty", +1, 2, "print", 1, 35, 32, "string", 2, "notEmpty", 1, 2, "print", 1, 35, 32, "0", 2, "notEmpty", 1, 2, "print", 1, 35, +43, 0, 2, "notEmpty", 1, 2, "print", 1, 35, 42, 0, 2, "notEmpty", 1, 2, "print", 1, 35, 2, "tuple", 0, 2, "notEmpty", 1, +2, "print", 1, 35, 33, 0, 2, "tuple", 1, 2, "notEmpty", 1, 2, "print", 1, 35, 33, 1, 33, 2, 2, "tuple", 2, 2, +"notEmpty", 1, 2, "print", 1, 35, 32, "", 2, "print", 1, 35, 32, "-- replaceAll, replaceOne --", 2, "print", 1, 35, 32, +"hello world", 32, "l", 32, "L", 2, "replaceAll", 3, 2, "print", 1, 35, 32, "hello world", 32, "l", 32, "L", 2, +"replaceOne", 3, 2, "print", 1, 35, 32, "", 2, "print", 1, 35, 32, "-- generateUUIDv4 --", 2, "print", 1, 35, 2, +"generateUUIDv4", 0, 2, "length", 1, 2, "print", 1, 35] diff --git a/hogvm/__tests__/__snapshots__/strings.hoge b/hogvm/__tests__/__snapshots__/strings.hoge index 11abe250f3a09..0c3118d3a043e 100644 --- a/hogvm/__tests__/__snapshots__/strings.hoge +++ b/hogvm/__tests__/__snapshots__/strings.hoge @@ -1,11 +1,11 @@ -["_h", 32, " hello world ", 2, "trim", 1, 2, "print", 1, 35, 32, " hello world ", 2, "trimLeft", 1, 2, "print", 1, -35, 32, " hello world ", 2, "trimRight", 1, 2, "print", 1, 35, 32, "x", 32, "xxxx hello world xx", 2, "trim", 2, 2, -"print", 1, 35, 32, "x", 32, "xxxx hello world xx", 2, "trimLeft", 2, 2, "print", 1, 35, 32, "x", 32, -"xxxx hello world xx", 2, "trimRight", 2, 2, "print", 1, 35, 32, "hello world and more", 32, " ", 2, "splitByString", -2, 2, "print", 1, 35, 33, 1, 32, "hello world and more", 32, " ", 2, "splitByString", 3, 2, "print", 1, 35, 33, 2, 32, -"hello world and more", 32, " ", 2, "splitByString", 3, 2, "print", 1, 35, 33, 10, 32, "hello world and more", 32, " ", -2, "splitByString", 3, 2, "print", 1, 35, 32, "N", 32, "banana", 2, "like", 2, 2, "print", 1, 35, 32, "n", 32, "banana", -2, "like", 2, 2, "print", 1, 35, 32, "naan", 32, "banana", 2, "like", 2, 2, "print", 1, 35, 32, "N", 32, "banana", 2, -"ilike", 2, 2, "print", 1, 35, 32, "n", 32, "banana", 2, "ilike", 2, 2, "print", 1, 35, 32, "naan", 32, "banana", 2, -"ilike", 2, 2, "print", 1, 35, 32, "N", 32, "banana", 2, "notLike", 2, 2, "print", 1, 35, 32, "NO", 32, "banana", 2, -"notILike", 2, 2, "print", 1, 35] +["_H", 1, 32, " hello world ", 2, "trim", 1, 2, "print", 1, 35, 32, " hello world ", 2, "trimLeft", 1, 2, "print", +1, 35, 32, " hello world ", 2, "trimRight", 1, 2, "print", 1, 35, 32, "xxxx hello world xx", 32, "x", 2, "trim", 2, +2, "print", 1, 35, 32, "xxxx hello world xx", 32, "x", 2, "trimLeft", 2, 2, "print", 1, 35, 32, +"xxxx hello world xx", 32, "x", 2, "trimRight", 2, 2, "print", 1, 35, 32, " ", 32, "hello world and more", 2, +"splitByString", 2, 2, "print", 1, 35, 32, " ", 32, "hello world and more", 33, 1, 2, "splitByString", 3, 2, "print", 1, +35, 32, " ", 32, "hello world and more", 33, 2, 2, "splitByString", 3, 2, "print", 1, 35, 32, " ", 32, +"hello world and more", 33, 10, 2, "splitByString", 3, 2, "print", 1, 35, 32, "banana", 32, "N", 2, "like", 2, 2, +"print", 1, 35, 32, "banana", 32, "n", 2, "like", 2, 2, "print", 1, 35, 32, "banana", 32, "naan", 2, "like", 2, 2, +"print", 1, 35, 32, "banana", 32, "N", 2, "ilike", 2, 2, "print", 1, 35, 32, "banana", 32, "n", 2, "ilike", 2, 2, +"print", 1, 35, 32, "banana", 32, "naan", 2, "ilike", 2, 2, "print", 1, 35, 32, "banana", 32, "N", 2, "notLike", 2, 2, +"print", 1, 35, 32, "banana", 32, "NO", 2, "notILike", 2, 2, "print", 1, 35] diff --git a/hogvm/__tests__/__snapshots__/tuples.hoge b/hogvm/__tests__/__snapshots__/tuples.hoge index 027d8ad266374..eb8c97ec6bf03 100644 --- a/hogvm/__tests__/__snapshots__/tuples.hoge +++ b/hogvm/__tests__/__snapshots__/tuples.hoge @@ -1,5 +1,5 @@ -["_h", 2, "tuple", 0, 2, "print", 1, 35, 33, 1, 44, 1, 2, "print", 1, 35, 33, 1, 33, 2, 44, 2, 2, "print", 1, 35, 33, 1, -33, 2, 44, 2, 2, "print", 1, 35, 33, 1, 33, 2, 33, 3, 44, 3, 2, "print", 1, 35, 33, 1, 32, "2", 33, 3, 44, 3, 2, +["_H", 1, 2, "tuple", 0, 2, "print", 1, 35, 33, 1, 44, 1, 2, "print", 1, 35, 33, 1, 33, 2, 44, 2, 2, "print", 1, 35, 33, +1, 33, 2, 44, 2, 2, "print", 1, 35, 33, 1, 33, 2, 33, 3, 44, 3, 2, "print", 1, 35, 33, 1, 32, "2", 33, 3, 44, 3, 2, "print", 1, 35, 33, 1, 33, 2, 33, 3, 44, 2, 33, 4, 44, 3, 2, "print", 1, 35, 33, 1, 33, 2, 33, 3, 33, 4, 44, 2, 44, 2, 33, 5, 44, 3, 2, "print", 1, 35, 33, 1, 33, 2, 33, 3, 44, 3, 36, 0, 33, 2, 45, 2, "print", 1, 35, 36, 0, 33, 2, 48, 2, "print", 1, 35, 36, 0, 33, 8, 48, 2, "print", 1, 35, 33, 1, 33, 2, 33, 3, 33, 4, 44, 2, 44, 2, 33, 5, 44, 3, 33, 2, 45, diff --git a/hogvm/__tests__/__snapshots__/variables.hoge b/hogvm/__tests__/__snapshots__/variables.hoge index b3f91623a1b0d..91f17e1f63b04 100644 --- a/hogvm/__tests__/__snapshots__/variables.hoge +++ b/hogvm/__tests__/__snapshots__/variables.hoge @@ -1,3 +1,3 @@ -["_h", 32, "-- test variables --", 2, "print", 1, 35, 33, 2, 33, 1, 6, 36, 0, 2, "print", 1, 35, 33, 4, 36, 0, 6, 36, 1, -2, "print", 1, 35, 35, 35, 32, "-- test variable reassignment --", 2, "print", 1, 35, 33, 1, 33, 3, 36, 0, 6, 37, 0, 33, -2, 36, 0, 8, 37, 0, 36, 0, 2, "print", 1, 35, 35] +["_H", 1, 32, "-- test variables --", 2, "print", 1, 35, 33, 2, 33, 1, 6, 36, 0, 2, "print", 1, 35, 33, 4, 36, 0, 6, 36, +1, 2, "print", 1, 35, 35, 35, 32, "-- test variable reassignment --", 2, "print", 1, 35, 33, 1, 33, 3, 36, 0, 6, 37, 0, +33, 2, 36, 0, 8, 37, 0, 36, 0, 2, "print", 1, 35, 35] diff --git a/hogvm/__tests__/dicts.hog b/hogvm/__tests__/dicts.hog index ccd081190b0da..8523c26cb5f8d 100644 --- a/hogvm/__tests__/dicts.hog +++ b/hogvm/__tests__/dicts.hog @@ -2,7 +2,6 @@ print({}) print({'key': 'value'}) print({'key': 'value', 'other': 'thing'}) print({'key': {'otherKey': 'value'}}) -print({key: 'value'}) let key := 3 print({key: 'value'}) diff --git a/hogvm/__tests__/loops.hog b/hogvm/__tests__/loops.hog index 369baf58a2339..f43fe7fcc1c39 100644 --- a/hogvm/__tests__/loops.hog +++ b/hogvm/__tests__/loops.hog @@ -11,9 +11,8 @@ print('-- test while loop --') print('-- test for loop --') { for (let i := 0; i < 3; i := i + 1) { - print(i) -- prints 3 times + print(i) // prints 3 times } - print(i) -- global does not print } print('-- test emptier for loop --') diff --git a/hogvm/__tests__/mandelbrot.hog b/hogvm/__tests__/mandelbrot.hog index 6ac17b2989d57..144ddf701ab87 100644 --- a/hogvm/__tests__/mandelbrot.hog +++ b/hogvm/__tests__/mandelbrot.hog @@ -41,4 +41,4 @@ fn main() { } } -main() \ No newline at end of file +main() diff --git a/hogvm/__tests__/operations.hog b/hogvm/__tests__/operations.hog index 25eca892ab190..8445bf17cee67 100644 --- a/hogvm/__tests__/operations.hog +++ b/hogvm/__tests__/operations.hog @@ -3,68 +3,64 @@ fn test(val) { } print('-- test the most common expressions --') -test(1 + 2) -- 3 -test(1 - 2) -- -1 -test(3 * 2) -- 6 -test(3 / 2) -- 1.5 -test(3 % 2) -- 1 -test(1 and 2) -- true -test(1 or 0) -- true -test(1 and 0) -- false -test(1 or (0 and 1) or 2) -- true -test((1 and 0) and 1) -- false -test((1 or 2) and (1 or 2)) -- true -test(true) -- true -test(not true) -- false -test(false) -- false -test(null) -- null -test(3.14) -- 3.14 -test(1 = 2) -- false -test(1 == 2) -- false -test(1 != 2) -- true -test(1 < 2) -- true -test(1 <= 2) -- true -test(1 > 2) -- false -test(1 >= 2) -- false -test('a' like 'b') -- false -test('baa' like '%a%') -- true -test('baa' like '%x%') -- false -test('baa' ilike '%A%') -- true -test('baa' ilike '%C%') -- false -test('a' ilike 'b') -- false -test('a' not like 'b') -- true -test('a' not ilike 'b') -- true -test('a' in 'car') -- true -test('a' in 'foo') -- false -test('a' not in 'car') -- false -test(properties.bla) -- null -test(properties.foo) -- "bar" -test(ifNull(properties.foo, false)) -- "bar" -test(ifNull(properties.nullValue, false)) -- false -test(concat('arg', 'another')) -- 'arganother' -test(concat(1, NULL)) -- '1' -test(concat(true, false)) -- 'truefalse' -test(match('test', 'e.*')) -- true -test(match('test', '^e.*')) -- false -test(match('test', 'x.*')) -- false -test('test' =~ 'e.*') -- true -test('test' !~ 'e.*') -- false -test('test' =~ '^e.*') -- false -test('test' !~ '^e.*') -- true -test('test' =~ 'x.*') -- false -test('test' !~ 'x.*') -- true -test('test' ~* 'EST') -- true -test('test' =~* 'EST') -- true -test('test' !~* 'EST') -- false -test(toString(1)) -- '1' -test(toString(1.5)) -- '1.5' -test(toString(true)) -- 'true' -test(toString(null)) -- 'null' -test(toString('string')) -- 'string' -test(toInt('1')) -- 1 -test(toInt('bla')) -- null -test(toFloat('1.2')) -- 1.2 -test(toFloat('bla')) -- null -test(toUUID('asd')) -- 'asd' -test(1 == null) -- false -test(1 != null) -- true +test(1 + 2) // 3 +test(1 - 2) // -1 +test(3 * 2) // 6 +test(3 / 2) // 1.5 +test(3 % 2) // 1 +test(1 and 2) // true +test(1 or 0) // true +test(1 and 0) // false +test(1 or (0 and 1) or 2) // true +test((1 and 0) and 1) // false +test((1 or 2) and (1 or 2)) // true +test(true) // true +test(not true) // false +test(false) // false +test(null) // null +test(3.14) // 3.14 +test(1 = 2) // false +test(1 == 2) // false +test(1 != 2) // true +test(1 < 2) // true +test(1 <= 2) // true +test(1 > 2) // false +test(1 >= 2) // false +test('a' like 'b') // false +test('baa' like '%a%') // true +test('baa' like '%x%') // false +test('baa' ilike '%A%') // true +test('baa' ilike '%C%') // false +test('a' ilike 'b') // false +test('a' not like 'b') // true +test('a' not ilike 'b') // true +test('a' in 'car') // true +test('a' in 'foo') // false +test('a' not in 'car') // false +test(concat('arg', 'another')) // 'arganother' +test(concat(1, NULL)) // '1' +test(concat(true, false)) // 'truefalse' +test(match('test', 'e.*')) // true +test(match('test', '^e.*')) // false +test(match('test', 'x.*')) // false +test('test' =~ 'e.*') // true +test('test' !~ 'e.*') // false +test('test' =~ '^e.*') // false +test('test' !~ '^e.*') // true +test('test' =~ 'x.*') // false +test('test' !~ 'x.*') // true +test('test' ~* 'EST') // true +test('test' =~* 'EST') // true +test('test' !~* 'EST') // false +test(toString(1)) // '1' +test(toString(1.5)) // '1.5' +test(toString(true)) // 'true' +test(toString(null)) // 'null' +test(toString('string')) // 'string' +test(toInt('1')) // 1 +test(toInt('bla')) // null +test(toFloat('1.2')) // 1.2 +test(toFloat('bla')) // null +test(toUUID('asd')) // 'asd' +test(1 == null) // false +test(1 != null) // true diff --git a/hogvm/python/debugger.py b/hogvm/python/debugger.py index 270c1a5233c01..10d4355e8c1c4 100644 --- a/hogvm/python/debugger.py +++ b/hogvm/python/debugger.py @@ -163,8 +163,8 @@ def print_symbol(symbol: Operation, ip: int, bytecode: list, stack: list, call_s ) case Operation.DECLARE_FN: return f"DECLARE_FN({bytecode[ip+1]}, args={bytecode[ip+2]}, ops={bytecode[ip+3]})" - case Operation.CALL: - return f"CALL({bytecode[ip+1]} {', '.join(str(stack[-i]) for i in range(bytecode[ip+2]))})" + case Operation.CALL_GLOBAL: + return f"CALL_GLOBAL({bytecode[ip+1]} {', '.join(str(stack[-(bytecode[ip+2] - i)]) for i in range(bytecode[ip+2]))})" case Operation.TRY: return f"TRY(+{bytecode[ip+1]})" case Operation.POP_TRY: @@ -177,8 +177,8 @@ def print_symbol(symbol: Operation, ip: int, bytecode: list, stack: list, call_s def color_bytecode(bytecode: list) -> list: - colored = ["op.START"] - ip = 1 + colored = ["op.START", f"version: {bytecode[1]}"] if bytecode[0] == "_H" else ["op.START"] + ip = len(colored) while ip < len(bytecode): symbol = bytecode[ip] match symbol: @@ -274,8 +274,8 @@ def color_bytecode(bytecode: list) -> list: add = ["op.JUMP_IF_STACK_NOT_NULL", f"offset: {'+' if bytecode[ip+1] >= 0 else ''}{bytecode[ip+1]}"] case Operation.DECLARE_FN: add = ["op.DECLARE_FN", f"name: {bytecode[ip+1]}", f"args: {bytecode[ip+2]}", f"ops: {bytecode[ip+3]}"] - case Operation.CALL: - add = ["op.CALL", f"name: {bytecode[ip+1]}", f"args: {bytecode[ip+2]}"] + case Operation.CALL_GLOBAL: + add = ["op.CALL_GLOBAL", f"name: {bytecode[ip+1]}", f"args: {bytecode[ip+2]}"] case Operation.TRY: add = ["op.TRY", f"catch: +{bytecode[ip+1]}"] case Operation.POP_TRY: diff --git a/hogvm/python/execute.py b/hogvm/python/execute.py index c137868d026e5..1f0a47e1bd1d9 100644 --- a/hogvm/python/execute.py +++ b/hogvm/python/execute.py @@ -7,7 +7,7 @@ from hogvm.python.debugger import debugger, color_bytecode from hogvm.python.objects import is_hog_error -from hogvm.python.operation import Operation, HOGQL_BYTECODE_IDENTIFIER +from hogvm.python.operation import Operation, HOGQL_BYTECODE_IDENTIFIER, HOGQL_BYTECODE_IDENTIFIER_V0 from hogvm.python.stl import STL from dataclasses import dataclass @@ -41,6 +41,9 @@ def execute_bytecode( team: Optional["Team"] = None, debug=False, ) -> BytecodeResult: + if len(bytecode) == 0 or (bytecode[0] not in (HOGQL_BYTECODE_IDENTIFIER, HOGQL_BYTECODE_IDENTIFIER_V0)): + raise HogVMException(f"Invalid bytecode. Must start with '{HOGQL_BYTECODE_IDENTIFIER}'") + version = bytecode[1] if len(bytecode) >= 2 and bytecode[0] == HOGQL_BYTECODE_IDENTIFIER else 0 result = None start_time = time.time() last_op = len(bytecode) - 1 @@ -51,13 +54,19 @@ def execute_bytecode( declared_functions: dict[str, tuple[int, int]] = {} mem_used = 0 max_mem_used = 0 - ip = -1 + ip = 1 if version > 0 else 0 ops = 0 stdout: list[str] = [] colored_bytecode = color_bytecode(bytecode) if debug else [] if isinstance(timeout, int): timeout = timedelta(seconds=timeout) + def stack_keep_first_elements(count: int): + nonlocal stack, mem_stack, mem_used + stack = stack[0:count] + mem_used -= sum(mem_stack[count:]) + mem_stack = mem_stack[0:count] + def next_token(): nonlocal ip ip += 1 @@ -82,10 +91,7 @@ def push_stack(value): if mem_used > MAX_MEMORY: raise HogVMException(f"Memory limit of {MAX_MEMORY} bytes exceeded. Tried to allocate {mem_used} bytes.") - if next_token() != HOGQL_BYTECODE_IDENTIFIER: - raise HogVMException(f"Invalid bytecode. Must start with '{HOGQL_BYTECODE_IDENTIFIER}'") - - if len(bytecode) == 1: + if len(bytecode) <= 2: return BytecodeResult(result=None, stdout=stdout, bytecode=bytecode) def check_timeout(): @@ -170,16 +176,17 @@ def check_timeout(): push_stack(not bool(re.search(re.compile(args[1], re.RegexFlag.IGNORECASE), args[0]))) case Operation.GET_GLOBAL: chain = [pop_stack() for _ in range(next_token())] - push_stack(deepcopy(get_nested_value(globals, chain))) + if globals and chain[0] in globals: + push_stack(deepcopy(get_nested_value(globals, chain))) + else: + raise HogVMException(f"Global variable not found: {chain[0]}") case Operation.POP: pop_stack() case Operation.RETURN: if call_stack: ip, stack_start, arg_len = call_stack.pop() response = pop_stack() - stack = stack[0:stack_start] - mem_used -= sum(mem_stack[stack_start:]) - mem_stack = mem_stack[0:stack_start] + stack_keep_first_elements(stack_start) push_stack(response) else: return BytecodeResult(result=pop_stack(), stdout=stdout, bytecode=bytecode) @@ -252,7 +259,7 @@ def check_timeout(): body_len = next_token() declared_functions[name] = (ip, arg_len) ip += body_len - case Operation.CALL: + case Operation.CALL_GLOBAL: check_timeout() name = next_token() if name in declared_functions: @@ -260,16 +267,17 @@ def check_timeout(): call_stack.append((ip + 1, len(stack) - arg_len, arg_len)) ip = func_ip else: - args = [pop_stack() for _ in range(next_token())] + arg_count = next_token() + args = [pop_stack() for _ in range(arg_count)] + if version > 0: + args = list(reversed(args)) if functions is not None and name in functions: push_stack(functions[name](*args)) - continue - - if name not in STL: + elif name in STL: + push_stack(STL[name](args, team, stdout, timeout.total_seconds())) + else: raise HogVMException(f"Unsupported function call: {name}") - - push_stack(STL[name](args, team, stdout, timeout.total_seconds())) case Operation.TRY: throw_stack.append((len(call_stack), len(stack), ip + next_token())) case Operation.POP_TRY: @@ -283,9 +291,7 @@ def check_timeout(): raise HogVMException("Can not throw: value is not of type Error") if throw_stack: call_stack_len, stack_len, catch_ip = throw_stack.pop() - stack = stack[0:stack_len] - mem_used -= sum(mem_stack[stack_len:]) - mem_stack = mem_stack[0:stack_len] + stack_keep_first_elements(stack_len) call_stack = call_stack[0:call_stack_len] push_stack(exception) ip = catch_ip diff --git a/hogvm/python/operation.py b/hogvm/python/operation.py index 319a450fc37b1..0feb79ebfac2e 100644 --- a/hogvm/python/operation.py +++ b/hogvm/python/operation.py @@ -1,12 +1,18 @@ from enum import Enum -HOGQL_BYTECODE_IDENTIFIER = "_h" +HOGQL_BYTECODE_IDENTIFIER_V0 = "_h" +HOGQL_BYTECODE_IDENTIFIER = "_H" HOGQL_BYTECODE_FUNCTION = "_f" +# Version history: +# 0 - initial version +# 1 - added version numbers; reversed order of function args in stack +HOGQL_BYTECODE_VERSION = 1 + class Operation(int, Enum): GET_GLOBAL = 1 - CALL = 2 + CALL_GLOBAL = 2 AND = 3 OR = 4 NOT = 5 diff --git a/hogvm/python/test/test_execute.py b/hogvm/python/test/test_execute.py index b5c1a3d8ee2ae..7289a1b585eff 100644 --- a/hogvm/python/test/test_execute.py +++ b/hogvm/python/test/test_execute.py @@ -4,7 +4,7 @@ from hogvm.python.execute import execute_bytecode, get_nested_value -from hogvm.python.operation import Operation as op, HOGQL_BYTECODE_IDENTIFIER as _H +from hogvm.python.operation import Operation as op, HOGQL_BYTECODE_IDENTIFIER as _H, HOGQL_BYTECODE_VERSION as VERSION from hogvm.python.utils import UncaughtHogVMException from posthog.hogql.bytecode import create_bytecode from posthog.hogql.parser import parse_expr, parse_program @@ -115,21 +115,21 @@ def test_nested_value(self): def test_errors(self): try: - execute_bytecode([_H, op.TRUE, op.CALL, "notAFunction", 1], {}) + execute_bytecode([_H, VERSION, op.TRUE, op.CALL_GLOBAL, "notAFunction", 1], {}) except Exception as e: assert str(e) == "Unsupported function call: notAFunction" else: raise AssertionError("Expected Exception not raised") try: - execute_bytecode([_H, op.CALL, "notAFunction", 1], {}) + execute_bytecode([_H, VERSION, op.CALL_GLOBAL, "notAFunction", 1], {}) except Exception as e: assert str(e) == "Stack underflow" else: raise AssertionError("Expected Exception not raised") try: - execute_bytecode([_H, op.TRUE, op.TRUE, op.NOT], {}) + execute_bytecode([_H, VERSION, op.TRUE, op.TRUE, op.NOT], {}) except Exception as e: assert str(e) == "Invalid bytecode. More than one value left on stack" else: @@ -182,10 +182,6 @@ def test_memory_limits_1(self): raise AssertionError("Expected Exception not raised") def test_memory_limits_2(self): - # let string := 'banana' - # for (let i := 0; i < 100; i := i + 1) { - # string := string || string - # } bytecode = [ "_h", 32, @@ -281,27 +277,40 @@ def stringify(*args): return "zero" functions = {"stringify": stringify} - assert execute_bytecode([_H, op.INTEGER, 1, op.CALL, "stringify", 1, op.RETURN], {}, functions).result == "one" - assert execute_bytecode([_H, op.INTEGER, 2, op.CALL, "stringify", 1, op.RETURN], {}, functions).result == "two" assert ( - execute_bytecode([_H, op.STRING, "2", op.CALL, "stringify", 1, op.RETURN], {}, functions).result == "zero" + execute_bytecode( + [_H, VERSION, op.INTEGER, 1, op.CALL_GLOBAL, "stringify", 1, op.RETURN], {}, functions + ).result + == "one" + ) + assert ( + execute_bytecode( + [_H, VERSION, op.INTEGER, 2, op.CALL_GLOBAL, "stringify", 1, op.RETURN], {}, functions + ).result + == "two" + ) + assert ( + execute_bytecode( + [_H, VERSION, op.STRING, "2", op.CALL_GLOBAL, "stringify", 1, op.RETURN], {}, functions + ).result + == "zero" + ) + + def test_version_0_and_1(self): + # version 0 of HogQL bytecode had arguments in a different order + assert ( + execute_bytecode(["_h", op.STRING, "1", op.STRING, "2", op.CALL_GLOBAL, "concat", 2, op.RETURN]).result + == "21" + ) + assert ( + execute_bytecode(["_H", 1, op.STRING, "1", op.STRING, "2", op.CALL_GLOBAL, "concat", 2, op.RETURN]).result + == "12" ) def test_bytecode_variable_assignment(self): program = parse_program("let a := 1 + 2; return a;") bytecode = create_bytecode(program) - assert bytecode == [ - _H, - op.INTEGER, - 2, - op.INTEGER, - 1, - op.PLUS, - op.GET_LOCAL, - 0, - op.RETURN, - op.POP, - ] + assert bytecode == ["_H", 1, op.INTEGER, 2, op.INTEGER, 1, op.PLUS, op.GET_LOCAL, 0, op.RETURN, op.POP] assert self._run_program("let a := 1 + 2; return a;") == 3 assert ( @@ -319,7 +328,8 @@ def test_bytecode_if_else(self): program = parse_program("if (true) return 1; else return 2;") bytecode = create_bytecode(program) assert bytecode == [ - _H, + "_H", + 1, op.TRUE, op.JUMP_IF_FALSE, 5, @@ -371,7 +381,8 @@ def test_bytecode_while(self): program = parse_program("while (true) 1 + 1;") bytecode = create_bytecode(program) assert bytecode == [ - _H, + "_H", + 1, op.TRUE, op.JUMP_IF_FALSE, 8, @@ -388,10 +399,11 @@ def test_bytecode_while(self): program = parse_program("while (toString('a')) { 1 + 1; } return 3;") bytecode = create_bytecode(program) assert bytecode == [ - _H, + "_H", + 1, op.STRING, "a", - op.CALL, + op.CALL_GLOBAL, "toString", 1, op.JUMP_IF_FALSE, @@ -466,7 +478,7 @@ def test_bytecode_for(self): print(i) -- prints 3 times j := j + 2 } - print(i) -- global does not print + // print(i) -- global does not print return j """ ) @@ -484,22 +496,23 @@ def test_bytecode_functions(self): ) bytecode = create_bytecode(program) assert bytecode == [ - _H, + "_H", + 1, op.DECLARE_FN, "add", 2, 6, op.GET_LOCAL, - 0, - op.GET_LOCAL, 1, + op.GET_LOCAL, + 0, op.PLUS, op.RETURN, op.INTEGER, - 4, - op.INTEGER, 3, - op.CALL, + op.INTEGER, + 4, + op.CALL_GLOBAL, "add", 2, op.RETURN, @@ -620,7 +633,12 @@ def test_bytecode_dicts(self): assert self._run_program("return {'key': 'value'};") == {"key": "value"} assert self._run_program("return {'key': 'value', 'other': 'thing'};") == {"key": "value", "other": "thing"} assert self._run_program("return {'key': {'otherKey': 'value'}};") == {"key": {"otherKey": "value"}} - assert self._run_program("return {key: 'value'};") == {None: "value"} + try: + self._run_program("return {key: 'value'};") + except Exception as e: + assert str(e) == "Global variable not found: key" + else: + raise AssertionError("Expected Exception not raised") assert self._run_program("let key := 3; return {key: 'value'};") == {3: "value"} assert self._run_program("return {'key': 'value'}.key;") == "value" diff --git a/hogvm/typescript/src/__tests__/execute.test.ts b/hogvm/typescript/src/__tests__/execute.test.ts index 494f6da0753c7..867e5cf9a9c03 100644 --- a/hogvm/typescript/src/__tests__/execute.test.ts +++ b/hogvm/typescript/src/__tests__/execute.test.ts @@ -63,24 +63,24 @@ describe('hogvm execute', () => { expect(execSync(['_h', op.STRING, 'AL', op.STRING, 'kala', op.NOT_IREGEX], options)).toBe(false) expect(execSync(['_h', op.STRING, 'bla', op.STRING, 'properties', op.GET_GLOBAL, 2], options)).toBe(null) expect(execSync(['_h', op.STRING, 'foo', op.STRING, 'properties', op.GET_GLOBAL, 2], options)).toBe('bar') - expect(execSync(['_h', op.STRING, 'another', op.STRING, 'arg', op.CALL, 'concat', 2], options)).toBe( + expect(execSync(['_h', op.STRING, 'another', op.STRING, 'arg', op.CALL_GLOBAL, 'concat', 2], options)).toBe( 'arganother' ) - expect(execSync(['_h', op.NULL, op.INTEGER, 1, op.CALL, 'concat', 2], options)).toBe('1') - expect(execSync(['_h', op.FALSE, op.TRUE, op.CALL, 'concat', 2], options)).toBe('truefalse') - expect(execSync(['_h', op.STRING, 'e.*', op.STRING, 'test', op.CALL, 'match', 2], options)).toBe(true) - expect(execSync(['_h', op.STRING, '^e.*', op.STRING, 'test', op.CALL, 'match', 2], options)).toBe(false) - expect(execSync(['_h', op.STRING, 'x.*', op.STRING, 'test', op.CALL, 'match', 2], options)).toBe(false) - expect(execSync(['_h', op.INTEGER, 1, op.CALL, 'toString', 1], options)).toBe('1') - expect(execSync(['_h', op.FLOAT, 1.5, op.CALL, 'toString', 1], options)).toBe('1.5') - expect(execSync(['_h', op.TRUE, op.CALL, 'toString', 1], options)).toBe('true') - expect(execSync(['_h', op.NULL, op.CALL, 'toString', 1], options)).toBe('null') - expect(execSync(['_h', op.STRING, 'string', op.CALL, 'toString', 1], options)).toBe('string') - expect(execSync(['_h', op.STRING, '1', op.CALL, 'toInt', 1], options)).toBe(1) - expect(execSync(['_h', op.STRING, 'bla', op.CALL, 'toInt', 1], options)).toBe(null) - expect(execSync(['_h', op.STRING, '1.2', op.CALL, 'toFloat', 1], options)).toBe(1.2) - expect(execSync(['_h', op.STRING, 'bla', op.CALL, 'toFloat', 1], options)).toBe(null) - expect(execSync(['_h', op.STRING, 'asd', op.CALL, 'toUUID', 1], options)).toBe('asd') + expect(execSync(['_h', op.NULL, op.INTEGER, 1, op.CALL_GLOBAL, 'concat', 2], options)).toBe('1') + expect(execSync(['_h', op.FALSE, op.TRUE, op.CALL_GLOBAL, 'concat', 2], options)).toBe('truefalse') + expect(execSync(['_h', op.STRING, 'e.*', op.STRING, 'test', op.CALL_GLOBAL, 'match', 2], options)).toBe(true) + expect(execSync(['_h', op.STRING, '^e.*', op.STRING, 'test', op.CALL_GLOBAL, 'match', 2], options)).toBe(false) + expect(execSync(['_h', op.STRING, 'x.*', op.STRING, 'test', op.CALL_GLOBAL, 'match', 2], options)).toBe(false) + expect(execSync(['_h', op.INTEGER, 1, op.CALL_GLOBAL, 'toString', 1], options)).toBe('1') + expect(execSync(['_h', op.FLOAT, 1.5, op.CALL_GLOBAL, 'toString', 1], options)).toBe('1.5') + expect(execSync(['_h', op.TRUE, op.CALL_GLOBAL, 'toString', 1], options)).toBe('true') + expect(execSync(['_h', op.NULL, op.CALL_GLOBAL, 'toString', 1], options)).toBe('null') + expect(execSync(['_h', op.STRING, 'string', op.CALL_GLOBAL, 'toString', 1], options)).toBe('string') + expect(execSync(['_h', op.STRING, '1', op.CALL_GLOBAL, 'toInt', 1], options)).toBe(1) + expect(execSync(['_h', op.STRING, 'bla', op.CALL_GLOBAL, 'toInt', 1], options)).toBe(null) + expect(execSync(['_h', op.STRING, '1.2', op.CALL_GLOBAL, 'toFloat', 1], options)).toBe(1.2) + expect(execSync(['_h', op.STRING, 'bla', op.CALL_GLOBAL, 'toFloat', 1], options)).toBe(null) + expect(execSync(['_h', op.STRING, 'asd', op.CALL_GLOBAL, 'toUUID', 1], options)).toBe('asd') expect(execSync(['_h', op.NULL, op.INTEGER, 1, op.EQ], options)).toBe(false) expect(execSync(['_h', op.NULL, op.INTEGER, 1, op.NOT_EQ], options)).toBe(true) @@ -89,19 +89,34 @@ describe('hogvm execute', () => { test('error handling', async () => { const globals = { properties: { foo: 'bar' } } const options = { globals } - expect(() => execSync([], options)).toThrow("Invalid HogQL bytecode, must start with '_h'") - await expect(execAsync([], options)).rejects.toThrow("Invalid HogQL bytecode, must start with '_h'") + expect(() => execSync([], options)).toThrow("Invalid HogQL bytecode, must start with '_H'") + await expect(execAsync([], options)).rejects.toThrow("Invalid HogQL bytecode, must start with '_H'") + expect(() => execSync(['_h', op.INTEGER, 2, op.INTEGER, 1, 'InvalidOp'], options)).toThrow( 'Unexpected node while running bytecode: InvalidOp' ) expect(() => - execSync(['_h', op.STRING, 'another', op.STRING, 'arg', op.CALL, 'invalidFunc', 2], options) + execSync(['_h', op.STRING, 'another', op.STRING, 'arg', op.CALL_GLOBAL, 'invalidFunc', 2], options) ).toThrow('Unsupported function call: invalidFunc') expect(() => execSync(['_h', op.INTEGER], options)).toThrow('Unexpected end of bytecode') - expect(() => execSync(['_h', op.CALL, 'match', 1], options)).toThrow('Not enough arguments on the stack') + expect(() => execSync(['_h', op.CALL_GLOBAL, 'match', 1], options)).toThrow('Not enough arguments on the stack') expect(() => execSync(['_h', op.TRUE, op.TRUE, op.NOT], options)).toThrow( 'Invalid bytecode. More than one value left on stack' ) + + expect(() => execSync(['_H', 1, op.INTEGER, 2, op.INTEGER, 1, 'InvalidOp'], options)).toThrow( + 'Unexpected node while running bytecode: InvalidOp' + ) + expect(() => + execSync(['_H', 1, op.STRING, 'another', op.STRING, 'arg', op.CALL_GLOBAL, 'invalidFunc', 2], options) + ).toThrow('Unsupported function call: invalidFunc') + expect(() => execSync(['_H', 1, op.INTEGER], options)).toThrow('Unexpected end of bytecode') + expect(() => execSync(['_H', 1, op.CALL_GLOBAL, 'match', 1], options)).toThrow( + 'Not enough arguments on the stack' + ) + expect(() => execSync(['_H', 1, op.TRUE, op.TRUE, op.NOT], options)).toThrow( + 'Invalid bytecode. More than one value left on stack' + ) }) test('async limits', async () => { @@ -288,9 +303,14 @@ describe('hogvm execute', () => { return 'zero' }, } - expect(execSync(['_h', op.INTEGER, 1, op.CALL, 'stringify', 1], { functions })).toBe('one') - expect(execSync(['_h', op.INTEGER, 2, op.CALL, 'stringify', 1], { functions })).toBe('two') - expect(execSync(['_h', op.STRING, '2', op.CALL, 'stringify', 1], { functions })).toBe('zero') + expect(execSync(['_h', op.INTEGER, 1, op.CALL_GLOBAL, 'stringify', 1], { functions })).toBe('one') + expect(execSync(['_h', op.INTEGER, 2, op.CALL_GLOBAL, 'stringify', 1], { functions })).toBe('two') + expect(execSync(['_h', op.STRING, '2', op.CALL_GLOBAL, 'stringify', 1], { functions })).toBe('zero') + }) + + test('version 0 and 1', async () => { + expect(execSync(['_h', op.STRING, '1', op.STRING, '2', op.CALL_GLOBAL, 'concat', 2, op.RETURN])).toBe('21') + expect(execSync(['_H', 1, op.STRING, '1', op.STRING, '2', op.CALL_GLOBAL, 'concat', 2, op.RETURN])).toBe('12') }) test('should execute user-defined stringify async function correctly', async () => { @@ -304,9 +324,9 @@ describe('hogvm execute', () => { return Promise.resolve('zero') }, } - expect(await execAsync(['_h', op.INTEGER, 1, op.CALL, 'stringify', 1], { asyncFunctions })).toBe('one') - expect(await execAsync(['_h', op.INTEGER, 2, op.CALL, 'stringify', 1], { asyncFunctions })).toBe('two') - expect(await execAsync(['_h', op.STRING, '2', op.CALL, 'stringify', 1], { asyncFunctions })).toBe('zero') + expect(await execAsync(['_h', op.INTEGER, 1, op.CALL_GLOBAL, 'stringify', 1], { asyncFunctions })).toBe('one') + expect(await execAsync(['_h', op.INTEGER, 2, op.CALL_GLOBAL, 'stringify', 1], { asyncFunctions })).toBe('two') + expect(await execAsync(['_h', op.STRING, '2', op.CALL_GLOBAL, 'stringify', 1], { asyncFunctions })).toBe('zero') }) test('bytecode variable assignment', async () => { @@ -393,7 +413,7 @@ describe('hogvm execute', () => { 1, op.INTEGER, 2, - op.CALL, + op.CALL_GLOBAL, 'add', 2, op.INTEGER, @@ -402,12 +422,12 @@ describe('hogvm execute', () => { 4, op.INTEGER, 3, - op.CALL, + op.CALL_GLOBAL, 'add', 2, op.PLUS, op.PLUS, - op.CALL, + op.CALL_GLOBAL, 'divide', 2, op.RETURN, @@ -439,7 +459,7 @@ describe('hogvm execute', () => { op.GET_LOCAL, 0, op.MINUS, - op.CALL, + op.CALL_GLOBAL, 'fibonacci', 1, op.INTEGER, @@ -447,14 +467,14 @@ describe('hogvm execute', () => { op.GET_LOCAL, 0, op.MINUS, - op.CALL, + op.CALL_GLOBAL, 'fibonacci', 1, op.PLUS, op.RETURN, op.INTEGER, 6, - op.CALL, + op.CALL_GLOBAL, 'fibonacci', 1, op.RETURN, @@ -623,10 +643,10 @@ describe('hogvm execute', () => { .result ).toEqual(map({ key: map({ otherKey: 'value' }) })) - // return {key: 'value'}; + // // return {key: 'value'}; expect( - exec(['_h', op.STRING, 'key', op.GET_GLOBAL, 1, op.STRING, 'value', op.DICT, 1, op.RETURN]).result - ).toEqual(new Map([[null, 'value']])) + () => exec(['_h', op.STRING, 'key', op.GET_GLOBAL, 1, op.STRING, 'value', op.DICT, 1, op.RETURN]).result + ).toThrow('Global variable not found: key') // var key := 3; return {key: 'value'}; expect( @@ -1729,11 +1749,11 @@ describe('hogvm execute', () => { op.DICT, 2, ] - expect(execSync(['_h', op.STRING, '[1,2,3]', op.CALL, 'jsonParse', 1])).toEqual([1, 2, 3]) - expect(execSync(['_h', ...dict, op.CALL, 'jsonStringify', 1])).toEqual( + expect(execSync(['_h', op.STRING, '[1,2,3]', op.CALL_GLOBAL, 'jsonParse', 1])).toEqual([1, 2, 3]) + expect(execSync(['_h', ...dict, op.CALL_GLOBAL, 'jsonStringify', 1])).toEqual( '{"event":"$pageview","properties":{"$browser":"Chrome","$os":"Windows"}}' ) - expect(execSync(['_h', op.INTEGER, 2, ...dict, op.CALL, 'jsonStringify', 2])).toEqual( + expect(execSync(['_h', op.INTEGER, 2, ...dict, op.CALL_GLOBAL, 'jsonStringify', 2])).toEqual( JSON.stringify({ event: '$pageview', properties: { $browser: 'Chrome', $os: 'Windows' } }, null, 2) ) }) @@ -1783,21 +1803,21 @@ describe('hogvm execute', () => { 7, op.STRING, 'true1', - op.CALL, + op.CALL_GLOBAL, 'noisy_print', 1, op.JUMP, 5, op.STRING, 'false1', - op.CALL, + op.CALL_GLOBAL, 'noisy_print', 1, op.JUMP, 5, op.STRING, 'false2', - op.CALL, + op.CALL_GLOBAL, 'noisy_print', 1, op.RETURN, @@ -1823,13 +1843,13 @@ describe('hogvm execute', () => { op.POP, op.STRING, 'no', - op.CALL, + op.CALL_GLOBAL, 'noisy_print', 1, op.RETURN, op.STRING, 'post', - op.CALL, + op.CALL_GLOBAL, 'noisy_print', 1, op.POP, @@ -1840,7 +1860,7 @@ describe('hogvm execute', () => { test('uncaught exceptions', () => { // throw Error('Not a good day') - const bytecode1 = ['_h', op.NULL, op.NULL, op.STRING, 'Not a good day', op.CALL, 'Error', 3, op.THROW] + const bytecode1 = ['_h', op.NULL, op.NULL, op.STRING, 'Not a good day', op.CALL_GLOBAL, 'Error', 3, op.THROW] expect(() => execSync(bytecode1)).toThrow(new UncaughtHogVMException('Error', 'Not a good day', null)) // throw RetryError('Not a good day', {'key': 'value'}) @@ -1854,7 +1874,7 @@ describe('hogvm execute', () => { 1, op.STRING, 'Not a good day', - op.CALL, + op.CALL_GLOBAL, 'RetryError', 2, op.THROW, @@ -1865,7 +1885,20 @@ describe('hogvm execute', () => { }) test('returns serialized state', () => { - const bytecode = ['_h', op.STRING, 'key', op.STRING, 'value', op.DICT, 1, op.GET_LOCAL, 0, op.CALL, 'fetch', 1] + const bytecode = [ + '_h', + op.STRING, + 'key', + op.STRING, + 'value', + op.DICT, + 1, + op.GET_LOCAL, + 0, + op.CALL_GLOBAL, + 'fetch', + 1, + ] expect(exec(bytecode, { asyncFunctions: { fetch: async () => null } })).toEqual({ asyncFunctionArgs: [{ key: 'value' }], // not a Map asyncFunctionName: 'fetch', diff --git a/hogvm/typescript/src/execute.ts b/hogvm/typescript/src/execute.ts index dd7865b77f0af..9f9bb5af6a422 100644 --- a/hogvm/typescript/src/execute.ts +++ b/hogvm/typescript/src/execute.ts @@ -110,10 +110,10 @@ export function exec(code: any[] | VMState, options?: ExecOptions): ExecResult { } else { bytecode = code } - - if (!bytecode || bytecode.length === 0 || bytecode[0] !== '_h') { - throw new HogVMException("Invalid HogQL bytecode, must start with '_h'") + if (!bytecode || bytecode.length === 0 || (bytecode[0] !== '_h' && bytecode[0] !== '_H')) { + throw new HogVMException("Invalid HogQL bytecode, must start with '_H'") } + const version = bytecode[0] === '_H' ? bytecode[1] ?? 0 : 0 const startTime = Date.now() let temp: any @@ -131,7 +131,7 @@ export function exec(code: any[] | VMState, options?: ExecOptions): ExecResult { let memUsed = memStack.reduce((acc, val) => acc + val, 0) let maxMemUsed = Math.max(vmState ? vmState.maxMemUsed : 0, memUsed) const memLimit = options?.memoryLimit ?? DEFAULT_MAX_MEMORY - let ip = vmState ? vmState.ip : 1 + let ip = vmState ? vmState.ip : bytecode[0] === '_H' ? 2 : 1 let ops = vmState ? vmState.ops : 0 const timeout = options?.timeout ?? DEFAULT_TIMEOUT_MS const maxAsyncSteps = options?.maxAsyncSteps ?? DEFAULT_MAX_ASYNC_STEPS @@ -158,7 +158,9 @@ export function exec(code: any[] | VMState, options?: ExecOptions): ExecResult { memUsed -= memStack.splice(start, deleteCount).reduce((acc, val) => acc + val, 0) return stack.splice(start, deleteCount) } - function spliceStack1(start: number): any[] { + + /** Keep start elements, return those removed */ + function stackKeepFirstElements(start: number): any[] { memUsed -= memStack.splice(start).reduce((acc, val) => acc + val, 0) return stack.splice(start) } @@ -310,7 +312,11 @@ export function exec(code: any[] | VMState, options?: ExecOptions): ExecResult { for (let i = 0; i < count; i++) { chain.push(popStack()) } - pushStack(options?.globals ? convertJSToHog(getNestedValue(options.globals, chain)) : null) + if (options?.globals && chain[0] in options.globals && Object.hasOwn(options.globals, chain[0])) { + pushStack(convertJSToHog(getNestedValue(options.globals, chain))) + } else { + throw new HogVMException(`Global variable not found: ${chain.join('.')}`) + } break } case Operation.POP: @@ -320,7 +326,7 @@ export function exec(code: any[] | VMState, options?: ExecOptions): ExecResult { if (callStack.length > 0) { const [newIp, stackStart, _] = callStack.pop()! const response = popStack() - spliceStack1(stackStart) + stackKeepFirstElements(stackStart) pushStack(response) ip = newIp break @@ -400,7 +406,7 @@ export function exec(code: any[] | VMState, options?: ExecOptions): ExecResult { ip += bodyLength break } - case Operation.CALL: { + case Operation.CALL_GLOBAL: { checkTimeout() const name = next() // excluding "toString" only because of JavaScript --> no, it's not declared, it's omnipresent! o_O @@ -416,9 +422,14 @@ export function exec(code: any[] | VMState, options?: ExecOptions): ExecResult { if (temp > MAX_FUNCTION_ARGS_LENGTH) { throw new HogVMException('Too many arguments') } - const args = Array(temp) - .fill(null) - .map(() => popStack()) + + const args = + version === 0 + ? Array(temp) + .fill(null) + .map(() => popStack()) + : stackKeepFirstElements(stack.length - temp) + if (options?.functions && Object.hasOwn(options.functions, name) && options.functions[name]) { pushStack(convertJSToHog(options.functions[name](...args.map(convertHogToJS)))) } else if ( @@ -475,7 +486,7 @@ export function exec(code: any[] | VMState, options?: ExecOptions): ExecResult { } if (throwStack.length > 0) { const [callStackLen, stackLen, catchIp] = throwStack.pop()! - spliceStack1(stackLen) + stackKeepFirstElements(stackLen) memUsed -= memStack.splice(stackLen).reduce((acc, val) => acc + val, 0) callStack.splice(callStackLen) pushStack(exception) diff --git a/hogvm/typescript/src/operation.ts b/hogvm/typescript/src/operation.ts index 2f8af6d275f56..4d4c5eee71a1a 100644 --- a/hogvm/typescript/src/operation.ts +++ b/hogvm/typescript/src/operation.ts @@ -1,6 +1,6 @@ export const enum Operation { GET_GLOBAL = 1, - CALL = 2, + CALL_GLOBAL = 2, AND = 3, OR = 4, NOT = 5, diff --git a/posthog/hogql/bytecode.py b/posthog/hogql/bytecode.py index 36d4e47e9eb72..1d71ec173d372 100644 --- a/posthog/hogql/bytecode.py +++ b/posthog/hogql/bytecode.py @@ -14,6 +14,7 @@ from hogvm.python.operation import ( Operation, HOGQL_BYTECODE_IDENTIFIER, + HOGQL_BYTECODE_VERSION, ) from posthog.schema import HogQLNotice @@ -65,7 +66,8 @@ def create_bytecode( bytecode: list[Any] = [] if args is None: bytecode.append(HOGQL_BYTECODE_IDENTIFIER) - bytecode.extend(BytecodeBuilder(supported_functions, args, context).visit(expr)) + bytecode.append(HOGQL_BYTECODE_VERSION) + bytecode.extend(BytecodeCompiler(supported_functions, args, context).visit(expr)) return bytecode @@ -82,7 +84,7 @@ class HogFunction: bytecode: list[Any] -class BytecodeBuilder(Visitor): +class BytecodeCompiler(Visitor): def __init__( self, supported_functions: Optional[set[str]] = None, @@ -97,7 +99,7 @@ def __init__( self.args = args # we're in a function definition if args is not None: - for arg in reversed(args): + for arg in args: self._declare_local(arg) self.context = context or HogQLContext(team_id=None) @@ -126,7 +128,7 @@ def _declare_local(self, name: str) -> int: def visit_and(self, node: ast.And): response = [] - for expr in reversed(node.exprs): + for expr in node.exprs: response.extend(self.visit(expr)) response.append(Operation.AND) response.append(len(node.exprs)) @@ -134,7 +136,7 @@ def visit_and(self, node: ast.And): def visit_or(self, node: ast.Or): response = [] - for expr in reversed(node.exprs): + for expr in node.exprs: response.extend(self.visit(expr)) response.append(Operation.OR) response.append(len(node.exprs)) @@ -224,12 +226,12 @@ def visit_call(self, node: ast.Call): return [*self.visit(node.args[0]), Operation.NOT] if node.name == "and" and len(node.args) > 1: args = [] - for arg in reversed(node.args): + for arg in node.args: args.extend(self.visit(arg)) return [*args, Operation.AND, len(node.args)] if node.name == "or" and len(node.args) > 1: args = [] - for arg in reversed(node.args): + for arg in node.args: args.extend(self.visit(arg)) return [*args, Operation.OR, len(node.args)] if node.name == "if" and len(node.args) >= 2: @@ -278,16 +280,16 @@ def visit_call(self, node: ast.Call): ) response = [] + for expr in node.args: + response.extend(self.visit(expr)) + if node.name in MIN_ARGS_INCLUDING_OPTIONAL and len(node.args) < MIN_ARGS_INCLUDING_OPTIONAL[node.name]: for _ in range(len(node.args), MIN_ARGS_INCLUDING_OPTIONAL[node.name]): response.append(Operation.NULL) - for expr in reversed(node.args): - response.extend(self.visit(expr)) - response.extend( [ - Operation.CALL, + Operation.CALL_GLOBAL, node.name, len(node.args) if node.name not in MIN_ARGS_INCLUDING_OPTIONAL @@ -484,18 +486,18 @@ def visit_for_in_statement(self, node: ast.ForInStatement): if key_var is not None: expr_keys_local = self._declare_local("__H_keys_H__") # keys - response.extend([Operation.GET_LOCAL, expr_local, Operation.CALL, "keys", 1]) + response.extend([Operation.GET_LOCAL, expr_local, Operation.CALL_GLOBAL, "keys", 1]) else: expr_keys_local = None expr_values_local = self._declare_local("__H_values_H__") # values - response.extend([Operation.GET_LOCAL, expr_local, Operation.CALL, "values", 1]) + response.extend([Operation.GET_LOCAL, expr_local, Operation.CALL_GLOBAL, "values", 1]) loop_index_local = self._declare_local("__H_index_H__") # 0 response.extend([Operation.INTEGER, 1]) loop_limit_local = self._declare_local("__H_limit_H__") # length of keys - response.extend([Operation.GET_LOCAL, expr_values_local, Operation.CALL, "length", 1]) + response.extend([Operation.GET_LOCAL, expr_values_local, Operation.CALL_GLOBAL, "length", 1]) if key_var is not None: key_var_local = self._declare_local(key_var) # loop key @@ -668,5 +670,9 @@ def execute_hog( if not source_code.endswith(";"): source_code = f"{source_code};" program = parse_program(source_code) - bytecode = create_bytecode(program) + bytecode = create_bytecode( + program, + supported_functions=set(functions.keys()) if functions is not None else set(), + context=HogQLContext(team_id=team.id if team else None), + ) return execute_bytecode(bytecode, globals=globals, functions=functions, timeout=timeout, team=team) diff --git a/posthog/hogql/test/test_bytecode.py b/posthog/hogql/test/test_bytecode.py index 29b2c4e5620b4..2abfa516525b9 100644 --- a/posthog/hogql/test/test_bytecode.py +++ b/posthog/hogql/test/test_bytecode.py @@ -191,7 +191,7 @@ def test_bytecode_objects(self): def test_bytecode_create_not_implemented_error(self): with self.assertRaises(NotImplementedError) as e: to_bytecode("(select 1)") - self.assertEqual(str(e.exception), "BytecodeBuilder has no method visit_select_query") + self.assertEqual(str(e.exception), "BytecodeCompiler has no method visit_select_query") def test_bytecode_create_query_error(self): with self.assertRaises(QueryError) as e: From ea4d593719fd0201e43386a57abf7e9e3e36211b Mon Sep 17 00:00:00 2001 From: Marius Andra Date: Mon, 26 Aug 2024 22:04:24 +0200 Subject: [PATCH 11/21] bump --- hogvm/typescript/package.json | 2 +- plugin-server/package.json | 2 +- plugin-server/pnpm-lock.yaml | 8 ++++---- 3 files changed, 6 insertions(+), 6 deletions(-) diff --git a/hogvm/typescript/package.json b/hogvm/typescript/package.json index b6e47b51cbcbc..90291d4afa369 100644 --- a/hogvm/typescript/package.json +++ b/hogvm/typescript/package.json @@ -1,6 +1,6 @@ { "name": "@posthog/hogvm", - "version": "1.0.35", + "version": "1.0.36", "description": "PostHog Hog Virtual Machine", "types": "dist/index.d.ts", "main": "dist/index.js", diff --git a/plugin-server/package.json b/plugin-server/package.json index f7672084d42eb..ea7467fb42993 100644 --- a/plugin-server/package.json +++ b/plugin-server/package.json @@ -52,7 +52,7 @@ "@google-cloud/storage": "^5.8.5", "@maxmind/geoip2-node": "^3.4.0", "@posthog/clickhouse": "^1.7.0", - "@posthog/hogvm": "^1.0.35", + "@posthog/hogvm": "^1.0.36", "@posthog/plugin-scaffold": "1.4.4", "@sentry/node": "^7.49.0", "@sentry/profiling-node": "^0.3.0", diff --git a/plugin-server/pnpm-lock.yaml b/plugin-server/pnpm-lock.yaml index 0bb579b69c438..faedff7194010 100644 --- a/plugin-server/pnpm-lock.yaml +++ b/plugin-server/pnpm-lock.yaml @@ -47,8 +47,8 @@ dependencies: specifier: file:../rust/cyclotron-node version: file:../rust/cyclotron-node '@posthog/hogvm': - specifier: ^1.0.35 - version: 1.0.35(luxon@3.4.4)(re2@1.20.3) + specifier: ^1.0.36 + version: 1.0.36(luxon@3.4.4)(re2@1.20.3) '@posthog/plugin-scaffold': specifier: 1.4.4 version: 1.4.4 @@ -3116,8 +3116,8 @@ packages: engines: {node: '>=12'} dev: false - /@posthog/hogvm@1.0.35(luxon@3.4.4)(re2@1.20.3): - resolution: {integrity: sha512-Uq3Cpg0CGxwScdgGddfzDCs42opILFhgnM6wqly55PAZGBhXWxVHgVpejLiWLtG1z8aIMLC8HCbQx1rZheCGMQ==} + /@posthog/hogvm@1.0.36(luxon@3.4.4)(re2@1.20.3): + resolution: {integrity: sha512-O4mVlTCNYAOg3eh82r5YE0HqMf4b0em7JNHCD6tkUUMxe47rTAVflSW/vVOkV7ogfgyjxQD0bOS6w708FW/cMg==} peerDependencies: luxon: ^3.4.4 re2: ^1.21.3 From 8390eaf6f2202dc6fcafcb8f92a0e1566a31f3a0 Mon Sep 17 00:00:00 2001 From: Marius Andra Date: Mon, 26 Aug 2024 22:11:24 +0200 Subject: [PATCH 12/21] bump --- hogvm/typescript/src/__tests__/execute.test.ts | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/hogvm/typescript/src/__tests__/execute.test.ts b/hogvm/typescript/src/__tests__/execute.test.ts index 494f6da0753c7..7de7f42d2d3a2 100644 --- a/hogvm/typescript/src/__tests__/execute.test.ts +++ b/hogvm/typescript/src/__tests__/execute.test.ts @@ -1879,7 +1879,7 @@ describe('hogvm execute', () => { ip: 12, maxMemUsed: 64, ops: 5, - stack: [{ key: 'value' }], // not a Map + stack: [{ key: 'value' }], // is not a Map syncDuration: 0, throwStack: [], }, From f6e2b88d1ba1e435c5bff9bbf958441f4f8fd718 Mon Sep 17 00:00:00 2001 From: Marius Andra Date: Tue, 27 Aug 2024 09:51:33 +0200 Subject: [PATCH 13/21] fix mypy --- posthog/hogql/test/test_bytecode.py | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/posthog/hogql/test/test_bytecode.py b/posthog/hogql/test/test_bytecode.py index 2abfa516525b9..ec143f13e3ad5 100644 --- a/posthog/hogql/test/test_bytecode.py +++ b/posthog/hogql/test/test_bytecode.py @@ -60,7 +60,7 @@ def test_bytecode_create(self): ) self.assertEqual( to_bytecode("concat('arg', 'another')"), - [_H, op.STRING, "another", op.STRING, "arg", op.CALL, "concat", 2], + [_H, op.STRING, "another", op.STRING, "arg", op.CALL_GLOBAL, "concat", 2], ) self.assertEqual( to_bytecode("ifNull(properties.email, false)"), @@ -120,15 +120,15 @@ def test_bytecode_create(self): ) self.assertEqual( to_bytecode("match('test', 'e.*')"), - [_H, op.STRING, "e.*", op.STRING, "test", op.CALL, "match", 2], + [_H, op.STRING, "e.*", op.STRING, "test", op.CALL_GLOBAL, "match", 2], ) self.assertEqual( to_bytecode("match('test', '^e.*')"), - [_H, op.STRING, "^e.*", op.STRING, "test", op.CALL, "match", 2], + [_H, op.STRING, "^e.*", op.STRING, "test", op.CALL_GLOBAL, "match", 2], ) self.assertEqual( to_bytecode("match('test', 'x.*')"), - [_H, op.STRING, "x.*", op.STRING, "test", op.CALL, "match", 2], + [_H, op.STRING, "x.*", op.STRING, "test", op.CALL_GLOBAL, "match", 2], ) self.assertEqual(to_bytecode("not('test')"), [_H, op.STRING, "test", op.NOT]) self.assertEqual(to_bytecode("not 'test'"), [_H, op.STRING, "test", op.NOT]) From d12b25b0c7303fbf318e2ebe5352f56d4d8cd445 Mon Sep 17 00:00:00 2001 From: Marius Andra Date: Tue, 27 Aug 2024 10:05:30 +0200 Subject: [PATCH 14/21] fix a bunch of tests --- .../api/test/__snapshots__/test_action.ambr | 70 ---------- posthog/api/test/test_action.py | 2 +- posthog/api/test/test_hog_function.py | 83 ++++++++---- posthog/hogql/test/test_bytecode.py | 123 +++++++++++------- .../test/test_migrate_action_webhooks.py | 4 +- .../commands/test/test_migrate_hooks.py | 3 +- posthog/models/test/test_hog_function.py | 22 ++-- 7 files changed, 151 insertions(+), 156 deletions(-) diff --git a/posthog/api/test/__snapshots__/test_action.ambr b/posthog/api/test/__snapshots__/test_action.ambr index 03d20dc4a2b43..44b749ef70294 100644 --- a/posthog/api/test/__snapshots__/test_action.ambr +++ b/posthog/api/test/__snapshots__/test_action.ambr @@ -290,76 +290,6 @@ "posthog_action"."name" ASC ''' # --- -# name: TestActionApi.test_listing_actions_is_not_nplus1.15 - ''' - SELECT COUNT(*) - FROM - (SELECT "posthog_action"."id" AS "col1" - FROM "posthog_action" - LEFT OUTER JOIN "posthog_action_events" ON ("posthog_action"."id" = "posthog_action_events"."action_id") - WHERE (NOT "posthog_action"."deleted" - AND "posthog_action"."team_id" = 2 - AND "posthog_action"."team_id" = 2) - GROUP BY 1) subquery - ''' -# --- -# name: TestActionApi.test_listing_actions_is_not_nplus1.16 - ''' - SELECT "posthog_action"."id", - "posthog_action"."name", - "posthog_action"."team_id", - "posthog_action"."description", - "posthog_action"."created_at", - "posthog_action"."created_by_id", - "posthog_action"."deleted", - "posthog_action"."post_to_slack", - "posthog_action"."slack_message_format", - "posthog_action"."updated_at", - "posthog_action"."bytecode", - "posthog_action"."bytecode_error", - "posthog_action"."steps_json", - "posthog_action"."is_calculating", - "posthog_action"."last_calculated_at", - COUNT("posthog_action_events"."event_id") AS "count", - "posthog_user"."id", - "posthog_user"."password", - "posthog_user"."last_login", - "posthog_user"."first_name", - "posthog_user"."last_name", - "posthog_user"."is_staff", - "posthog_user"."is_active", - "posthog_user"."date_joined", - "posthog_user"."uuid", - "posthog_user"."current_organization_id", - "posthog_user"."current_team_id", - "posthog_user"."email", - "posthog_user"."pending_email", - "posthog_user"."temporary_token", - "posthog_user"."distinct_id", - "posthog_user"."is_email_verified", - "posthog_user"."requested_password_reset_at", - "posthog_user"."has_seen_product_intro_for", - "posthog_user"."strapi_id", - "posthog_user"."theme_mode", - "posthog_user"."partial_notification_settings", - "posthog_user"."anonymize_data", - "posthog_user"."toolbar_mode", - "posthog_user"."hedgehog_config", - "posthog_user"."events_column_config", - "posthog_user"."email_opt_in" - FROM "posthog_action" - LEFT OUTER JOIN "posthog_action_events" ON ("posthog_action"."id" = "posthog_action_events"."action_id") - LEFT OUTER JOIN "posthog_user" ON ("posthog_action"."created_by_id" = "posthog_user"."id") - WHERE (NOT "posthog_action"."deleted" - AND "posthog_action"."team_id" = 2 - AND "posthog_action"."team_id" = 2) - GROUP BY "posthog_action"."id", - "posthog_user"."id" - ORDER BY "posthog_action"."last_calculated_at" DESC, - "posthog_action"."name" ASC - LIMIT 100 - ''' -# --- # name: TestActionApi.test_listing_actions_is_not_nplus1.2 ''' SELECT "posthog_organizationmembership"."id", diff --git a/posthog/api/test/test_action.py b/posthog/api/test/test_action.py index 3e4a0c4f56d87..96ae589fdea35 100644 --- a/posthog/api/test/test_action.py +++ b/posthog/api/test/test_action.py @@ -100,7 +100,7 @@ def test_create_action_generates_bytecode(self): ) assert response.status_code == status.HTTP_201_CREATED, response.json() action = Action.objects.get(pk=response.json()["id"]) - assert action.bytecode == ["_h", 32, "%/signup%", 32, "$current_url", 32, "properties", 1, 2, 17] + assert action.bytecode == ["_H", 1, 32, "%/signup%", 32, "$current_url", 32, "properties", 1, 2, 17] def test_cant_create_action_with_the_same_name(self, *args): original_action = Action.objects.create(name="user signed up", team=self.team) diff --git a/posthog/api/test/test_hog_function.py b/posthog/api/test/test_hog_function.py index 191b3473da27d..813ee45bddec3 100644 --- a/posthog/api/test/test_hog_function.py +++ b/posthog/api/test/test_hog_function.py @@ -5,6 +5,7 @@ from inline_snapshot import snapshot from rest_framework import status +from hogvm.python.operation import HOGQL_BYTECODE_VERSION from posthog.constants import AvailableFeature from posthog.models.action.action import Action from posthog.models.hog_functions.hog_function import DEFAULT_STATE, HogFunction @@ -140,10 +141,10 @@ def test_create_hog_function(self, *args): "updated_at": ANY, "enabled": False, "hog": "fetch(inputs.url);", - "bytecode": ["_h", 32, "url", 32, "inputs", 1, 2, 2, "fetch", 1, 35], + "bytecode": ["_H", HOGQL_BYTECODE_VERSION, 32, "url", 32, "inputs", 1, 2, 2, "fetch", 1, 35], "inputs_schema": [], "inputs": {}, - "filters": {"bytecode": ["_h", 29]}, + "filters": {"bytecode": ["_H", HOGQL_BYTECODE_VERSION, 29]}, "icon_url": None, "template": None, "masking": None, @@ -325,7 +326,7 @@ def test_generates_hog_bytecode(self, *args): ) # JSON loads for one line comparison assert response.json()["bytecode"] == json.loads( - '["_h", 33, 0, 33, 3, 36, 0, 15, 40, 45, 33, 1, 36, 0, 6, 37, 0, 32, "headers", 32, "x-count", 36, 0, 42, 1, 32, "body", 32, "payload", 32, "inputs", 1, 2, 32, "method", 32, "method", 32, "inputs", 1, 2, 42, 3, 32, "url", 32, "inputs", 1, 2, 2, "fetch", 2, 35, 39, -52, 35]' + f'["_H", {HOGQL_BYTECODE_VERSION}, 33, 0, 33, 3, 36, 0, 15, 40, 45, 33, 1, 36, 0, 6, 37, 0, 32, "url", 32, "inputs", 1, 2, 32, "headers", 32, "x-count", 36, 0, 42, 1, 32, "body", 32, "payload", 32, "inputs", 1, 2, 32, "method", 32, "method", 32, "inputs", 1, 2, 42, 3, 2, "fetch", 2, 35, 39, -52, 35]' ), response.json() def test_generates_inputs_bytecode(self, *args): @@ -334,7 +335,12 @@ def test_generates_inputs_bytecode(self, *args): assert response.json()["inputs"] == { "url": { "value": "http://localhost:2080/0e02d917-563f-4050-9725-aad881b69937", - "bytecode": ["_h", 32, "http://localhost:2080/0e02d917-563f-4050-9725-aad881b69937"], + "bytecode": [ + "_H", + HOGQL_BYTECODE_VERSION, + 32, + "http://localhost:2080/0e02d917-563f-4050-9725-aad881b69937", + ], }, "payload": { "value": { @@ -345,18 +351,48 @@ def test_generates_inputs_bytecode(self, *args): "event_url": "{f'{event.url}-test'}", }, "bytecode": { - "event": ["_h", 32, "event", 1, 1], - "groups": ["_h", 32, "groups", 1, 1], - "nested": {"foo": ["_h", 32, "url", 32, "event", 1, 2]}, - "person": ["_h", 32, "person", 1, 1], - "event_url": ["_h", 32, "-test", 32, "url", 32, "event", 1, 2, 2, "concat", 2], + "event": ["_H", HOGQL_BYTECODE_VERSION, 32, "event", 1, 1], + "groups": ["_H", HOGQL_BYTECODE_VERSION, 32, "groups", 1, 1], + "nested": {"foo": ["_H", HOGQL_BYTECODE_VERSION, 32, "url", 32, "event", 1, 2]}, + "person": ["_H", HOGQL_BYTECODE_VERSION, 32, "person", 1, 1], + "event_url": [ + "_H", + HOGQL_BYTECODE_VERSION, + 32, + "url", + 32, + "event", + 1, + 2, + 32, + "-test", + 2, + "concat", + 2, + ], }, }, "method": {"value": "POST"}, "headers": { "value": {"version": "v={event.properties.$lib_version}"}, "bytecode": { - "version": ["_h", 32, "$lib_version", 32, "properties", 32, "event", 1, 3, 32, "v=", 2, "concat", 2] + "version": [ + "_H", + HOGQL_BYTECODE_VERSION, + 32, + "$lib_version", + 32, + "properties", + 32, + "event", + 1, + 3, + 32, + "v=", + 2, + "concat", + 2, + ] }, }, } @@ -394,16 +430,19 @@ def test_generates_filters_bytecode(self, *args): "actions": [{"id": f"{action.id}", "name": "Test Action", "type": "actions", "order": 1}], "filter_test_accounts": True, "bytecode": [ - "_h", + "_H", + HOGQL_BYTECODE_VERSION, 32, - "%docs%", + "%@posthog.com%", 32, - "$current_url", + "email", 32, "properties", + 32, + "person", 1, - 2, - 17, + 3, + 20, 32, "$pageview", 32, @@ -424,8 +463,6 @@ def test_generates_filters_bytecode(self, *args): 1, 3, 20, - 3, - 2, 32, "$pageview", 32, @@ -434,16 +471,16 @@ def test_generates_filters_bytecode(self, *args): 1, 11, 32, - "%@posthog.com%", + "%docs%", 32, - "email", + "$current_url", 32, "properties", - 32, - "person", 1, + 2, + 17, 3, - 20, + 2, 3, 2, 4, @@ -465,7 +502,7 @@ def test_saves_masking_config(self, *args): "ttl": 60, "threshold": 20, "hash": "{person.properties.email}", - "bytecode": ["_h", 32, "email", 32, "properties", 32, "person", 1, 3], + "bytecode": ["_H", HOGQL_BYTECODE_VERSION, 32, "email", 32, "properties", 32, "person", 1, 3], } ) diff --git a/posthog/hogql/test/test_bytecode.py b/posthog/hogql/test/test_bytecode.py index ec143f13e3ad5..967066b3312f1 100644 --- a/posthog/hogql/test/test_bytecode.py +++ b/posthog/hogql/test/test_bytecode.py @@ -1,30 +1,31 @@ import pytest from posthog.hogql.bytecode import to_bytecode, execute_hog -from hogvm.python.operation import Operation as op, HOGQL_BYTECODE_IDENTIFIER as _H +from hogvm.python.operation import Operation as op, HOGQL_BYTECODE_IDENTIFIER as _H, HOGQL_BYTECODE_VERSION from posthog.hogql.errors import NotImplementedError, QueryError from posthog.test.base import BaseTest class TestBytecode(BaseTest): def test_bytecode_create(self): - self.assertEqual(to_bytecode("1 + 2"), [_H, op.INTEGER, 2, op.INTEGER, 1, op.PLUS]) - self.assertEqual(to_bytecode("1 and 2"), [_H, op.INTEGER, 2, op.INTEGER, 1, op.AND, 2]) - self.assertEqual(to_bytecode("1 or 2"), [_H, op.INTEGER, 2, op.INTEGER, 1, op.OR, 2]) + self.assertEqual(to_bytecode("1 + 2"), [_H, HOGQL_BYTECODE_VERSION, op.INTEGER, 2, op.INTEGER, 1, op.PLUS]) + self.assertEqual(to_bytecode("1 and 2"), [_H, HOGQL_BYTECODE_VERSION, op.INTEGER, 1, op.INTEGER, 2, op.AND, 2]) + self.assertEqual(to_bytecode("1 or 2"), [_H, HOGQL_BYTECODE_VERSION, op.INTEGER, 1, op.INTEGER, 2, op.OR, 2]) self.assertEqual( to_bytecode("1 or (2 and 1) or 2"), [ _H, - op.INTEGER, - 2, + HOGQL_BYTECODE_VERSION, op.INTEGER, 1, op.INTEGER, 2, + op.INTEGER, + 1, op.AND, 2, op.INTEGER, - 1, + 2, op.OR, 3, ], @@ -33,39 +34,41 @@ def test_bytecode_create(self): to_bytecode("(1 or 2) and (1 or 2)"), [ _H, - op.INTEGER, - 2, + HOGQL_BYTECODE_VERSION, op.INTEGER, 1, - op.OR, - 2, op.INTEGER, 2, + op.OR, + 2, op.INTEGER, 1, + op.INTEGER, + 2, op.OR, 2, op.AND, 2, ], ) - self.assertEqual(to_bytecode("not true"), [_H, op.TRUE, op.NOT]) - self.assertEqual(to_bytecode("true"), [_H, op.TRUE]) - self.assertEqual(to_bytecode("false"), [_H, op.FALSE]) - self.assertEqual(to_bytecode("null"), [_H, op.NULL]) - self.assertEqual(to_bytecode("3.14"), [_H, op.FLOAT, 3.14]) + self.assertEqual(to_bytecode("not true"), [_H, HOGQL_BYTECODE_VERSION, op.TRUE, op.NOT]) + self.assertEqual(to_bytecode("true"), [_H, HOGQL_BYTECODE_VERSION, op.TRUE]) + self.assertEqual(to_bytecode("false"), [_H, HOGQL_BYTECODE_VERSION, op.FALSE]) + self.assertEqual(to_bytecode("null"), [_H, HOGQL_BYTECODE_VERSION, op.NULL]) + self.assertEqual(to_bytecode("3.14"), [_H, HOGQL_BYTECODE_VERSION, op.FLOAT, 3.14]) self.assertEqual( to_bytecode("properties.bla"), - [_H, op.STRING, "bla", op.STRING, "properties", op.GET_GLOBAL, 2], + [_H, HOGQL_BYTECODE_VERSION, op.STRING, "bla", op.STRING, "properties", op.GET_GLOBAL, 2], ) self.assertEqual( to_bytecode("concat('arg', 'another')"), - [_H, op.STRING, "another", op.STRING, "arg", op.CALL_GLOBAL, "concat", 2], + [_H, HOGQL_BYTECODE_VERSION, op.STRING, "arg", op.STRING, "another", op.CALL_GLOBAL, "concat", 2], ) self.assertEqual( to_bytecode("ifNull(properties.email, false)"), [ _H, + HOGQL_BYTECODE_VERSION, op.STRING, "email", op.STRING, @@ -78,91 +81,111 @@ def test_bytecode_create(self): op.FALSE, ], ) - self.assertEqual(to_bytecode("1 = 2"), [_H, op.INTEGER, 2, op.INTEGER, 1, op.EQ]) - self.assertEqual(to_bytecode("1 == 2"), [_H, op.INTEGER, 2, op.INTEGER, 1, op.EQ]) - self.assertEqual(to_bytecode("1 != 2"), [_H, op.INTEGER, 2, op.INTEGER, 1, op.NOT_EQ]) - self.assertEqual(to_bytecode("1 < 2"), [_H, op.INTEGER, 2, op.INTEGER, 1, op.LT]) - self.assertEqual(to_bytecode("1 <= 2"), [_H, op.INTEGER, 2, op.INTEGER, 1, op.LT_EQ]) - self.assertEqual(to_bytecode("1 > 2"), [_H, op.INTEGER, 2, op.INTEGER, 1, op.GT]) - self.assertEqual(to_bytecode("1 >= 2"), [_H, op.INTEGER, 2, op.INTEGER, 1, op.GT_EQ]) - self.assertEqual(to_bytecode("1 like 2"), [_H, op.INTEGER, 2, op.INTEGER, 1, op.LIKE]) - self.assertEqual(to_bytecode("1 ilike 2"), [_H, op.INTEGER, 2, op.INTEGER, 1, op.ILIKE]) - self.assertEqual(to_bytecode("1 not like 2"), [_H, op.INTEGER, 2, op.INTEGER, 1, op.NOT_LIKE]) + self.assertEqual(to_bytecode("1 = 2"), [_H, HOGQL_BYTECODE_VERSION, op.INTEGER, 2, op.INTEGER, 1, op.EQ]) + self.assertEqual(to_bytecode("1 == 2"), [_H, HOGQL_BYTECODE_VERSION, op.INTEGER, 2, op.INTEGER, 1, op.EQ]) + self.assertEqual(to_bytecode("1 != 2"), [_H, HOGQL_BYTECODE_VERSION, op.INTEGER, 2, op.INTEGER, 1, op.NOT_EQ]) + self.assertEqual(to_bytecode("1 < 2"), [_H, HOGQL_BYTECODE_VERSION, op.INTEGER, 2, op.INTEGER, 1, op.LT]) + self.assertEqual(to_bytecode("1 <= 2"), [_H, HOGQL_BYTECODE_VERSION, op.INTEGER, 2, op.INTEGER, 1, op.LT_EQ]) + self.assertEqual(to_bytecode("1 > 2"), [_H, HOGQL_BYTECODE_VERSION, op.INTEGER, 2, op.INTEGER, 1, op.GT]) + self.assertEqual(to_bytecode("1 >= 2"), [_H, HOGQL_BYTECODE_VERSION, op.INTEGER, 2, op.INTEGER, 1, op.GT_EQ]) + self.assertEqual(to_bytecode("1 like 2"), [_H, HOGQL_BYTECODE_VERSION, op.INTEGER, 2, op.INTEGER, 1, op.LIKE]) + self.assertEqual(to_bytecode("1 ilike 2"), [_H, HOGQL_BYTECODE_VERSION, op.INTEGER, 2, op.INTEGER, 1, op.ILIKE]) + self.assertEqual( + to_bytecode("1 not like 2"), [_H, HOGQL_BYTECODE_VERSION, op.INTEGER, 2, op.INTEGER, 1, op.NOT_LIKE] + ) self.assertEqual( to_bytecode("1 not ilike 2"), - [_H, op.INTEGER, 2, op.INTEGER, 1, op.NOT_ILIKE], + [_H, HOGQL_BYTECODE_VERSION, op.INTEGER, 2, op.INTEGER, 1, op.NOT_ILIKE], + ) + self.assertEqual(to_bytecode("1 in 2"), [_H, HOGQL_BYTECODE_VERSION, op.INTEGER, 2, op.INTEGER, 1, op.IN]) + self.assertEqual( + to_bytecode("1 not in 2"), [_H, HOGQL_BYTECODE_VERSION, op.INTEGER, 2, op.INTEGER, 1, op.NOT_IN] ) - self.assertEqual(to_bytecode("1 in 2"), [_H, op.INTEGER, 2, op.INTEGER, 1, op.IN]) - self.assertEqual(to_bytecode("1 not in 2"), [_H, op.INTEGER, 2, op.INTEGER, 1, op.NOT_IN]) self.assertEqual( to_bytecode("'string' ~ 'regex'"), - [_H, op.STRING, "regex", op.STRING, "string", op.REGEX], + [_H, HOGQL_BYTECODE_VERSION, op.STRING, "regex", op.STRING, "string", op.REGEX], ) self.assertEqual( to_bytecode("'string' =~ 'regex'"), - [_H, op.STRING, "regex", op.STRING, "string", op.REGEX], + [_H, HOGQL_BYTECODE_VERSION, op.STRING, "regex", op.STRING, "string", op.REGEX], ) self.assertEqual( to_bytecode("'string' !~ 'regex'"), - [_H, op.STRING, "regex", op.STRING, "string", op.NOT_REGEX], + [_H, HOGQL_BYTECODE_VERSION, op.STRING, "regex", op.STRING, "string", op.NOT_REGEX], ) self.assertEqual( to_bytecode("'string' ~* 'regex'"), - [_H, op.STRING, "regex", op.STRING, "string", op.IREGEX], + [_H, HOGQL_BYTECODE_VERSION, op.STRING, "regex", op.STRING, "string", op.IREGEX], ) self.assertEqual( to_bytecode("'string' =~* 'regex'"), - [_H, op.STRING, "regex", op.STRING, "string", op.IREGEX], + [_H, HOGQL_BYTECODE_VERSION, op.STRING, "regex", op.STRING, "string", op.IREGEX], ) self.assertEqual( to_bytecode("'string' !~* 'regex'"), - [_H, op.STRING, "regex", op.STRING, "string", op.NOT_IREGEX], + [_H, HOGQL_BYTECODE_VERSION, op.STRING, "regex", op.STRING, "string", op.NOT_IREGEX], ) self.assertEqual( to_bytecode("match('test', 'e.*')"), - [_H, op.STRING, "e.*", op.STRING, "test", op.CALL_GLOBAL, "match", 2], + [_H, HOGQL_BYTECODE_VERSION, op.STRING, "test", op.STRING, "e.*", op.CALL_GLOBAL, "match", 2], ) self.assertEqual( to_bytecode("match('test', '^e.*')"), - [_H, op.STRING, "^e.*", op.STRING, "test", op.CALL_GLOBAL, "match", 2], + [_H, HOGQL_BYTECODE_VERSION, op.STRING, "test", op.STRING, "^e.*", op.CALL_GLOBAL, "match", 2], ) self.assertEqual( to_bytecode("match('test', 'x.*')"), - [_H, op.STRING, "x.*", op.STRING, "test", op.CALL_GLOBAL, "match", 2], + [_H, HOGQL_BYTECODE_VERSION, op.STRING, "test", op.STRING, "x.*", op.CALL_GLOBAL, "match", 2], ) - self.assertEqual(to_bytecode("not('test')"), [_H, op.STRING, "test", op.NOT]) - self.assertEqual(to_bytecode("not 'test'"), [_H, op.STRING, "test", op.NOT]) + self.assertEqual(to_bytecode("not('test')"), [_H, HOGQL_BYTECODE_VERSION, op.STRING, "test", op.NOT]) + self.assertEqual(to_bytecode("not 'test'"), [_H, HOGQL_BYTECODE_VERSION, op.STRING, "test", op.NOT]) self.assertEqual( to_bytecode("or('test', 'test2')"), - [_H, op.STRING, "test2", op.STRING, "test", op.OR, 2], + [_H, HOGQL_BYTECODE_VERSION, op.STRING, "test", op.STRING, "test2", op.OR, 2], ) self.assertEqual( to_bytecode("and('test', 'test2')"), - [_H, op.STRING, "test2", op.STRING, "test", op.AND, 2], + [_H, HOGQL_BYTECODE_VERSION, op.STRING, "test", op.STRING, "test2", op.AND, 2], ) @pytest.mark.skip(reason="C++ parsing is not working for these cases yet.") def test_bytecode_objects(self): self.assertEqual( to_bytecode("[1, 2, 3]"), - [_H, op.INTEGER, 1, op.INTEGER, 2, op.INTEGER, 3, op.ARRAY, 3], + [_H, HOGQL_BYTECODE_VERSION, op.INTEGER, 1, op.INTEGER, 2, op.INTEGER, 3, op.ARRAY, 3], ) self.assertEqual( to_bytecode("[1, 2, 3][1]"), - [_H, op.INTEGER, 1, op.INTEGER, 2, op.INTEGER, 3, op.ARRAY, 3, op.INTEGER, 1, op.GET_PROPERTY, 1], + [ + _H, + HOGQL_BYTECODE_VERSION, + op.INTEGER, + 1, + op.INTEGER, + 2, + op.INTEGER, + 3, + op.ARRAY, + 3, + op.INTEGER, + 1, + op.GET_PROPERTY, + 1, + ], ) self.assertEqual( to_bytecode("{'a': 'b'}"), - [_H, op.STRING, "a", op.STRING, "b", op.DICT, 1], + [_H, HOGQL_BYTECODE_VERSION, op.STRING, "a", op.STRING, "b", op.DICT, 1], ) self.assertEqual( to_bytecode("{'a': 'b', 'c': 'd'}"), - [_H, op.STRING, "a", op.STRING, "b", op.STRING, "c", op.STRING, "d", op.DICT, 2], + [_H, HOGQL_BYTECODE_VERSION, op.STRING, "a", op.STRING, "b", op.STRING, "c", op.STRING, "d", op.DICT, 2], ) self.assertEqual( to_bytecode("{'a': 'b', 'c': {'a': 'b'}}"), [ _H, + HOGQL_BYTECODE_VERSION, op.STRING, "a", op.STRING, @@ -181,11 +204,11 @@ def test_bytecode_objects(self): ) self.assertEqual( to_bytecode("['a', 'b']"), - [_H, op.STRING, "a", op.STRING, "b", op.ARRAY, 2], + [_H, HOGQL_BYTECODE_VERSION, op.STRING, "a", op.STRING, "b", op.ARRAY, 2], ) self.assertEqual( to_bytecode("('a', 'b')"), - [_H, op.STRING, "a", op.STRING, "b", op.TUPLE, 2], + [_H, HOGQL_BYTECODE_VERSION, op.STRING, "a", op.STRING, "b", op.TUPLE, 2], ) def test_bytecode_create_not_implemented_error(self): diff --git a/posthog/management/commands/test/test_migrate_action_webhooks.py b/posthog/management/commands/test/test_migrate_action_webhooks.py index 52e625a0610d5..45f6a393b2809 100644 --- a/posthog/management/commands/test/test_migrate_action_webhooks.py +++ b/posthog/management/commands/test/test_migrate_action_webhooks.py @@ -1,4 +1,6 @@ from inline_snapshot import snapshot + +from hogvm.python.operation import HOGQL_BYTECODE_VERSION from posthog.cdp.templates.webhook.template_webhook import template as template_webhook from posthog.management.commands.migrate_action_webhooks import migrate_action_webhooks from posthog.models.action.action import Action @@ -54,7 +56,7 @@ def test_migrates_base_action_config_correctly(self): assert hog_function.name == f"Webhook for action {self.action.id} (Test Action)" assert hog_function.filters == { "actions": [{"id": f"{self.action.id}", "name": "Test Action", "type": "actions", "order": 0}], - "bytecode": ["_h", 29, 3, 1, 4, 1], + "bytecode": ["_H", HOGQL_BYTECODE_VERSION, 29, 3, 1, 4, 1], } assert hog_function.hog == template_webhook.hog assert hog_function.inputs_schema == template_webhook.inputs_schema diff --git a/posthog/management/commands/test/test_migrate_hooks.py b/posthog/management/commands/test/test_migrate_hooks.py index 90910c915c469..62841f0785c2f 100644 --- a/posthog/management/commands/test/test_migrate_hooks.py +++ b/posthog/management/commands/test/test_migrate_hooks.py @@ -1,4 +1,5 @@ from ee.models.hook import Hook +from hogvm.python.operation import HOGQL_BYTECODE_VERSION from posthog.cdp.templates.zapier.template_zapier import template as template_zapier from posthog.management.commands.migrate_hooks import migrate_hooks from posthog.models.action.action import Action @@ -54,7 +55,7 @@ def test_migrates_hook_correctly(self): assert hog_function.name == f"Zapier webhook for action {self.action.id}" assert hog_function.filters == { "actions": [{"id": f"{self.action.id}", "name": "", "type": "actions", "order": 0}], - "bytecode": ["_h", 29, 3, 1, 4, 1], + "bytecode": ["_H", HOGQL_BYTECODE_VERSION, 29, 3, 1, 4, 1], } assert hog_function.hog == template_zapier.hog assert hog_function.inputs_schema == template_zapier.inputs_schema diff --git a/posthog/models/test/test_hog_function.py b/posthog/models/test/test_hog_function.py index 02bc9fb62e3c6..e36284fe796dc 100644 --- a/posthog/models/test/test_hog_function.py +++ b/posthog/models/test/test_hog_function.py @@ -2,6 +2,7 @@ from django.test import TestCase from inline_snapshot import snapshot +from hogvm.python.operation import HOGQL_BYTECODE_VERSION from posthog.models.action.action import Action from posthog.models.hog_functions.hog_function import HogFunction from posthog.models.user import User @@ -30,7 +31,7 @@ def test_hog_function_team_no_filters_compilation(self): # Some json serialization is needed to compare the bytecode more easily in tests json_filters = to_dict(item.filters) - assert json_filters["bytecode"] == ["_h", 29] # TRUE + assert json_filters["bytecode"] == ["_H", HOGQL_BYTECODE_VERSION, 29] # TRUE def test_hog_function_filters_compilation(self): item = HogFunction.objects.create( @@ -51,7 +52,8 @@ def test_hog_function_filters_compilation(self): "actions": [{"id": "9", "name": "Test Action", "type": "actions", "order": 1}], "filter_test_accounts": True, "bytecode": [ - "_h", + "_H", + HOGQL_BYTECODE_VERSION, 33, 2, 33, @@ -126,7 +128,7 @@ def test_hog_function_team_filters_only_compilation(self): json_filters = to_dict(item.filters) assert json.dumps(json_filters["bytecode"]) == snapshot( - '["_h", 32, "^(localhost|127\\\\.0\\\\.0\\\\.1)($|:)", 32, "$host", 32, "properties", 1, 2, 2, "toString", 1, 2, "match", 2, 5, 47, 3, 35, 33, 1, 3, 1]' + f'["_H", {HOGQL_BYTECODE_VERSION}, 32, "^(localhost|127\\\\.0\\\\.0\\\\.1)($|:)", 32, "$host", 32, "properties", 1, 2, 2, "toString", 1, 2, "match", 2, 5, 47, 3, 35, 33, 1, 3, 1]' ) @@ -197,11 +199,11 @@ def test_hog_functions_reload_on_action_saved(self): # Check that the bytecode is correct assert json.dumps(hog_function_1.filters["bytecode"]) == snapshot( - '["_h", 32, "old-value-2", 32, "prop-2", 32, "properties", 1, 2, 11, 3, 1, 32, "old-value-1", 32, "prop-1", 32, "properties", 1, 2, 11, 32, "test-event", 32, "event", 1, 1, 11, 3, 2, 3, 1, 4, 2]' + f'["_H", {HOGQL_BYTECODE_VERSION}, 32, "old-value-2", 32, "prop-2", 32, "properties", 1, 2, 11, 3, 1, 32, "old-value-1", 32, "prop-1", 32, "properties", 1, 2, 11, 32, "test-event", 32, "event", 1, 1, 11, 3, 2, 3, 1, 4, 2]' ) assert json.dumps(hog_function_2.filters["bytecode"]) == snapshot( - '["_h", 32, "old-value-1", 32, "prop-1", 32, "properties", 1, 2, 11, 32, "test-event", 32, "event", 1, 1, 11, 3, 2, 3, 1, 4, 1]' + f'["_H", {HOGQL_BYTECODE_VERSION}, 32, "old-value-1", 32, "prop-1", 32, "properties", 1, 2, 11, 32, "test-event", 32, "event", 1, 1, 11, 3, 2, 3, 1, 4, 1]' ) # Modify the action and check that the bytecode is updated @@ -225,10 +227,10 @@ def test_hog_functions_reload_on_action_saved(self): hog_function_2.refresh_from_db() assert json.dumps(hog_function_1.filters["bytecode"]) == snapshot( - '["_h", 32, "old-value-2", 32, "prop-2", 32, "properties", 1, 2, 11, 3, 1, 32, "change-value", 32, "prop-1", 32, "properties", 1, 2, 11, 32, "test-event", 32, "event", 1, 1, 11, 3, 2, 3, 1, 4, 2]' + f'["_H", {HOGQL_BYTECODE_VERSION}, 32, "old-value-2", 32, "prop-2", 32, "properties", 1, 2, 11, 3, 1, 32, "change-value", 32, "prop-1", 32, "properties", 1, 2, 11, 32, "test-event", 32, "event", 1, 1, 11, 3, 2, 3, 1, 4, 2]' ) assert json.dumps(hog_function_2.filters["bytecode"]) == snapshot( - '["_h", 32, "change-value", 32, "prop-1", 32, "properties", 1, 2, 11, 32, "test-event", 32, "event", 1, 1, 11, 3, 2, 3, 1, 4, 1]' + f'["_H", {HOGQL_BYTECODE_VERSION}, 32, "change-value", 32, "prop-1", 32, "properties", 1, 2, 11, 32, "test-event", 32, "event", 1, 1, 11, 3, 2, 3, 1, 4, 1]' ) def test_hog_functions_reload_on_team_saved(self): @@ -260,7 +262,7 @@ def test_hog_functions_reload_on_team_saved(self): # Check that the bytecode is correct assert json.dumps(hog_function_1.filters["bytecode"]) == snapshot('["_h", 29]') assert json.dumps(hog_function_2.filters["bytecode"]) == snapshot( - '["_h", 32, "$pageview", 32, "event", 1, 1, 11, 3, 1, 4, 1]' + f'["_H", {HOGQL_BYTECODE_VERSION}, 32, "$pageview", 32, "event", 1, 1, 11, 3, 1, 4, 1]' ) assert json.dumps(hog_function_3.filters["bytecode"]) == snapshot('["_h", 29]') @@ -277,9 +279,9 @@ def test_hog_functions_reload_on_team_saved(self): hog_function_3.refresh_from_db() assert json.dumps(hog_function_1.filters["bytecode"]) == snapshot( - '["_h", 32, "test", 32, "$pageview", 32, "properties", 1, 2, 2, "toString", 1, 2, "match", 2, 47, 3, 35, 33, 0, 32, "^(localhost|127\\\\.0\\\\.0\\\\.1)($|:)", 32, "$host", 32, "properties", 1, 2, 2, "toString", 1, 2, "match", 2, 47, 3, 35, 33, 0, 3, 2]' + f'["_H", {HOGQL_BYTECODE_VERSION}, 32, "test", 32, "$pageview", 32, "properties", 1, 2, 2, "toString", 1, 2, "match", 2, 47, 3, 35, 33, 0, 32, "^(localhost|127\\\\.0\\\\.0\\\\.1)($|:)", 32, "$host", 32, "properties", 1, 2, 2, "toString", 1, 2, "match", 2, 47, 3, 35, 33, 0, 3, 2]' ) assert json.dumps(hog_function_2.filters["bytecode"]) == snapshot( - '["_h", 32, "$pageview", 32, "event", 1, 1, 11, 32, "test", 32, "$pageview", 32, "properties", 1, 2, 2, "toString", 1, 2, "match", 2, 47, 3, 35, 33, 0, 32, "^(localhost|127\\\\.0\\\\.0\\\\.1)($|:)", 32, "$host", 32, "properties", 1, 2, 2, "toString", 1, 2, "match", 2, 47, 3, 35, 33, 0, 3, 3, 4, 1]' + f'["_H", {HOGQL_BYTECODE_VERSION}, 32, "$pageview", 32, "event", 1, 1, 11, 32, "test", 32, "$pageview", 32, "properties", 1, 2, 2, "toString", 1, 2, "match", 2, 47, 3, 35, 33, 0, 32, "^(localhost|127\\\\.0\\\\.0\\\\.1)($|:)", 32, "$host", 32, "properties", 1, 2, 2, "toString", 1, 2, "match", 2, 47, 3, 35, 33, 0, 3, 3, 4, 1]' ) assert json.dumps(hog_function_3.filters["bytecode"]) == snapshot('["_h", 29]') From e2b55d07f6b925a44e30f1de646dc44ca1468d33 Mon Sep 17 00:00:00 2001 From: Marius Andra Date: Tue, 27 Aug 2024 10:25:45 +0200 Subject: [PATCH 15/21] even more test fixes --- .../cdp-function-callbacks-consumer.test.ts | 12 +- .../cdp/cdp-processed-events-consumer.test.ts | 2 +- plugin-server/tests/cdp/fixtures.ts | 10 ++ plugin-server/tests/cdp/hog-executor.test.ts | 19 ++- posthog/cdp/test/test_filters.py | 146 +++++++++--------- posthog/cdp/test/test_validation.py | 35 ++++- 6 files changed, 138 insertions(+), 86 deletions(-) diff --git a/plugin-server/tests/cdp/cdp-function-callbacks-consumer.test.ts b/plugin-server/tests/cdp/cdp-function-callbacks-consumer.test.ts index 54f052fe439d4..7ef3cbe515287 100644 --- a/plugin-server/tests/cdp/cdp-function-callbacks-consumer.test.ts +++ b/plugin-server/tests/cdp/cdp-function-callbacks-consumer.test.ts @@ -111,6 +111,14 @@ describe('CDP Processed Events Consuner', () => { $lib_version: '1.0.0', }, }, + groups: {}, + person: { + uuid: 'b3a1fe86-b10c-43cc-acaf-d208977608d0', + distinct_ids: ['b3a1fe86-b10c-43cc-acaf-d208977608d0'], + properties: { + email: 'test@posthog.com', + }, + }, } beforeEach(async () => { @@ -161,7 +169,7 @@ describe('CDP Processed Events Consuner', () => { }, { level: 'debug', - message: "Suspending function due to async function call 'fetch'. Payload: 1140 bytes", + message: "Suspending function due to async function call 'fetch'. Payload: 1639 bytes", }, { level: 'info', @@ -209,7 +217,7 @@ describe('CDP Processed Events Consuner', () => { }, { level: 'debug', - message: "Suspending function due to async function call 'fetch'. Payload: 1140 bytes", + message: "Suspending function due to async function call 'fetch'. Payload: 1639 bytes", }, { level: 'debug', diff --git a/plugin-server/tests/cdp/cdp-processed-events-consumer.test.ts b/plugin-server/tests/cdp/cdp-processed-events-consumer.test.ts index 4de26bd05fca0..56a68bc485cd1 100644 --- a/plugin-server/tests/cdp/cdp-processed-events-consumer.test.ts +++ b/plugin-server/tests/cdp/cdp-processed-events-consumer.test.ts @@ -211,7 +211,7 @@ describe('CDP Processed Events Consuner', () => { topic: 'log_entries_test', value: { log_source: 'hog_function', - message: "Suspending function due to async function call 'fetch'. Payload: 1497 bytes", + message: "Suspending function due to async function call 'fetch'. Payload: 1805 bytes", team_id: 2, }, }) diff --git a/plugin-server/tests/cdp/fixtures.ts b/plugin-server/tests/cdp/fixtures.ts index b70af8efe3c39..8643212fe522b 100644 --- a/plugin-server/tests/cdp/fixtures.ts +++ b/plugin-server/tests/cdp/fixtures.ts @@ -100,6 +100,16 @@ export const createHogExecutionGlobals = ( ): HogFunctionInvocationGlobals => { return { ...data, + groups: data.groups ?? {}, + person: { + uuid: 'uuid', + name: 'test', + url: 'http://localhost:8000/persons/1', + properties: { + $lib_version: '1.2.3', + }, + ...(data.person ?? {}), + }, project: { id: 1, name: 'test', diff --git a/plugin-server/tests/cdp/hog-executor.test.ts b/plugin-server/tests/cdp/hog-executor.test.ts index ae5203f6415b0..07966689f6197 100644 --- a/plugin-server/tests/cdp/hog-executor.test.ts +++ b/plugin-server/tests/cdp/hog-executor.test.ts @@ -87,7 +87,7 @@ describe('Hog Executor', () => { { timestamp: expect.any(DateTime), level: 'debug', - message: "Suspending function due to async function call 'fetch'. Payload: 1299 bytes", + message: "Suspending function due to async function call 'fetch'. Payload: 1764 bytes", }, ]) }) @@ -163,9 +163,14 @@ describe('Hog Executor', () => { properties: { $lib_version: '1.2.3' }, timestamp: '2024-06-07T12:00:00.000Z', }, - groups: null, + groups: {}, nested: { foo: 'http://localhost:8000/events/1' }, - person: null, + person: { + uuid: 'uuid', + name: 'test', + url: 'http://localhost:8000/persons/1', + properties: { $lib_version: '1.2.3' }, + }, event_url: 'http://localhost:8000/events/1-test', }, method: 'POST', @@ -191,10 +196,10 @@ describe('Hog Executor', () => { expect(asyncExecResult.finished).toBe(true) expect(logs.map((log) => log.message)).toEqual([ 'Executing function', - "Suspending function due to async function call 'fetch'. Payload: 1299 bytes", + "Suspending function due to async function call 'fetch'. Payload: 1764 bytes", 'Resuming function', 'Fetch response:, {"status":200,"body":"success"}', - 'Function completed in 100ms. Sync: 0ms. Mem: 589 bytes. Ops: 22.', + 'Function completed in 100ms. Sync: 0ms. Mem: 746 bytes. Ops: 22.', ]) }) @@ -219,10 +224,10 @@ describe('Hog Executor', () => { expect(asyncExecResult.finished).toBe(true) expect(logs.map((log) => log.message)).toEqual([ 'Executing function', - "Suspending function due to async function call 'fetch'. Payload: 1299 bytes", + "Suspending function due to async function call 'fetch'. Payload: 1764 bytes", 'Resuming function', 'Fetch response:, {"status":200,"body":{"foo":"bar"}}', // The body is parsed - 'Function completed in 100ms. Sync: 0ms. Mem: 589 bytes. Ops: 22.', + 'Function completed in 100ms. Sync: 0ms. Mem: 746 bytes. Ops: 22.', ]) }) }) diff --git a/posthog/cdp/test/test_filters.py b/posthog/cdp/test/test_filters.py index 8278dee55783d..b8c79da81290e 100644 --- a/posthog/cdp/test/test_filters.py +++ b/posthog/cdp/test/test_filters.py @@ -1,6 +1,7 @@ import json from inline_snapshot import snapshot +from hogvm.python.operation import HOGQL_BYTECODE_VERSION from posthog.cdp.filters import hog_function_filters_to_expr from posthog.hogql.bytecode import create_bytecode from posthog.models.action.action import Action @@ -63,7 +64,7 @@ def filters_to_bytecode(self, filters: dict): return json.loads(json.dumps(create_bytecode(res))) def test_filters_empty(self): - assert self.filters_to_bytecode(filters={}) == snapshot(["_h", 29]) + assert self.filters_to_bytecode(filters={}) == snapshot(["_H", HOGQL_BYTECODE_VERSION, 29]) def test_filters_all_events(self): assert self.filters_to_bytecode( @@ -77,12 +78,21 @@ def test_filters_all_events(self): } ] } - ) == snapshot(["_h", 3, 0, 29, 4, 2]) + ) == snapshot(["_H", HOGQL_BYTECODE_VERSION, 29, 3, 0, 4, 2]) def test_filters_events(self): - assert self.filters_to_bytecode(filters={"events": self.filters["events"]}) == snapshot( + bytecode = self.filters_to_bytecode(filters={"events": self.filters["events"]}) + assert bytecode == snapshot( [ - "_h", + "_H", + HOGQL_BYTECODE_VERSION, + 32, + "$pageview", + 32, + "event", + 1, + 1, + 11, 32, "%docs%", 32, @@ -92,13 +102,6 @@ def test_filters_events(self): 1, 2, 18, - 32, - "$pageview", - 32, - "event", - 1, - 1, - 11, 3, 2, 4, @@ -107,9 +110,18 @@ def test_filters_events(self): ) def test_filters_actions(self): - assert self.filters_to_bytecode(filters={"actions": self.filters["actions"]}) == snapshot( + bytecode = self.filters_to_bytecode(filters={"actions": self.filters["actions"]}) + assert bytecode == snapshot( [ - "_h", + "_H", + HOGQL_BYTECODE_VERSION, + 32, + "$pageview", + 32, + "event", + 1, + 1, + 11, 32, "%docs%", 32, @@ -119,13 +131,6 @@ def test_filters_actions(self): 1, 2, 17, - 32, - "$pageview", - 32, - "event", - 1, - 1, - 11, 3, 2, 3, @@ -138,67 +143,52 @@ def test_filters_actions(self): def test_filters_properties(self): assert self.filters_to_bytecode(filters={"properties": self.filters["properties"]}) == snapshot( [ - "_h", + "_H", + HOGQL_BYTECODE_VERSION, 32, - "ben", + "%@posthog.com%", 32, - "name", + "email", 32, "properties", 32, "person", 1, 3, - 11, + 18, 32, - "%@posthog.com%", + "ben", 32, - "email", + "name", 32, "properties", 32, "person", 1, 3, - 18, + 11, 3, 2, ] ) def test_filters_full(self): - assert self.filters_to_bytecode(filters=self.filters) == snapshot( + bytecode = self.filters_to_bytecode(filters=self.filters) + assert bytecode == snapshot( [ - "_h", - 32, - "%docs%", - 32, - "$current_url", - 32, - "properties", - 1, - 2, - 17, + "_H", + HOGQL_BYTECODE_VERSION, 32, - "$pageview", - 32, - "event", - 1, - 1, - 11, - 3, - 2, - 32, - "ben", + "%@posthog.com%", 32, - "name", + "email", 32, "properties", 32, "person", 1, 3, - 11, + 20, 32, "%@posthog.com%", 32, @@ -211,18 +201,23 @@ def test_filters_full(self): 3, 18, 32, - "%@posthog.com%", + "ben", 32, - "email", + "name", 32, "properties", 32, "person", 1, 3, - 20, - 3, - 4, + 11, + 32, + "$pageview", + 32, + "event", + 1, + 1, + 11, 32, "%docs%", 32, @@ -232,24 +227,19 @@ def test_filters_full(self): 1, 2, 18, + 3, + 5, 32, - "$pageview", - 32, - "event", - 1, - 1, - 11, - 32, - "ben", + "%@posthog.com%", 32, - "name", + "email", 32, "properties", 32, "person", 1, 3, - 11, + 20, 32, "%@posthog.com%", 32, @@ -262,18 +252,36 @@ def test_filters_full(self): 3, 18, 32, - "%@posthog.com%", + "ben", 32, - "email", + "name", 32, "properties", 32, "person", 1, 3, - 20, + 11, + 32, + "$pageview", + 32, + "event", + 1, + 1, + 11, + 32, + "%docs%", + 32, + "$current_url", + 32, + "properties", + 1, + 2, + 17, 3, - 5, + 2, + 3, + 4, 4, 2, ] diff --git a/posthog/cdp/test/test_validation.py b/posthog/cdp/test/test_validation.py index 90428c9dd574a..06d801e830b71 100644 --- a/posthog/cdp/test/test_validation.py +++ b/posthog/cdp/test/test_validation.py @@ -2,6 +2,7 @@ from inline_snapshot import snapshot +from hogvm.python.operation import HOGQL_BYTECODE_VERSION from posthog.cdp.validation import validate_inputs, validate_inputs_schema from posthog.test.base import APIBaseTest, ClickhouseTestMixin, QueryMatchingTest @@ -78,7 +79,12 @@ def test_validate_inputs(self): { "url": { "value": "http://localhost:2080/0e02d917-563f-4050-9725-aad881b69937", - "bytecode": ["_h", 32, "http://localhost:2080/0e02d917-563f-4050-9725-aad881b69937"], + "bytecode": [ + "_H", + HOGQL_BYTECODE_VERSION, + 32, + "http://localhost:2080/0e02d917-563f-4050-9725-aad881b69937", + ], }, "payload": { "value": { @@ -89,11 +95,25 @@ def test_validate_inputs(self): "event_url": "{f'{event.url}-test'}", }, "bytecode": { - "event": ["_h", 32, "event", 1, 1], - "groups": ["_h", 32, "groups", 1, 1], - "nested": {"foo": ["_h", 32, "url", 32, "event", 1, 2]}, - "person": ["_h", 32, "person", 1, 1], - "event_url": ["_h", 32, "-test", 32, "url", 32, "event", 1, 2, 2, "concat", 2], + "event": ["_H", HOGQL_BYTECODE_VERSION, 32, "event", 1, 1], + "groups": ["_H", HOGQL_BYTECODE_VERSION, 32, "groups", 1, 1], + "nested": {"foo": ["_H", HOGQL_BYTECODE_VERSION, 32, "url", 32, "event", 1, 2]}, + "person": ["_H", HOGQL_BYTECODE_VERSION, 32, "person", 1, 1], + "event_url": [ + "_H", + HOGQL_BYTECODE_VERSION, + 32, + "-test", + 32, + "url", + 32, + "event", + 1, + 2, + 2, + "concat", + 2, + ], }, }, "method": {"value": "POST"}, @@ -140,7 +160,8 @@ def test_validate_inputs_creates_bytecode_for_html(self): { "html": { "bytecode": [ - "_h", + "_H", + HOGQL_BYTECODE_VERSION, 32, "

\n\n", 32, From 68937302835d40b66d80f588ef284202abb1c7cb Mon Sep 17 00:00:00 2001 From: Marius Andra Date: Tue, 27 Aug 2024 10:29:06 +0200 Subject: [PATCH 16/21] even more test fixes --- posthog/api/test/test_hog_function.py | 4 ++-- posthog/cdp/templates/test_cdp_templates.py | 2 +- posthog/cdp/test/test_validation.py | 15 ++++++++------- 3 files changed, 11 insertions(+), 10 deletions(-) diff --git a/posthog/api/test/test_hog_function.py b/posthog/api/test/test_hog_function.py index 813ee45bddec3..f62a96714a311 100644 --- a/posthog/api/test/test_hog_function.py +++ b/posthog/api/test/test_hog_function.py @@ -380,6 +380,8 @@ def test_generates_inputs_bytecode(self, *args): "_H", HOGQL_BYTECODE_VERSION, 32, + "v=", + 32, "$lib_version", 32, "properties", @@ -387,8 +389,6 @@ def test_generates_inputs_bytecode(self, *args): "event", 1, 3, - 32, - "v=", 2, "concat", 2, diff --git a/posthog/cdp/templates/test_cdp_templates.py b/posthog/cdp/templates/test_cdp_templates.py index 21d5d841b3a9d..889f7431e33a1 100644 --- a/posthog/cdp/templates/test_cdp_templates.py +++ b/posthog/cdp/templates/test_cdp_templates.py @@ -10,5 +10,5 @@ def setUp(self): def test_templates_are_valid(self): for template in HOG_FUNCTION_TEMPLATES: bytecode = compile_hog(template.hog) - assert bytecode[0] == "_h" + assert bytecode[0] == "_H" assert validate_inputs_schema(template.inputs_schema) diff --git a/posthog/cdp/test/test_validation.py b/posthog/cdp/test/test_validation.py index 06d801e830b71..90a41f8cca653 100644 --- a/posthog/cdp/test/test_validation.py +++ b/posthog/cdp/test/test_validation.py @@ -103,13 +103,13 @@ def test_validate_inputs(self): "_H", HOGQL_BYTECODE_VERSION, 32, - "-test", - 32, "url", 32, "event", 1, 2, + 32, + "-test", 2, "concat", 2, @@ -121,7 +121,10 @@ def test_validate_inputs(self): "value": {"version": "v={event.properties.$lib_version}"}, "bytecode": { "version": [ - "_h", + "_H", + HOGQL_BYTECODE_VERSION, + 32, + "v=", 32, "$lib_version", 32, @@ -130,8 +133,6 @@ def test_validate_inputs(self): "event", 1, 3, - 32, - "v=", 2, "concat", 2, @@ -163,7 +164,7 @@ def test_validate_inputs_creates_bytecode_for_html(self): "_H", HOGQL_BYTECODE_VERSION, 32, - "

\n\n", + '\n\n\n\n\n\n

Hi ', 32, "email", 32, @@ -173,7 +174,7 @@ def test_validate_inputs_creates_bytecode_for_html(self): 1, 3, 32, - '\n\n\n\n\n\n

Hi ', + "

\n\n", 2, "concat", 3, From 87b22c1235ae4789c815b918cbe7757f4b5319b0 Mon Sep 17 00:00:00 2001 From: Marius Andra Date: Tue, 27 Aug 2024 10:44:17 +0200 Subject: [PATCH 17/21] still some more test fixes --- posthog/models/test/test_hog_function.py | 43 ++++++++++++------------ 1 file changed, 21 insertions(+), 22 deletions(-) diff --git a/posthog/models/test/test_hog_function.py b/posthog/models/test/test_hog_function.py index e36284fe796dc..95d53f916a6c9 100644 --- a/posthog/models/test/test_hog_function.py +++ b/posthog/models/test/test_hog_function.py @@ -46,7 +46,6 @@ def test_hog_function_filters_compilation(self): # Some json serialization is needed to compare the bytecode more easily in tests json_filters = to_dict(item.filters) - assert json_filters == { "events": [{"id": "$pageview", "name": "$pageview", "type": "events", "order": 0}], "actions": [{"id": "9", "name": "Test Action", "type": "actions", "order": 1}], @@ -54,13 +53,6 @@ def test_hog_function_filters_compilation(self): "bytecode": [ "_H", HOGQL_BYTECODE_VERSION, - 33, - 2, - 33, - 1, - 11, - 32, - "^(localhost|127\\.0\\.0\\.1)($|:)", 32, "$host", 32, @@ -70,6 +62,8 @@ def test_hog_function_filters_compilation(self): 2, "toString", 1, + 32, + "^(localhost|127\\.0\\.0\\.1)($|:)", 2, "match", 2, @@ -79,8 +73,6 @@ def test_hog_function_filters_compilation(self): 35, 33, 1, - 3, - 2, 32, "$pageview", 32, @@ -88,8 +80,8 @@ def test_hog_function_filters_compilation(self): 1, 1, 11, - 32, - "^(localhost|127\\.0\\.0\\.1)($|:)", + 3, + 2, 32, "$host", 32, @@ -99,6 +91,8 @@ def test_hog_function_filters_compilation(self): 2, "toString", 1, + 32, + "^(localhost|127\\.0\\.0\\.1)($|:)", 2, "match", 2, @@ -108,6 +102,11 @@ def test_hog_function_filters_compilation(self): 35, 33, 1, + 33, + 2, + 33, + 1, + 11, 3, 2, 4, @@ -128,7 +127,7 @@ def test_hog_function_team_filters_only_compilation(self): json_filters = to_dict(item.filters) assert json.dumps(json_filters["bytecode"]) == snapshot( - f'["_H", {HOGQL_BYTECODE_VERSION}, 32, "^(localhost|127\\\\.0\\\\.0\\\\.1)($|:)", 32, "$host", 32, "properties", 1, 2, 2, "toString", 1, 2, "match", 2, 5, 47, 3, 35, 33, 1, 3, 1]' + f'["_H", {HOGQL_BYTECODE_VERSION}, 32, "$host", 32, "properties", 1, 2, 2, "toString", 1, 32, "^(localhost|127\\\\.0\\\\.0\\\\.1)($|:)", 2, "match", 2, 5, 47, 3, 35, 33, 1, 3, 1]' ) @@ -199,11 +198,11 @@ def test_hog_functions_reload_on_action_saved(self): # Check that the bytecode is correct assert json.dumps(hog_function_1.filters["bytecode"]) == snapshot( - f'["_H", {HOGQL_BYTECODE_VERSION}, 32, "old-value-2", 32, "prop-2", 32, "properties", 1, 2, 11, 3, 1, 32, "old-value-1", 32, "prop-1", 32, "properties", 1, 2, 11, 32, "test-event", 32, "event", 1, 1, 11, 3, 2, 3, 1, 4, 2]' + f'["_H", {HOGQL_BYTECODE_VERSION}, 32, "test-event", 32, "event", 1, 1, 11, 32, "old-value-1", 32, "prop-1", 32, "properties", 1, 2, 11, 3, 2, 3, 1, 32, "old-value-2", 32, "prop-2", 32, "properties", 1, 2, 11, 3, 1, 4, 2]' ) assert json.dumps(hog_function_2.filters["bytecode"]) == snapshot( - f'["_H", {HOGQL_BYTECODE_VERSION}, 32, "old-value-1", 32, "prop-1", 32, "properties", 1, 2, 11, 32, "test-event", 32, "event", 1, 1, 11, 3, 2, 3, 1, 4, 1]' + f'["_H", {HOGQL_BYTECODE_VERSION}, 32, "test-event", 32, "event", 1, 1, 11, 32, "old-value-1", 32, "prop-1", 32, "properties", 1, 2, 11, 3, 2, 3, 1, 4, 1]' ) # Modify the action and check that the bytecode is updated @@ -227,10 +226,10 @@ def test_hog_functions_reload_on_action_saved(self): hog_function_2.refresh_from_db() assert json.dumps(hog_function_1.filters["bytecode"]) == snapshot( - f'["_H", {HOGQL_BYTECODE_VERSION}, 32, "old-value-2", 32, "prop-2", 32, "properties", 1, 2, 11, 3, 1, 32, "change-value", 32, "prop-1", 32, "properties", 1, 2, 11, 32, "test-event", 32, "event", 1, 1, 11, 3, 2, 3, 1, 4, 2]' + f'["_H", {HOGQL_BYTECODE_VERSION}, 32, "test-event", 32, "event", 1, 1, 11, 32, "change-value", 32, "prop-1", 32, "properties", 1, 2, 11, 3, 2, 3, 1, 32, "old-value-2", 32, "prop-2", 32, "properties", 1, 2, 11, 3, 1, 4, 2]' ) assert json.dumps(hog_function_2.filters["bytecode"]) == snapshot( - f'["_H", {HOGQL_BYTECODE_VERSION}, 32, "change-value", 32, "prop-1", 32, "properties", 1, 2, 11, 32, "test-event", 32, "event", 1, 1, 11, 3, 2, 3, 1, 4, 1]' + f'["_H", {HOGQL_BYTECODE_VERSION}, 32, "test-event", 32, "event", 1, 1, 11, 32, "change-value", 32, "prop-1", 32, "properties", 1, 2, 11, 3, 2, 3, 1, 4, 1]' ) def test_hog_functions_reload_on_team_saved(self): @@ -260,11 +259,11 @@ def test_hog_functions_reload_on_team_saved(self): ) # Check that the bytecode is correct - assert json.dumps(hog_function_1.filters["bytecode"]) == snapshot('["_h", 29]') + assert json.dumps(hog_function_1.filters["bytecode"]) == snapshot(f'["_H", {HOGQL_BYTECODE_VERSION}, 29]') assert json.dumps(hog_function_2.filters["bytecode"]) == snapshot( f'["_H", {HOGQL_BYTECODE_VERSION}, 32, "$pageview", 32, "event", 1, 1, 11, 3, 1, 4, 1]' ) - assert json.dumps(hog_function_3.filters["bytecode"]) == snapshot('["_h", 29]') + assert json.dumps(hog_function_3.filters["bytecode"]) == snapshot(f'["_H", {HOGQL_BYTECODE_VERSION}, 29]') # Modify the action and check that the bytecode is updated self.team.test_account_filters = [ @@ -279,9 +278,9 @@ def test_hog_functions_reload_on_team_saved(self): hog_function_3.refresh_from_db() assert json.dumps(hog_function_1.filters["bytecode"]) == snapshot( - f'["_H", {HOGQL_BYTECODE_VERSION}, 32, "test", 32, "$pageview", 32, "properties", 1, 2, 2, "toString", 1, 2, "match", 2, 47, 3, 35, 33, 0, 32, "^(localhost|127\\\\.0\\\\.0\\\\.1)($|:)", 32, "$host", 32, "properties", 1, 2, 2, "toString", 1, 2, "match", 2, 47, 3, 35, 33, 0, 3, 2]' + f'["_H", {HOGQL_BYTECODE_VERSION}, 32, "$host", 32, "properties", 1, 2, 2, "toString", 1, 32, "^(localhost|127\\\\.0\\\\.0\\\\.1)($|:)", 2, "match", 2, 47, 3, 35, 33, 0, 32, "$pageview", 32, "properties", 1, 2, 2, "toString", 1, 32, "test", 2, "match", 2, 47, 3, 35, 33, 0, 3, 2]' ) assert json.dumps(hog_function_2.filters["bytecode"]) == snapshot( - f'["_H", {HOGQL_BYTECODE_VERSION}, 32, "$pageview", 32, "event", 1, 1, 11, 32, "test", 32, "$pageview", 32, "properties", 1, 2, 2, "toString", 1, 2, "match", 2, 47, 3, 35, 33, 0, 32, "^(localhost|127\\\\.0\\\\.0\\\\.1)($|:)", 32, "$host", 32, "properties", 1, 2, 2, "toString", 1, 2, "match", 2, 47, 3, 35, 33, 0, 3, 3, 4, 1]' + f'["_H", {HOGQL_BYTECODE_VERSION}, 32, "$host", 32, "properties", 1, 2, 2, "toString", 1, 32, "^(localhost|127\\\\.0\\\\.0\\\\.1)($|:)", 2, "match", 2, 47, 3, 35, 33, 0, 32, "$pageview", 32, "properties", 1, 2, 2, "toString", 1, 32, "test", 2, "match", 2, 47, 3, 35, 33, 0, 32, "$pageview", 32, "event", 1, 1, 11, 3, 3, 4, 1]' ) - assert json.dumps(hog_function_3.filters["bytecode"]) == snapshot('["_h", 29]') + assert json.dumps(hog_function_3.filters["bytecode"]) == snapshot(f'["_H", {HOGQL_BYTECODE_VERSION}, 29]') From ca29bafde49bf7bdee78f644ef53969105ddd134 Mon Sep 17 00:00:00 2001 From: Marius Andra Date: Tue, 27 Aug 2024 10:57:27 +0200 Subject: [PATCH 18/21] update byte sizes --- .../tests/cdp/cdp-function-callbacks-consumer.test.ts | 4 ++-- .../tests/cdp/cdp-processed-events-consumer.test.ts | 2 +- plugin-server/tests/cdp/hog-executor.test.ts | 6 +++--- 3 files changed, 6 insertions(+), 6 deletions(-) diff --git a/plugin-server/tests/cdp/cdp-function-callbacks-consumer.test.ts b/plugin-server/tests/cdp/cdp-function-callbacks-consumer.test.ts index 7ef3cbe515287..33559d108ace9 100644 --- a/plugin-server/tests/cdp/cdp-function-callbacks-consumer.test.ts +++ b/plugin-server/tests/cdp/cdp-function-callbacks-consumer.test.ts @@ -169,7 +169,7 @@ describe('CDP Processed Events Consuner', () => { }, { level: 'debug', - message: "Suspending function due to async function call 'fetch'. Payload: 1639 bytes", + message: "Suspending function due to async function call 'fetch'. Payload: 1331 bytes", }, { level: 'info', @@ -217,7 +217,7 @@ describe('CDP Processed Events Consuner', () => { }, { level: 'debug', - message: "Suspending function due to async function call 'fetch'. Payload: 1639 bytes", + message: "Suspending function due to async function call 'fetch'. Payload: 1331 bytes", }, { level: 'debug', diff --git a/plugin-server/tests/cdp/cdp-processed-events-consumer.test.ts b/plugin-server/tests/cdp/cdp-processed-events-consumer.test.ts index 56a68bc485cd1..4de26bd05fca0 100644 --- a/plugin-server/tests/cdp/cdp-processed-events-consumer.test.ts +++ b/plugin-server/tests/cdp/cdp-processed-events-consumer.test.ts @@ -211,7 +211,7 @@ describe('CDP Processed Events Consuner', () => { topic: 'log_entries_test', value: { log_source: 'hog_function', - message: "Suspending function due to async function call 'fetch'. Payload: 1805 bytes", + message: "Suspending function due to async function call 'fetch'. Payload: 1497 bytes", team_id: 2, }, }) diff --git a/plugin-server/tests/cdp/hog-executor.test.ts b/plugin-server/tests/cdp/hog-executor.test.ts index 07966689f6197..1bb0630c60da5 100644 --- a/plugin-server/tests/cdp/hog-executor.test.ts +++ b/plugin-server/tests/cdp/hog-executor.test.ts @@ -87,7 +87,7 @@ describe('Hog Executor', () => { { timestamp: expect.any(DateTime), level: 'debug', - message: "Suspending function due to async function call 'fetch'. Payload: 1764 bytes", + message: "Suspending function due to async function call 'fetch'. Payload: 1456 bytes", }, ]) }) @@ -196,7 +196,7 @@ describe('Hog Executor', () => { expect(asyncExecResult.finished).toBe(true) expect(logs.map((log) => log.message)).toEqual([ 'Executing function', - "Suspending function due to async function call 'fetch'. Payload: 1764 bytes", + "Suspending function due to async function call 'fetch'. Payload: 1456 bytes", 'Resuming function', 'Fetch response:, {"status":200,"body":"success"}', 'Function completed in 100ms. Sync: 0ms. Mem: 746 bytes. Ops: 22.', @@ -224,7 +224,7 @@ describe('Hog Executor', () => { expect(asyncExecResult.finished).toBe(true) expect(logs.map((log) => log.message)).toEqual([ 'Executing function', - "Suspending function due to async function call 'fetch'. Payload: 1764 bytes", + "Suspending function due to async function call 'fetch'. Payload: 1456 bytes", 'Resuming function', 'Fetch response:, {"status":200,"body":{"foo":"bar"}}', // The body is parsed 'Function completed in 100ms. Sync: 0ms. Mem: 746 bytes. Ops: 22.', From b932890e2bfa5df0e3dfae8f0c06dcc7a22c2d99 Mon Sep 17 00:00:00 2001 From: Marius Andra Date: Tue, 27 Aug 2024 11:23:08 +0200 Subject: [PATCH 19/21] fix groups manager test --- plugin-server/tests/cdp/fixtures.ts | 1 - 1 file changed, 1 deletion(-) diff --git a/plugin-server/tests/cdp/fixtures.ts b/plugin-server/tests/cdp/fixtures.ts index 8643212fe522b..8f3fed7da62dc 100644 --- a/plugin-server/tests/cdp/fixtures.ts +++ b/plugin-server/tests/cdp/fixtures.ts @@ -100,7 +100,6 @@ export const createHogExecutionGlobals = ( ): HogFunctionInvocationGlobals => { return { ...data, - groups: data.groups ?? {}, person: { uuid: 'uuid', name: 'test', From 3f115b1c63d5cf7255721192946e2890855d81de Mon Sep 17 00:00:00 2001 From: Marius Andra Date: Tue, 27 Aug 2024 15:52:48 +0200 Subject: [PATCH 20/21] fix some stuff --- plugin-server/tests/cdp/hog-executor.test.ts | 37 +++++++++++--------- 1 file changed, 20 insertions(+), 17 deletions(-) diff --git a/plugin-server/tests/cdp/hog-executor.test.ts b/plugin-server/tests/cdp/hog-executor.test.ts index 1bb0630c60da5..cce13921db1ad 100644 --- a/plugin-server/tests/cdp/hog-executor.test.ts +++ b/plugin-server/tests/cdp/hog-executor.test.ts @@ -58,9 +58,9 @@ describe('Hog Executor', () => { }) it('can execute messages', () => { - const globals = createHogExecutionGlobals() + const globals = createHogExecutionGlobals({ groups: {} }) const results = executor - .findMatchingFunctions(createHogExecutionGlobals()) + .findMatchingFunctions(createHogExecutionGlobals({ groups: {} })) .matchingFunctions.map((x) => executor.executeFunction(globals, x) as HogFunctionInvocationResult) expect(results).toHaveLength(1) expect(results[0]).toMatchObject({ @@ -74,9 +74,9 @@ describe('Hog Executor', () => { }) it('collects logs from the function', () => { - const globals = createHogExecutionGlobals() + const globals = createHogExecutionGlobals({ groups: {} }) const results = executor - .findMatchingFunctions(createHogExecutionGlobals()) + .findMatchingFunctions(createHogExecutionGlobals({ groups: {} })) .matchingFunctions.map((x) => executor.executeFunction(globals, x) as HogFunctionInvocationResult) expect(results[0].logs).toMatchObject([ { @@ -100,7 +100,10 @@ describe('Hog Executor', () => { mockFunctionManager.getTeamHogFunctions.mockReturnValue([fn]) - const result = executor.executeFunction(createHogExecutionGlobals(), fn) as HogFunctionInvocationResult + const result = executor.executeFunction( + createHogExecutionGlobals({ groups: {} }), + fn + ) as HogFunctionInvocationResult expect(result.logs.map((x) => x.message)).toMatchInlineSnapshot(` Array [ "Executing function", @@ -115,9 +118,9 @@ describe('Hog Executor', () => { }) it('queues up an async function call', () => { - const globals = createHogExecutionGlobals() + const globals = createHogExecutionGlobals({ groups: {} }) const results = executor - .findMatchingFunctions(createHogExecutionGlobals()) + .findMatchingFunctions(createHogExecutionGlobals({ groups: {} })) .matchingFunctions.map((x) => executor.executeFunction(globals, x) as HogFunctionInvocationResult) expect(results[0]).toMatchObject({ invocation: { @@ -182,9 +185,9 @@ describe('Hog Executor', () => { it('executes the full function in a loop', () => { const logs: LogEntry[] = [] - const globals = createHogExecutionGlobals() + const globals = createHogExecutionGlobals({ groups: {} }) const results = executor - .findMatchingFunctions(createHogExecutionGlobals()) + .findMatchingFunctions(createHogExecutionGlobals({ groups: {} })) .matchingFunctions.map((x) => executor.executeFunction(globals, x) as HogFunctionInvocationResult) const splicedLogs = results[0].logs.splice(0, 100) logs.push(...splicedLogs) @@ -205,9 +208,9 @@ describe('Hog Executor', () => { it('parses the responses body if a string', () => { const logs: LogEntry[] = [] - const globals = createHogExecutionGlobals() + const globals = createHogExecutionGlobals({ groups: {} }) const results = executor - .findMatchingFunctions(createHogExecutionGlobals()) + .findMatchingFunctions(createHogExecutionGlobals({ groups: {} })) .matchingFunctions.map((x) => executor.executeFunction(globals, x) as HogFunctionInvocationResult) const splicedLogs = results[0].logs.splice(0, 100) logs.push(...splicedLogs) @@ -242,7 +245,7 @@ describe('Hog Executor', () => { mockFunctionManager.getTeamHogFunctions.mockReturnValue([fn]) - const resultsShouldntMatch = executor.findMatchingFunctions(createHogExecutionGlobals()) + const resultsShouldntMatch = executor.findMatchingFunctions(createHogExecutionGlobals({ groups: {} })) expect(resultsShouldntMatch.matchingFunctions).toHaveLength(0) expect(resultsShouldntMatch.nonMatchingFunctions).toHaveLength(1) @@ -272,9 +275,9 @@ describe('Hog Executor', () => { mockFunctionManager.getTeamHogFunctions.mockReturnValue([fn]) // Simulate the recusive loop - const globals = createHogExecutionGlobals() + const globals = createHogExecutionGlobals({ groups: {} }) const results = executor - .findMatchingFunctions(createHogExecutionGlobals()) + .findMatchingFunctions(createHogExecutionGlobals({ groups: {} })) .matchingFunctions.map((x) => executor.executeFunction(globals, x) as HogFunctionInvocationResult) expect(results).toHaveLength(1) @@ -310,9 +313,9 @@ describe('Hog Executor', () => { mockFunctionManager.getTeamHogFunctions.mockReturnValue([fn]) - const globals = createHogExecutionGlobals() + const globals = createHogExecutionGlobals({ groups: {} }) const results = executor - .findMatchingFunctions(createHogExecutionGlobals()) + .findMatchingFunctions(createHogExecutionGlobals({ groups: {} })) .matchingFunctions.map((x) => executor.executeFunction(globals, x) as HogFunctionInvocationResult) expect(results).toHaveLength(1) expect(results[0].error).toContain('Execution timed out after 0.1 seconds. Performed ') @@ -344,7 +347,7 @@ describe('Hog Executor', () => { ...HOG_FILTERS_EXAMPLES.no_filters, }) - const globals = createHogExecutionGlobals() + const globals = createHogExecutionGlobals({ groups: {} }) const result = executor.executeFunction(globals, fn) expect(result?.capturedPostHogEvents).toEqual([ { From 5953566938305e12f70f385b2441c3973537cb9a Mon Sep 17 00:00:00 2001 From: Marius Andra Date: Tue, 27 Aug 2024 16:12:10 +0200 Subject: [PATCH 21/21] one more time... --- plugin-server/tests/cdp/hog-executor.test.ts | 2 ++ 1 file changed, 2 insertions(+) diff --git a/plugin-server/tests/cdp/hog-executor.test.ts b/plugin-server/tests/cdp/hog-executor.test.ts index cce13921db1ad..e8ac3d365cd9a 100644 --- a/plugin-server/tests/cdp/hog-executor.test.ts +++ b/plugin-server/tests/cdp/hog-executor.test.ts @@ -251,6 +251,7 @@ describe('Hog Executor', () => { const resultsShouldMatch = executor.findMatchingFunctions( createHogExecutionGlobals({ + groups: {}, event: { name: '$pageview', properties: { @@ -370,6 +371,7 @@ describe('Hog Executor', () => { }) const globals = createHogExecutionGlobals({ + groups: {}, event: { properties: { $hog_function_execution_count: 1,