From 0e15a447b18087ef1e4bbdd8e64b9e5345433bd7 Mon Sep 17 00:00:00 2001 From: Marcus Hof <13001502+MarconLP@users.noreply.github.com> Date: Tue, 29 Oct 2024 13:48:34 +0100 Subject: [PATCH 01/14] fix(cdp): fallback to hashing an empty string and filter out empty user data values (#25863) Co-authored-by: github-actions <41898282+github-actions[bot]@users.noreply.github.com> --- .../templates/meta_ads/template_meta_ads.py | 37 ++++++++++++------- .../meta_ads/test_template_meta_ads.py | 5 ++- 2 files changed, 27 insertions(+), 15 deletions(-) diff --git a/posthog/cdp/templates/meta_ads/template_meta_ads.py b/posthog/cdp/templates/meta_ads/template_meta_ads.py index 146166b14946d..0fb1631f90ea7 100644 --- a/posthog/cdp/templates/meta_ads/template_meta_ads.py +++ b/posthog/cdp/templates/meta_ads/template_meta_ads.py @@ -9,22 +9,31 @@ icon_url="/static/services/meta-ads.png", category=["Advertisement"], hog=""" +let body := { + 'data': [ + { + 'event_name': inputs.eventName, + 'event_time': inputs.eventTime, + 'action_source': inputs.actionSource, + 'user_data': {} + } + ], + 'access_token': inputs.accessToken +} + +for (let key, value in inputs.userData) { + // e3b0c44298fc1c149afbf4c8996fb92427ae41e4649b934ca495991b7852b855 is an empty string hashed + if (not empty(value) and value != 'e3b0c44298fc1c149afbf4c8996fb92427ae41e4649b934ca495991b7852b855') { + body.data.1.user_data[key] := value + } +} + let res := fetch(f'https://graph.facebook.com/v21.0/{inputs.pixelId}/events', { 'method': 'POST', 'headers': { 'Content-Type': 'application/json', }, - 'body': { - 'data': [ - { - 'event_name': inputs.eventName, - 'event_time': inputs.eventTime, - 'action_source': inputs.actionSource, - 'user_data': inputs.userData - } - ], - 'access_token': inputs.accessToken - } + 'body': body }) if (res.status >= 400) { throw Error(f'Error from graph.facebook.com (status {res.status}): {res.body}') @@ -118,9 +127,9 @@ "label": "User data", "description": "A map that contains customer information data. See this page for options: https://developers.facebook.com/docs/marketing-api/conversions-api/parameters/customer-information-parameters", "default": { - "em": "{sha256Hex(person.properties.email)}", - "fn": "{sha256Hex(person.properties.first_name)}", - "ln": "{sha256Hex(person.properties.last_name)}", + "em": "{sha256Hex(person.properties.email ?? '')}", + "fn": "{sha256Hex(person.properties.first_name ?? '')}", + "ln": "{sha256Hex(person.properties.last_name ?? '')}", }, "secret": False, "required": True, diff --git a/posthog/cdp/templates/meta_ads/test_template_meta_ads.py b/posthog/cdp/templates/meta_ads/test_template_meta_ads.py index 5d14328cec39d..df2405e1d026c 100644 --- a/posthog/cdp/templates/meta_ads/test_template_meta_ads.py +++ b/posthog/cdp/templates/meta_ads/test_template_meta_ads.py @@ -15,7 +15,10 @@ def _inputs(self, **kwargs): "eventName": "checkout", "eventTime": "1728812163", "actionSource": "website", - "userData": {"em": "3edfaed7454eedb3c72bad566901af8bfbed1181816dde6db91dfff0f0cffa98"}, + "userData": { + "em": "3edfaed7454eedb3c72bad566901af8bfbed1181816dde6db91dfff0f0cffa98", + "fn": "e3b0c44298fc1c149afbf4c8996fb92427ae41e4649b934ca495991b7852b855", + }, } inputs.update(kwargs) return inputs From 483358dd1f9edc2c4a0fbda35c804a72913cb005 Mon Sep 17 00:00:00 2001 From: Marcus Hof <13001502+MarconLP@users.noreply.github.com> Date: Tue, 29 Oct 2024 14:05:12 +0100 Subject: [PATCH 02/14] fix(cdp): run once per person per interval - correct person id (#25869) --- .../scenes/pipeline/hogfunctions/filters/HogFunctionFilters.tsx | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/frontend/src/scenes/pipeline/hogfunctions/filters/HogFunctionFilters.tsx b/frontend/src/scenes/pipeline/hogfunctions/filters/HogFunctionFilters.tsx index 50bf6bad4f4df..9dee4c767cc5e 100644 --- a/frontend/src/scenes/pipeline/hogfunctions/filters/HogFunctionFilters.tsx +++ b/frontend/src/scenes/pipeline/hogfunctions/filters/HogFunctionFilters.tsx @@ -158,7 +158,7 @@ export function HogFunctionFilters(): JSX.Element { label: 'Run once per interval', }, { - value: '{person.uuid}', + value: '{person.id}', label: 'Run once per person per interval', }, ]} From 30cfe5322e12909ff2c00402d1d0a82060eefde3 Mon Sep 17 00:00:00 2001 From: David Newell Date: Tue, 29 Oct 2024 16:16:59 +0000 Subject: [PATCH 03/14] chore: create ClickHouse override tables (#25681) --- plugin-server/src/config/kafka-topics.ts | 6 +- ...ingerprint_overrides_table_and_consumer.py | 12 +++ posthog/clickhouse/schema.py | 8 ++ .../test/__snapshots__/test_schema.ambr | 99 +++++++++++++++++++ posthog/conftest.py | 2 + .../test/__snapshots__/test_in_cohort.ambr | 8 +- posthog/kafka_client/topics.py | 5 +- posthog/models/error_tracking/sql.py | 79 +++++++++++++++ 8 files changed, 211 insertions(+), 8 deletions(-) create mode 100644 posthog/clickhouse/migrations/0083_add_error_tracking_issue_fingerprint_overrides_table_and_consumer.py create mode 100644 posthog/models/error_tracking/sql.py diff --git a/plugin-server/src/config/kafka-topics.ts b/plugin-server/src/config/kafka-topics.ts index d7ea527904477..8610bf8f0b819 100644 --- a/plugin-server/src/config/kafka-topics.ts +++ b/plugin-server/src/config/kafka-topics.ts @@ -38,8 +38,6 @@ export const KAFKA_CLICKHOUSE_SESSION_REPLAY_EVENTS = `${prefix}clickhouse_sessi export const KAFKA_PERFORMANCE_EVENTS = `${prefix}clickhouse_performance_events${suffix}` // write heatmap events to ClickHouse export const KAFKA_CLICKHOUSE_HEATMAP_EVENTS = `${prefix}clickhouse_heatmap_events${suffix}` -// write exception events to ClickHouse -export const KAFKA_EXCEPTION_SYMBOLIFICATION_EVENTS = `${prefix}exception_symbolification_events${suffix}` // log entries for ingestion into ClickHouse export const KAFKA_LOG_ENTRIES = `${prefix}log_entries${suffix}` @@ -47,3 +45,7 @@ export const KAFKA_LOG_ENTRIES = `${prefix}log_entries${suffix}` // CDP topics export const KAFKA_CDP_FUNCTION_CALLBACKS = `${prefix}cdp_function_callbacks${suffix}` export const KAFKA_CDP_FUNCTION_OVERFLOW = `${prefix}cdp_function_overflow${suffix}` + +// Error tracking topics +export const KAFKA_EXCEPTION_SYMBOLIFICATION_EVENTS = `${prefix}exception_symbolification_events${suffix}` +export const KAFKA_ERROR_TRACKING_ISSUE_FINGERPRINT = `${prefix}clickhouse_error_tracking_issue_fingerprint${suffix}` diff --git a/posthog/clickhouse/migrations/0083_add_error_tracking_issue_fingerprint_overrides_table_and_consumer.py b/posthog/clickhouse/migrations/0083_add_error_tracking_issue_fingerprint_overrides_table_and_consumer.py new file mode 100644 index 0000000000000..1d24e713ee6c3 --- /dev/null +++ b/posthog/clickhouse/migrations/0083_add_error_tracking_issue_fingerprint_overrides_table_and_consumer.py @@ -0,0 +1,12 @@ +from posthog.clickhouse.client.migration_tools import run_sql_with_exceptions +from posthog.models.error_tracking.sql import ( + ERROR_TRACKING_ISSUE_FINGERPRINT_OVERRIDES_TABLE_SQL, + KAFKA_ERROR_TRACKING_ISSUE_FINGERPRINT_OVERRIDES_TABLE_SQL, + ERROR_TRACKING_ISSUE_FINGERPRINT_OVERRIDES_MV_SQL, +) + +operations = [ + run_sql_with_exceptions(ERROR_TRACKING_ISSUE_FINGERPRINT_OVERRIDES_TABLE_SQL()), + run_sql_with_exceptions(KAFKA_ERROR_TRACKING_ISSUE_FINGERPRINT_OVERRIDES_TABLE_SQL()), + run_sql_with_exceptions(ERROR_TRACKING_ISSUE_FINGERPRINT_OVERRIDES_MV_SQL), +] diff --git a/posthog/clickhouse/schema.py b/posthog/clickhouse/schema.py index e3f5044b7a419..1df1fa52792af 100644 --- a/posthog/clickhouse/schema.py +++ b/posthog/clickhouse/schema.py @@ -84,6 +84,11 @@ PERSON_DISTINCT_ID_OVERRIDES_MV_SQL, KAFKA_PERSON_DISTINCT_ID_OVERRIDES_TABLE_SQL, ) +from posthog.models.error_tracking.sql import ( + ERROR_TRACKING_ISSUE_FINGERPRINT_OVERRIDES_TABLE_SQL, + ERROR_TRACKING_ISSUE_FINGERPRINT_OVERRIDES_MV_SQL, + KAFKA_ERROR_TRACKING_ISSUE_FINGERPRINT_OVERRIDES_TABLE_SQL, +) from posthog.models.person_overrides.sql import ( PERSON_OVERRIDES_CREATE_TABLE_SQL, PERSON_OVERRIDES_CREATE_DICTIONARY_SQL, @@ -130,6 +135,7 @@ PERSONS_DISTINCT_ID_TABLE_SQL, PERSON_DISTINCT_ID2_TABLE_SQL, PERSON_DISTINCT_ID_OVERRIDES_TABLE_SQL, + ERROR_TRACKING_ISSUE_FINGERPRINT_OVERRIDES_TABLE_SQL, PLUGIN_LOG_ENTRIES_TABLE_SQL, SESSION_RECORDING_EVENTS_TABLE_SQL, INGESTION_WARNINGS_DATA_TABLE_SQL, @@ -170,6 +176,7 @@ KAFKA_PERSONS_DISTINCT_ID_TABLE_SQL, KAFKA_PERSON_DISTINCT_ID2_TABLE_SQL, KAFKA_PERSON_DISTINCT_ID_OVERRIDES_TABLE_SQL, + KAFKA_ERROR_TRACKING_ISSUE_FINGERPRINT_OVERRIDES_TABLE_SQL, KAFKA_PLUGIN_LOG_ENTRIES_TABLE_SQL, KAFKA_SESSION_RECORDING_EVENTS_TABLE_SQL, KAFKA_INGESTION_WARNINGS_TABLE_SQL, @@ -189,6 +196,7 @@ PERSONS_DISTINCT_ID_TABLE_MV_SQL, PERSON_DISTINCT_ID2_MV_SQL, PERSON_DISTINCT_ID_OVERRIDES_MV_SQL, + ERROR_TRACKING_ISSUE_FINGERPRINT_OVERRIDES_MV_SQL, PLUGIN_LOG_ENTRIES_TABLE_MV_SQL, SESSION_RECORDING_EVENTS_TABLE_MV_SQL, INGESTION_WARNINGS_MV_TABLE_SQL, diff --git a/posthog/clickhouse/test/__snapshots__/test_schema.ambr b/posthog/clickhouse/test/__snapshots__/test_schema.ambr index ac13d60ef2d66..bc5a623ed0cdc 100644 --- a/posthog/clickhouse/test/__snapshots__/test_schema.ambr +++ b/posthog/clickhouse/test/__snapshots__/test_schema.ambr @@ -74,6 +74,21 @@ ''' # --- +# name: test_create_kafka_table_with_different_kafka_host[kafka_error_tracking_issue_fingerprint_overrides] + ''' + + CREATE TABLE IF NOT EXISTS kafka_error_tracking_issue_fingerprint_overrides ON CLUSTER 'posthog' + ( + team_id Int64, + fingerprint VARCHAR, + issue_id UUID, + is_deleted Int8, + version Int64 + + ) ENGINE = Kafka('test.kafka.broker:9092', 'clickhouse_error_tracking_issue_fingerprint_test', 'clickhouse-error-tracking-issue-fingerprint-overrides', 'JSONEachRow') + + ''' +# --- # name: test_create_kafka_table_with_different_kafka_host[kafka_events_dead_letter_queue] ''' @@ -558,6 +573,50 @@ Order By (team_id, cohort_id, person_id, version) + ''' +# --- +# name: test_create_table_query[error_tracking_issue_fingerprint_overrides] + ''' + + CREATE TABLE IF NOT EXISTS error_tracking_issue_fingerprint_overrides ON CLUSTER 'posthog' + ( + team_id Int64, + fingerprint VARCHAR, + issue_id UUID, + is_deleted Int8, + version Int64 + + + , _timestamp DateTime + , _offset UInt64 + , _partition UInt64 + + , INDEX kafka_timestamp_minmax_error_tracking_issue_fingerprint_overrides _timestamp TYPE minmax GRANULARITY 3 + + ) ENGINE = ReplicatedReplacingMergeTree('/clickhouse/tables/77f1df52-4b43-11e9-910f-b8ca3a9b9f3e_noshard/posthog.error_tracking_issue_fingerprint_overrides', '{replica}-{shard}', version) + + ORDER BY (team_id, fingerprint) + SETTINGS index_granularity = 512 + + ''' +# --- +# name: test_create_table_query[error_tracking_issue_fingerprint_overrides_mv] + ''' + + CREATE MATERIALIZED VIEW IF NOT EXISTS error_tracking_issue_fingerprint_overrides_mv ON CLUSTER 'posthog' + TO posthog_test.error_tracking_issue_fingerprint_overrides + AS SELECT + team_id, + fingerprint, + issue_id, + is_deleted, + version, + _timestamp, + _offset, + _partition + FROM posthog_test.kafka_error_tracking_issue_fingerprint_overrides + WHERE version > 0 -- only store updated rows, not newly inserted ones + ''' # --- # name: test_create_table_query[events] @@ -877,6 +936,21 @@ ''' # --- +# name: test_create_table_query[kafka_error_tracking_issue_fingerprint_overrides] + ''' + + CREATE TABLE IF NOT EXISTS kafka_error_tracking_issue_fingerprint_overrides ON CLUSTER 'posthog' + ( + team_id Int64, + fingerprint VARCHAR, + issue_id UUID, + is_deleted Int8, + version Int64 + + ) ENGINE = Kafka('kafka:9092', 'clickhouse_error_tracking_issue_fingerprint_test', 'clickhouse-error-tracking-issue-fingerprint-overrides', 'JSONEachRow') + + ''' +# --- # name: test_create_table_query[kafka_events_dead_letter_queue] ''' @@ -2910,6 +2984,31 @@ Order By (team_id, cohort_id, person_id, version) + ''' +# --- +# name: test_create_table_query_replicated_and_storage[error_tracking_issue_fingerprint_overrides] + ''' + + CREATE TABLE IF NOT EXISTS error_tracking_issue_fingerprint_overrides ON CLUSTER 'posthog' + ( + team_id Int64, + fingerprint VARCHAR, + issue_id UUID, + is_deleted Int8, + version Int64 + + + , _timestamp DateTime + , _offset UInt64 + , _partition UInt64 + + , INDEX kafka_timestamp_minmax_error_tracking_issue_fingerprint_overrides _timestamp TYPE minmax GRANULARITY 3 + + ) ENGINE = ReplicatedReplacingMergeTree('/clickhouse/tables/77f1df52-4b43-11e9-910f-b8ca3a9b9f3e_noshard/posthog.error_tracking_issue_fingerprint_overrides', '{replica}-{shard}', version) + + ORDER BY (team_id, fingerprint) + SETTINGS index_granularity = 512 + ''' # --- # name: test_create_table_query_replicated_and_storage[events_dead_letter_queue] diff --git a/posthog/conftest.py b/posthog/conftest.py index eb7c5500adb19..938ae3028bfeb 100644 --- a/posthog/conftest.py +++ b/posthog/conftest.py @@ -68,6 +68,7 @@ def reset_clickhouse_tables(): TRUNCATE_PERSON_STATIC_COHORT_TABLE_SQL, TRUNCATE_PERSON_TABLE_SQL, ) + from posthog.models.error_tracking.sql import TRUNCATE_ERROR_TRACKING_ISSUE_FINGERPRINT_OVERRIDES_TABLE_SQL from posthog.models.sessions.sql import TRUNCATE_SESSIONS_TABLE_SQL from posthog.session_recordings.sql.session_recording_event_sql import ( TRUNCATE_SESSION_RECORDING_EVENTS_TABLE_SQL, @@ -81,6 +82,7 @@ def reset_clickhouse_tables(): TRUNCATE_PERSON_DISTINCT_ID2_TABLE_SQL, TRUNCATE_PERSON_DISTINCT_ID_OVERRIDES_TABLE_SQL, TRUNCATE_PERSON_STATIC_COHORT_TABLE_SQL, + TRUNCATE_ERROR_TRACKING_ISSUE_FINGERPRINT_OVERRIDES_TABLE_SQL, TRUNCATE_SESSION_RECORDING_EVENTS_TABLE_SQL(), TRUNCATE_PLUGIN_LOG_ENTRIES_TABLE_SQL, TRUNCATE_COHORTPEOPLE_TABLE_SQL, diff --git a/posthog/hogql/transforms/test/__snapshots__/test_in_cohort.ambr b/posthog/hogql/transforms/test/__snapshots__/test_in_cohort.ambr index 06e46e0ca30b0..f018e96ef067a 100644 --- a/posthog/hogql/transforms/test/__snapshots__/test_in_cohort.ambr +++ b/posthog/hogql/transforms/test/__snapshots__/test_in_cohort.ambr @@ -31,7 +31,7 @@ FROM events LEFT JOIN ( SELECT person_static_cohort.person_id AS cohort_person_id, 1 AS matched, person_static_cohort.cohort_id AS cohort_id FROM person_static_cohort - WHERE and(equals(person_static_cohort.team_id, 420), in(person_static_cohort.cohort_id, [6]))) AS __in_cohort ON equals(__in_cohort.cohort_person_id, events.person_id) + WHERE and(equals(person_static_cohort.team_id, 420), in(person_static_cohort.cohort_id, [4]))) AS __in_cohort ON equals(__in_cohort.cohort_person_id, events.person_id) WHERE and(equals(events.team_id, 420), 1, ifNull(equals(__in_cohort.matched, 1), 0)) LIMIT 100 SETTINGS readonly=2, max_execution_time=60, allow_experimental_object_type=1, format_csv_allow_double_quotes=0, max_ast_elements=4000000, max_expanded_ast_elements=4000000, max_bytes_before_external_group_by=0 @@ -42,7 +42,7 @@ FROM events LEFT JOIN ( SELECT person_id AS cohort_person_id, 1 AS matched, cohort_id FROM static_cohort_people - WHERE in(cohort_id, [6])) AS __in_cohort ON equals(__in_cohort.cohort_person_id, person_id) + WHERE in(cohort_id, [4])) AS __in_cohort ON equals(__in_cohort.cohort_person_id, person_id) WHERE and(1, equals(__in_cohort.matched, 1)) LIMIT 100 ''' @@ -55,7 +55,7 @@ FROM events LEFT JOIN ( SELECT person_static_cohort.person_id AS cohort_person_id, 1 AS matched, person_static_cohort.cohort_id AS cohort_id FROM person_static_cohort - WHERE and(equals(person_static_cohort.team_id, 420), in(person_static_cohort.cohort_id, [7]))) AS __in_cohort ON equals(__in_cohort.cohort_person_id, events.person_id) + WHERE and(equals(person_static_cohort.team_id, 420), in(person_static_cohort.cohort_id, [5]))) AS __in_cohort ON equals(__in_cohort.cohort_person_id, events.person_id) WHERE and(equals(events.team_id, 420), 1, ifNull(equals(__in_cohort.matched, 1), 0)) LIMIT 100 SETTINGS readonly=2, max_execution_time=60, allow_experimental_object_type=1, format_csv_allow_double_quotes=0, max_ast_elements=4000000, max_expanded_ast_elements=4000000, max_bytes_before_external_group_by=0 @@ -66,7 +66,7 @@ FROM events LEFT JOIN ( SELECT person_id AS cohort_person_id, 1 AS matched, cohort_id FROM static_cohort_people - WHERE in(cohort_id, [7])) AS __in_cohort ON equals(__in_cohort.cohort_person_id, person_id) + WHERE in(cohort_id, [5])) AS __in_cohort ON equals(__in_cohort.cohort_person_id, person_id) WHERE and(1, equals(__in_cohort.matched, 1)) LIMIT 100 ''' diff --git a/posthog/kafka_client/topics.py b/posthog/kafka_client/topics.py index 227ca18d666fc..fa58d40c5fa36 100644 --- a/posthog/kafka_client/topics.py +++ b/posthog/kafka_client/topics.py @@ -23,8 +23,6 @@ KAFKA_CLICKHOUSE_HEATMAP_EVENTS = f"{KAFKA_PREFIX}clickhouse_heatmap_events{SUFFIX}" -KAFKA_EXCEPTION_SYMBOLIFICATION_EVENTS = f"{KAFKA_PREFIX}exception_symbolification_events{SUFFIX}" - # from capture to recordings consumer KAFKA_SESSION_RECORDING_EVENTS = f"{KAFKA_PREFIX}session_recording_events{SUFFIX}" # from capture to recordings blob ingestion consumer @@ -34,3 +32,6 @@ # from recordings consumer to clickhouse KAFKA_CLICKHOUSE_SESSION_REPLAY_EVENTS = f"{KAFKA_PREFIX}clickhouse_session_replay_events{SUFFIX}" KAFKA_CLICKHOUSE_SESSION_RECORDING_EVENTS = f"{KAFKA_PREFIX}clickhouse_session_recording_events{SUFFIX}" + +KAFKA_EXCEPTION_SYMBOLIFICATION_EVENTS = f"{KAFKA_PREFIX}exception_symbolification_events{SUFFIX}" +KAFKA_ERROR_TRACKING_ISSUE_FINGERPRINT = f"{KAFKA_PREFIX}clickhouse_error_tracking_issue_fingerprint{SUFFIX}" diff --git a/posthog/models/error_tracking/sql.py b/posthog/models/error_tracking/sql.py new file mode 100644 index 0000000000000..1700a6c7c4cd9 --- /dev/null +++ b/posthog/models/error_tracking/sql.py @@ -0,0 +1,79 @@ +from posthog.clickhouse.indexes import index_by_kafka_timestamp +from posthog.clickhouse.kafka_engine import KAFKA_COLUMNS_WITH_PARTITION, kafka_engine +from posthog.clickhouse.table_engines import ReplacingMergeTree +from posthog.kafka_client.topics import KAFKA_ERROR_TRACKING_ISSUE_FINGERPRINT +from posthog.settings import CLICKHOUSE_CLUSTER, CLICKHOUSE_DATABASE + +# +# error_tracking_issue_fingerprint_overrides: This table contains rows for all (team_id, fingerprint) +# pairs where the $exception_issue_id has changed. +# + +ERROR_TRACKING_ISSUE_FINGERPRINT_OVERRIDES_TABLE = "error_tracking_issue_fingerprint_overrides" + +ERROR_TRACKING_ISSUE_FINGERPRINT_OVERRIDES_TABLE_BASE_SQL = """ +CREATE TABLE IF NOT EXISTS {table_name} ON CLUSTER '{cluster}' +( + team_id Int64, + fingerprint VARCHAR, + issue_id UUID, + is_deleted Int8, + version Int64 + {extra_fields} +) ENGINE = {engine} +""" + +ERROR_TRACKING_ISSUE_FINGERPRINT_OVERRIDES_TABLE_ENGINE = lambda: ReplacingMergeTree( + ERROR_TRACKING_ISSUE_FINGERPRINT_OVERRIDES_TABLE, ver="version" +) + +ERROR_TRACKING_ISSUE_FINGERPRINT_OVERRIDES_TABLE_SQL = lambda: ( + ERROR_TRACKING_ISSUE_FINGERPRINT_OVERRIDES_TABLE_BASE_SQL + + """ + ORDER BY (team_id, fingerprint) + SETTINGS index_granularity = 512 + """ +).format( + table_name=ERROR_TRACKING_ISSUE_FINGERPRINT_OVERRIDES_TABLE, + cluster=CLICKHOUSE_CLUSTER, + engine=ERROR_TRACKING_ISSUE_FINGERPRINT_OVERRIDES_TABLE_ENGINE(), + extra_fields=f""" + {KAFKA_COLUMNS_WITH_PARTITION} + , {index_by_kafka_timestamp(ERROR_TRACKING_ISSUE_FINGERPRINT_OVERRIDES_TABLE)} + """, +) + +KAFKA_ERROR_TRACKING_ISSUE_FINGERPRINT_OVERRIDES_TABLE_SQL = ( + lambda: ERROR_TRACKING_ISSUE_FINGERPRINT_OVERRIDES_TABLE_BASE_SQL.format( + table_name="kafka_" + ERROR_TRACKING_ISSUE_FINGERPRINT_OVERRIDES_TABLE, + cluster=CLICKHOUSE_CLUSTER, + engine=kafka_engine( + KAFKA_ERROR_TRACKING_ISSUE_FINGERPRINT, group="clickhouse-error-tracking-issue-fingerprint-overrides" + ), + extra_fields="", + ) +) + +ERROR_TRACKING_ISSUE_FINGERPRINT_OVERRIDES_MV_SQL = """ +CREATE MATERIALIZED VIEW IF NOT EXISTS {table_name}_mv ON CLUSTER '{cluster}' +TO {database}.{table_name} +AS SELECT +team_id, +fingerprint, +issue_id, +is_deleted, +version, +_timestamp, +_offset, +_partition +FROM {database}.kafka_{table_name} +WHERE version > 0 -- only store updated rows, not newly inserted ones +""".format( + table_name=ERROR_TRACKING_ISSUE_FINGERPRINT_OVERRIDES_TABLE, + cluster=CLICKHOUSE_CLUSTER, + database=CLICKHOUSE_DATABASE, +) + +TRUNCATE_ERROR_TRACKING_ISSUE_FINGERPRINT_OVERRIDES_TABLE_SQL = ( + f"TRUNCATE TABLE IF EXISTS {ERROR_TRACKING_ISSUE_FINGERPRINT_OVERRIDES_TABLE} ON CLUSTER '{CLICKHOUSE_CLUSTER}'" +) From e6877d34365e314f0dc46e9d530382bac090735a Mon Sep 17 00:00:00 2001 From: Raquel Smith Date: Tue, 29 Oct 2024 09:52:29 -0700 Subject: [PATCH 04/14] feat: record non-onboarding product intents for data warehouse (#25859) Co-authored-by: github-actions <41898282+github-actions[bot]@users.noreply.github.com> --- .../data-warehouse/new/sourceWizardLogic.tsx | 7 +++++ frontend/src/scenes/teamActivityDescriber.tsx | 1 + frontend/src/scenes/teamLogic.tsx | 3 +- frontend/src/types.ts | 7 +++++ posthog/api/project.py | 24 ++++++++++++++-- posthog/api/team.py | 28 +++++++++++++++---- .../api/test/__snapshots__/test_api_docs.ambr | 2 +- .../api/test/__snapshots__/test_decide.ambr | 3 +- posthog/api/test/test_team.py | 9 ++++++ 9 files changed, 73 insertions(+), 11 deletions(-) diff --git a/frontend/src/scenes/data-warehouse/new/sourceWizardLogic.tsx b/frontend/src/scenes/data-warehouse/new/sourceWizardLogic.tsx index 2d8bba2f256bc..95a525987b8a2 100644 --- a/frontend/src/scenes/data-warehouse/new/sourceWizardLogic.tsx +++ b/frontend/src/scenes/data-warehouse/new/sourceWizardLogic.tsx @@ -6,6 +6,7 @@ import api from 'lib/api' import posthog from 'posthog-js' import { preflightLogic } from 'scenes/PreflightCheck/preflightLogic' import { Scene } from 'scenes/sceneTypes' +import { teamLogic } from 'scenes/teamLogic' import { urls } from 'scenes/urls' import { @@ -16,6 +17,7 @@ import { manualLinkSources, ManualLinkSourceType, PipelineTab, + ProductKey, SourceConfig, SourceFieldConfig, } from '~/types' @@ -731,6 +733,8 @@ export const sourceWizardLogic = kea([ ['resetTable', 'createTableSuccess'], dataWarehouseSettingsLogic, ['loadSources'], + teamLogic, + ['addProductIntent'], ], }), reducers({ @@ -1129,6 +1133,9 @@ export const sourceWizardLogic = kea([ setManualLinkingProvider: () => { actions.onNext() }, + selectConnector: () => { + actions.addProductIntent({ product_type: ProductKey.DATA_WAREHOUSE, intent_context: 'selected connector' }) + }, })), urlToAction(({ actions }) => ({ '/data-warehouse/:kind/redirect': ({ kind = '' }, searchParams) => { diff --git a/frontend/src/scenes/teamActivityDescriber.tsx b/frontend/src/scenes/teamActivityDescriber.tsx index 7c1a5cd22e44a..e3c4f9d27052f 100644 --- a/frontend/src/scenes/teamActivityDescriber.tsx +++ b/frontend/src/scenes/teamActivityDescriber.tsx @@ -347,6 +347,7 @@ const teamActionsMapping: Record< updated_at: () => null, uuid: () => null, live_events_token: () => null, + product_intents: () => null, } function nameAndLink(logItem?: ActivityLogItem): JSX.Element { diff --git a/frontend/src/scenes/teamLogic.tsx b/frontend/src/scenes/teamLogic.tsx index 3f6d102270525..0e6754609ca29 100644 --- a/frontend/src/scenes/teamLogic.tsx +++ b/frontend/src/scenes/teamLogic.tsx @@ -145,13 +145,14 @@ export const teamLogic = kea([ resetToken: async () => await api.update(`api/environments/${values.currentTeamId}/reset_token`, {}), addProductIntent: async ({ product_type, + intent_context, }: { product_type: ProductKey intent_context?: string | null }) => await api.update(`api/environments/${values.currentTeamId}/add_product_intent`, { product_type, - intent_context: null, + intent_context: intent_context ?? undefined, }), recordProductIntentOnboardingComplete: async ({ product_type }: { product_type: ProductKey }) => await api.update(`api/environments/${values.currentTeamId}/complete_product_onboarding`, { diff --git a/frontend/src/types.ts b/frontend/src/types.ts index 3d08ee1fb7512..6b78307b81774 100644 --- a/frontend/src/types.ts +++ b/frontend/src/types.ts @@ -545,6 +545,13 @@ export interface TeamType extends TeamBasicType { extra_settings?: Record modifiers?: HogQLQueryModifiers default_modifiers?: HogQLQueryModifiers + product_intents?: ProductIntentType[] +} + +export interface ProductIntentType { + product_type: string + created_at: string + onboarding_completed_at?: string } // This type would be more correct without `Partial`, but it's only used in the shared dashboard/insight diff --git a/posthog/api/project.py b/posthog/api/project.py index 0c60c7e649a91..8efca11b21968 100644 --- a/posthog/api/project.py +++ b/posthog/api/project.py @@ -44,7 +44,11 @@ TeamMemberStrictManagementPermission, ) from posthog.user_permissions import UserPermissions, UserPermissionsSerializerMixin -from posthog.utils import get_ip_address, get_week_start_for_country_code +from posthog.utils import ( + get_instance_realm, + get_ip_address, + get_week_start_for_country_code, +) class ProjectSerializer(serializers.ModelSerializer): @@ -195,7 +199,9 @@ def get_live_events_token(self, project: Project) -> Optional[str]: def get_product_intents(self, obj): project = obj team = project.passthrough_team - return ProductIntent.objects.filter(team=team).values("product_type", "created_at", "onboarding_completed_at") + return ProductIntent.objects.filter(team=team).values( + "product_type", "created_at", "onboarding_completed_at", "updated_at" + ) @staticmethod def validate_session_recording_linked_flag(value) -> dict | None: @@ -572,7 +578,7 @@ def add_product_intent(self, request: request.Request, *args, **kwargs): product_intent.updated_at = datetime.now(tz=UTC) product_intent.save() - if created and isinstance(user, User): + if isinstance(user, User): report_user_action( user, "user showed product intent", @@ -582,6 +588,10 @@ def add_product_intent(self, request: request.Request, *args, **kwargs): "$current_url": current_url, "$session_id": session_id, "intent_context": request.data.get("intent_context"), + "is_first_intent_for_product": created, + "intent_created_at": product_intent.created_at, + "intent_updated_at": product_intent.updated_at, + "realm": get_instance_realm(), }, team=team, ) @@ -612,6 +622,10 @@ def complete_product_onboarding(self, request: request.Request, *args, **kwargs) "$current_url": current_url, "$session_id": session_id, "intent_context": request.data.get("intent_context"), + "is_first_intent_for_product": created, + "intent_created_at": product_intent.created_at, + "intent_updated_at": product_intent.updated_at, + "realm": get_instance_realm(), }, team=team, ) @@ -626,6 +640,10 @@ def complete_product_onboarding(self, request: request.Request, *args, **kwargs) "product_key": product_type, "$current_url": current_url, "$session_id": session_id, + "intent_context": request.data.get("intent_context"), + "intent_created_at": product_intent.created_at, + "intent_updated_at": product_intent.updated_at, + "realm": get_instance_realm(), }, team=team, ) diff --git a/posthog/api/team.py b/posthog/api/team.py index b92f3acaf35ae..148471919cbc0 100644 --- a/posthog/api/team.py +++ b/posthog/api/team.py @@ -6,17 +6,17 @@ from django.shortcuts import get_object_or_404 from loginas.utils import is_impersonated_session -from posthog.auth import PersonalAPIKeyAuthentication -from posthog.jwt import PosthogJwtAudience, encode_jwt from rest_framework import exceptions, request, response, serializers, viewsets from rest_framework.permissions import BasePermission, IsAuthenticated from posthog.api.routing import TeamAndOrgViewSetMixin from posthog.api.shared import TeamBasicSerializer from posthog.api.utils import action +from posthog.auth import PersonalAPIKeyAuthentication from posthog.constants import AvailableFeature from posthog.event_usage import report_user_action from posthog.geoip import get_geoip_properties +from posthog.jwt import PosthogJwtAudience, encode_jwt from posthog.models import ProductIntent, Team, User from posthog.models.activity_logging.activity_log import ( Detail, @@ -43,7 +43,11 @@ get_organization_from_view, ) from posthog.user_permissions import UserPermissions, UserPermissionsSerializerMixin -from posthog.utils import get_ip_address, get_week_start_for_country_code +from posthog.utils import ( + get_instance_realm, + get_ip_address, + get_week_start_for_country_code, +) class PremiumMultiProjectPermissions(BasePermission): # TODO: Rename to include "Env" in name @@ -211,7 +215,9 @@ def get_live_events_token(self, team: Team) -> Optional[str]: ) def get_product_intents(self, obj): - return ProductIntent.objects.filter(team=obj).values("product_type", "created_at", "onboarding_completed_at") + return ProductIntent.objects.filter(team=obj).values( + "product_type", "created_at", "onboarding_completed_at", "updated_at" + ) @staticmethod def validate_session_recording_linked_flag(value) -> dict | None: @@ -582,7 +588,7 @@ def add_product_intent(self, request: request.Request, *args, **kwargs): product_intent.updated_at = datetime.now(tz=UTC) product_intent.save() - if created and isinstance(user, User): + if isinstance(user, User): report_user_action( user, "user showed product intent", @@ -592,6 +598,10 @@ def add_product_intent(self, request: request.Request, *args, **kwargs): "$current_url": current_url, "$session_id": session_id, "intent_context": request.data.get("intent_context"), + "is_first_intent_for_product": created, + "intent_created_at": product_intent.created_at, + "intent_updated_at": product_intent.updated_at, + "realm": get_instance_realm(), }, team=team, ) @@ -621,6 +631,10 @@ def complete_product_onboarding(self, request: request.Request, *args, **kwargs) "$current_url": current_url, "$session_id": session_id, "intent_context": request.data.get("intent_context"), + "is_first_intent_for_product": created, + "intent_created_at": product_intent.created_at, + "intent_updated_at": product_intent.updated_at, + "realm": get_instance_realm(), }, team=team, ) @@ -635,6 +649,10 @@ def complete_product_onboarding(self, request: request.Request, *args, **kwargs) "product_key": product_type, "$current_url": current_url, "$session_id": session_id, + "intent_context": request.data.get("intent_context"), + "intent_created_at": product_intent.created_at, + "intent_updated_at": product_intent.updated_at, + "realm": get_instance_realm(), }, team=team, ) diff --git a/posthog/api/test/__snapshots__/test_api_docs.ambr b/posthog/api/test/__snapshots__/test_api_docs.ambr index a5f9b394809ae..6ef31c6530176 100644 --- a/posthog/api/test/__snapshots__/test_api_docs.ambr +++ b/posthog/api/test/__snapshots__/test_api_docs.ambr @@ -97,8 +97,8 @@ '/home/runner/work/posthog/posthog/posthog/api/survey.py: Warning [SurveyViewSet > SurveySerializer]: unable to resolve type hint for function "get_conditions". Consider using a type hint or @extend_schema_field. Defaulting to string.', '/home/runner/work/posthog/posthog/posthog/api/web_experiment.py: Warning [WebExperimentViewSet]: could not derive type of path parameter "project_id" because model "posthog.models.web_experiment.WebExperiment" contained no such field. Consider annotating parameter with @extend_schema. Defaulting to "string".', 'Warning: encountered multiple names for the same choice set (HrefMatchingEnum). This may be unwanted even though the generated schema is technically correct. Add an entry to ENUM_NAME_OVERRIDES to fix the naming.', - 'Warning: enum naming encountered a non-optimally resolvable collision for fields named "kind". The same name has been used for multiple choice sets in multiple components. The collision was resolved with "KindCfaEnum". add an entry to ENUM_NAME_OVERRIDES to fix the naming.', 'Warning: enum naming encountered a non-optimally resolvable collision for fields named "kind". The same name has been used for multiple choice sets in multiple components. The collision was resolved with "Kind069Enum". add an entry to ENUM_NAME_OVERRIDES to fix the naming.', + 'Warning: enum naming encountered a non-optimally resolvable collision for fields named "kind". The same name has been used for multiple choice sets in multiple components. The collision was resolved with "KindCfaEnum". add an entry to ENUM_NAME_OVERRIDES to fix the naming.', 'Warning: enum naming encountered a non-optimally resolvable collision for fields named "type". The same name has been used for multiple choice sets in multiple components. The collision was resolved with "TypeF73Enum". add an entry to ENUM_NAME_OVERRIDES to fix the naming.', 'Warning: encountered multiple names for the same choice set (EffectivePrivilegeLevelEnum). This may be unwanted even though the generated schema is technically correct. Add an entry to ENUM_NAME_OVERRIDES to fix the naming.', 'Warning: encountered multiple names for the same choice set (MembershipLevelEnum). This may be unwanted even though the generated schema is technically correct. Add an entry to ENUM_NAME_OVERRIDES to fix the naming.', diff --git a/posthog/api/test/__snapshots__/test_decide.ambr b/posthog/api/test/__snapshots__/test_decide.ambr index 93ec860efb05b..18fc2e400e3fd 100644 --- a/posthog/api/test/__snapshots__/test_decide.ambr +++ b/posthog/api/test/__snapshots__/test_decide.ambr @@ -523,7 +523,8 @@ ''' SELECT "posthog_productintent"."product_type", "posthog_productintent"."created_at", - "posthog_productintent"."onboarding_completed_at" + "posthog_productintent"."onboarding_completed_at", + "posthog_productintent"."updated_at" FROM "posthog_productintent" WHERE "posthog_productintent"."team_id" = 2 ''' diff --git a/posthog/api/test/test_team.py b/posthog/api/test/test_team.py index ba697d073699f..3a881facfea44 100644 --- a/posthog/api/test/test_team.py +++ b/posthog/api/test/test_team.py @@ -26,6 +26,7 @@ from posthog.temporal.common.client import sync_connect from posthog.temporal.common.schedule import describe_schedule from posthog.test.base import APIBaseTest +from posthog.utils import get_instance_realm def team_api_test_factory(): @@ -1042,6 +1043,10 @@ def test_can_add_product_intent( "$session_id": "test_session_id", "intent_context": "onboarding product selected", "$set_once": {"first_onboarding_product_selected": "product_analytics"}, + "is_first_intent_for_product": True, + "intent_created_at": datetime(2024, 1, 1, 0, 0, 0, tzinfo=UTC), + "intent_updated_at": datetime(2024, 1, 1, 0, 0, 0, tzinfo=UTC), + "realm": get_instance_realm(), }, team=self.team, ) @@ -1073,6 +1078,10 @@ def test_can_complete_product_onboarding( "product_key": "product_analytics", "$current_url": "https://posthogtest.com/my-url", "$session_id": "test_session_id", + "intent_context": None, + "intent_created_at": datetime(2024, 1, 1, 0, 0, 0, tzinfo=UTC), + "intent_updated_at": datetime(2024, 1, 5, 0, 0, 0, tzinfo=UTC), + "realm": get_instance_realm(), }, team=self.team, ) From 447a18930f5a84d50ea2ebd9f5149c1ed9cb34a4 Mon Sep 17 00:00:00 2001 From: Sandy Spicer Date: Tue, 29 Oct 2024 11:31:56 -0700 Subject: [PATCH 05/14] feat: add "INTERSECT" and "EXCEPT" to HogQL (#25737) Co-authored-by: github-actions <41898282+github-actions[bot]@users.noreply.github.com> --- hogql_parser/HogQLLexer.cpp | 1022 ++--- hogql_parser/HogQLLexer.h | 53 +- hogql_parser/HogQLLexer.interp | 8 +- hogql_parser/HogQLLexer.tokens | 352 +- hogql_parser/HogQLParser.cpp | 3285 +++++++------- hogql_parser/HogQLParser.h | 153 +- hogql_parser/HogQLParser.interp | 9 +- hogql_parser/HogQLParser.tokens | 352 +- hogql_parser/HogQLParserBaseVisitor.h | 8 +- hogql_parser/HogQLParserVisitor.h | 6 +- hogql_parser/__init__.pyi | 4 +- hogql_parser/parser.cpp | 102 +- hogql_parser/setup.py | 2 +- mypy-baseline.txt | 64 +- posthog/api/test/test_plugin.py | 39 +- posthog/batch_exports/http.py | 6 +- posthog/hogql/ast.py | 50 +- posthog/hogql/autocomplete.py | 5 +- .../test_person_where_clause_extractor.py | 2 +- .../test_session_v2_where_clause_extractor.py | 38 +- .../test_session_where_clause_extractor.py | 2 +- posthog/hogql/grammar/HogQLLexer.g4 | 2 + posthog/hogql/grammar/HogQLLexer.interp | 8 +- posthog/hogql/grammar/HogQLLexer.py | 1471 ++++--- posthog/hogql/grammar/HogQLLexer.tokens | 352 +- posthog/hogql/grammar/HogQLParser.g4 | 14 +- posthog/hogql/grammar/HogQLParser.interp | 9 +- posthog/hogql/grammar/HogQLParser.py | 3914 +++++++++-------- posthog/hogql/grammar/HogQLParser.tokens | 352 +- posthog/hogql/grammar/HogQLParserVisitor.py | 13 +- posthog/hogql/metadata.py | 15 +- posthog/hogql/parser.py | 52 +- posthog/hogql/printer.py | 32 +- posthog/hogql/query.py | 14 +- posthog/hogql/resolver.py | 23 +- posthog/hogql/resolver_utils.py | 10 + .../test/__snapshots__/test_resolver.ambr | 1924 ++++---- posthog/hogql/test/_test_parser.py | 54 +- posthog/hogql/test/test_printer.py | 132 +- posthog/hogql/visitor.py | 20 +- posthog/hogql_queries/actors_query_runner.py | 5 +- .../actors_property_taxonomy_query_runner.py | 2 +- .../ai/event_taxonomy_query_runner.py | 2 +- .../ai/team_taxonomy_query_runner.py | 2 +- .../hogql_queries/insights/funnels/base.py | 2 +- .../funnel_correlation_query_runner.py | 14 +- .../insights/funnels/funnel_unordered.py | 2 +- .../insights/funnels/funnels_query_runner.py | 2 +- .../insight_actors_query_options_runner.py | 2 +- .../insights/insight_actors_query_runner.py | 4 +- .../insights/lifecycle_query_runner.py | 4 +- .../insights/paths_query_runner.py | 4 +- .../insights/retention_query_runner.py | 2 +- .../insights/stickiness_query_runner.py | 8 +- .../insights/trends/aggregation_operations.py | 10 +- .../hogql_queries/insights/trends/display.py | 4 +- .../trends/trends_actors_query_builder.py | 2 +- .../insights/trends/trends_query_builder.py | 8 +- .../insights/trends/trends_query_runner.py | 34 +- .../insights/utils/aggregations.py | 4 +- posthog/hogql_queries/query_runner.py | 4 +- .../hogql_queries/web_analytics/top_clicks.py | 2 +- .../hogql_queries/web_analytics/web_goals.py | 2 +- .../web_analytics/web_overview.py | 2 +- posthog/models/cohort/util.py | 5 +- .../session_recording_list_from_filters.py | 10 +- posthog/warehouse/models/modeling.py | 13 +- requirements.in | 2 +- requirements.txt | 2 +- 69 files changed, 7293 insertions(+), 6839 deletions(-) diff --git a/hogql_parser/HogQLLexer.cpp b/hogql_parser/HogQLLexer.cpp index 6041af94e2ea0..51f7c603a8216 100644 --- a/hogql_parser/HogQLLexer.cpp +++ b/hogql_parser/HogQLLexer.cpp @@ -60,26 +60,26 @@ void hogqllexerLexerInitialize() { "ALL", "AND", "ANTI", "ANY", "ARRAY", "AS", "ASCENDING", "ASOF", "BETWEEN", "BOTH", "BY", "CASE", "CAST", "CATCH", "COHORT", "COLLATE", "CROSS", "CUBE", "CURRENT", "DATE", "DAY", "DESC", "DESCENDING", "DISTINCT", - "ELSE", "END", "EXTRACT", "FINAL", "FINALLY", "FIRST", "FN", "FOLLOWING", - "FOR", "FROM", "FULL", "FUN", "GROUP", "HAVING", "HOUR", "ID", "IF", - "ILIKE", "IN", "INF", "INNER", "INTERVAL", "IS", "JOIN", "KEY", "LAST", - "LEADING", "LEFT", "LET", "LIKE", "LIMIT", "MINUTE", "MONTH", "NAN_SQL", - "NOT", "NULL_SQL", "NULLS", "OFFSET", "ON", "OR", "ORDER", "OUTER", - "OVER", "PARTITION", "PRECEDING", "PREWHERE", "QUARTER", "RANGE", - "RETURN", "RIGHT", "ROLLUP", "ROW", "ROWS", "SAMPLE", "SECOND", "SELECT", - "SEMI", "SETTINGS", "SUBSTRING", "THEN", "THROW", "TIES", "TIMESTAMP", - "TO", "TOP", "TOTALS", "TRAILING", "TRIM", "TRUNCATE", "TRY", "UNBOUNDED", - "UNION", "USING", "WEEK", "WHEN", "WHERE", "WHILE", "WINDOW", "WITH", - "YEAR", "ESCAPE_CHAR_COMMON", "IDENTIFIER", "FLOATING_LITERAL", "OCTAL_LITERAL", - "DECIMAL_LITERAL", "HEXADECIMAL_LITERAL", "STRING_LITERAL", "A", "B", - "C", "D", "E", "F", "G", "H", "I", "J", "K", "L", "M", "N", "O", "P", - "Q", "R", "S", "T", "U", "V", "W", "X", "Y", "Z", "LETTER", "OCT_DIGIT", - "DEC_DIGIT", "HEX_DIGIT", "ARROW", "ASTERISK", "BACKQUOTE", "BACKSLASH", - "COLON", "COMMA", "CONCAT", "DASH", "DOLLAR", "DOT", "EQ_DOUBLE", - "EQ_SINGLE", "GT_EQ", "GT", "HASH", "IREGEX_SINGLE", "IREGEX_DOUBLE", - "LBRACE", "LBRACKET", "LPAREN", "LT_EQ", "LT", "NOT_EQ", "NOT_IREGEX", - "NOT_REGEX", "NULL_PROPERTY", "NULLISH", "PERCENT", "PLUS", "QUERY", - "QUOTE_DOUBLE", "QUOTE_SINGLE_TEMPLATE", "QUOTE_SINGLE_TEMPLATE_FULL", + "ELSE", "END", "EXCEPT", "EXTRACT", "FINAL", "FINALLY", "FIRST", "FN", + "FOLLOWING", "FOR", "FROM", "FULL", "FUN", "GROUP", "HAVING", "HOUR", + "ID", "IF", "ILIKE", "IN", "INF", "INNER", "INTERSECT", "INTERVAL", + "IS", "JOIN", "KEY", "LAST", "LEADING", "LEFT", "LET", "LIKE", "LIMIT", + "MINUTE", "MONTH", "NAN_SQL", "NOT", "NULL_SQL", "NULLS", "OFFSET", + "ON", "OR", "ORDER", "OUTER", "OVER", "PARTITION", "PRECEDING", "PREWHERE", + "QUARTER", "RANGE", "RETURN", "RIGHT", "ROLLUP", "ROW", "ROWS", "SAMPLE", + "SECOND", "SELECT", "SEMI", "SETTINGS", "SUBSTRING", "THEN", "THROW", + "TIES", "TIMESTAMP", "TO", "TOP", "TOTALS", "TRAILING", "TRIM", "TRUNCATE", + "TRY", "UNBOUNDED", "UNION", "USING", "WEEK", "WHEN", "WHERE", "WHILE", + "WINDOW", "WITH", "YEAR", "ESCAPE_CHAR_COMMON", "IDENTIFIER", "FLOATING_LITERAL", + "OCTAL_LITERAL", "DECIMAL_LITERAL", "HEXADECIMAL_LITERAL", "STRING_LITERAL", + "A", "B", "C", "D", "E", "F", "G", "H", "I", "J", "K", "L", "M", "N", + "O", "P", "Q", "R", "S", "T", "U", "V", "W", "X", "Y", "Z", "LETTER", + "OCT_DIGIT", "DEC_DIGIT", "HEX_DIGIT", "ARROW", "ASTERISK", "BACKQUOTE", + "BACKSLASH", "COLON", "COMMA", "CONCAT", "DASH", "DOLLAR", "DOT", + "EQ_DOUBLE", "EQ_SINGLE", "GT_EQ", "GT", "HASH", "IREGEX_SINGLE", + "IREGEX_DOUBLE", "LBRACE", "LBRACKET", "LPAREN", "LT_EQ", "LT", "NOT_EQ", + "NOT_IREGEX", "NOT_REGEX", "NULL_PROPERTY", "NULLISH", "PERCENT", + "PLUS", "QUERY", "QUOTE_DOUBLE", "QUOTE_SINGLE_TEMPLATE", "QUOTE_SINGLE_TEMPLATE_FULL", "QUOTE_SINGLE", "REGEX_SINGLE", "REGEX_DOUBLE", "RBRACE", "RBRACKET", "RPAREN", "SEMICOLON", "SLASH", "UNDERSCORE", "MULTI_LINE_COMMENT", "SINGLE_LINE_COMMENT", "WHITESPACE", "STRING_TEXT", "STRING_ESCAPE_TRIGGER", @@ -98,30 +98,30 @@ void hogqllexerLexerInitialize() { "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", - "", "", "", "", "", "", "", "", "", "", "'->'", "'*'", "'`'", "'\\'", - "':'", "','", "'||'", "'-'", "'$'", "'.'", "'=='", "'='", "'>='", - "'>'", "'#'", "'~*'", "'=~*'", "'{'", "'['", "'('", "'<='", "'<'", - "", "'!~*'", "'!~'", "'\\u003F.'", "'\\u003F\\u003F'", "'%'", "'+'", - "'\\u003F'", "'\"'", "'f''", "'F''", "'''", "'~'", "'=~'", "'}'", - "']'", "')'", "';'", "'/'", "'_'" + "", "", "", "", "", "", "", "", "", "", "", "", "'->'", "'*'", "'`'", + "'\\'", "':'", "','", "'||'", "'-'", "'$'", "'.'", "'=='", "'='", + "'>='", "'>'", "'#'", "'~*'", "'=~*'", "'{'", "'['", "'('", "'<='", + "'<'", "", "'!~*'", "'!~'", "'\\u003F.'", "'\\u003F\\u003F'", "'%'", + "'+'", "'\\u003F'", "'\"'", "'f''", "'F''", "'''", "'~'", "'=~'", + "'}'", "']'", "')'", "';'", "'/'", "'_'" }, std::vector{ "", "ALL", "AND", "ANTI", "ANY", "ARRAY", "AS", "ASCENDING", "ASOF", "BETWEEN", "BOTH", "BY", "CASE", "CAST", "CATCH", "COHORT", "COLLATE", "CROSS", "CUBE", "CURRENT", "DATE", "DAY", "DESC", "DESCENDING", "DISTINCT", - "ELSE", "END", "EXTRACT", "FINAL", "FINALLY", "FIRST", "FN", "FOLLOWING", - "FOR", "FROM", "FULL", "FUN", "GROUP", "HAVING", "HOUR", "ID", "IF", - "ILIKE", "IN", "INF", "INNER", "INTERVAL", "IS", "JOIN", "KEY", "LAST", - "LEADING", "LEFT", "LET", "LIKE", "LIMIT", "MINUTE", "MONTH", "NAN_SQL", - "NOT", "NULL_SQL", "NULLS", "OFFSET", "ON", "OR", "ORDER", "OUTER", - "OVER", "PARTITION", "PRECEDING", "PREWHERE", "QUARTER", "RANGE", - "RETURN", "RIGHT", "ROLLUP", "ROW", "ROWS", "SAMPLE", "SECOND", "SELECT", - "SEMI", "SETTINGS", "SUBSTRING", "THEN", "THROW", "TIES", "TIMESTAMP", - "TO", "TOP", "TOTALS", "TRAILING", "TRIM", "TRUNCATE", "TRY", "UNBOUNDED", - "UNION", "USING", "WEEK", "WHEN", "WHERE", "WHILE", "WINDOW", "WITH", - "YEAR", "ESCAPE_CHAR_COMMON", "IDENTIFIER", "FLOATING_LITERAL", "OCTAL_LITERAL", - "DECIMAL_LITERAL", "HEXADECIMAL_LITERAL", "STRING_LITERAL", "ARROW", - "ASTERISK", "BACKQUOTE", "BACKSLASH", "COLON", "COMMA", "CONCAT", + "ELSE", "END", "EXCEPT", "EXTRACT", "FINAL", "FINALLY", "FIRST", "FN", + "FOLLOWING", "FOR", "FROM", "FULL", "FUN", "GROUP", "HAVING", "HOUR", + "ID", "IF", "ILIKE", "IN", "INF", "INNER", "INTERSECT", "INTERVAL", + "IS", "JOIN", "KEY", "LAST", "LEADING", "LEFT", "LET", "LIKE", "LIMIT", + "MINUTE", "MONTH", "NAN_SQL", "NOT", "NULL_SQL", "NULLS", "OFFSET", + "ON", "OR", "ORDER", "OUTER", "OVER", "PARTITION", "PRECEDING", "PREWHERE", + "QUARTER", "RANGE", "RETURN", "RIGHT", "ROLLUP", "ROW", "ROWS", "SAMPLE", + "SECOND", "SELECT", "SEMI", "SETTINGS", "SUBSTRING", "THEN", "THROW", + "TIES", "TIMESTAMP", "TO", "TOP", "TOTALS", "TRAILING", "TRIM", "TRUNCATE", + "TRY", "UNBOUNDED", "UNION", "USING", "WEEK", "WHEN", "WHERE", "WHILE", + "WINDOW", "WITH", "YEAR", "ESCAPE_CHAR_COMMON", "IDENTIFIER", "FLOATING_LITERAL", + "OCTAL_LITERAL", "DECIMAL_LITERAL", "HEXADECIMAL_LITERAL", "STRING_LITERAL", + "ARROW", "ASTERISK", "BACKQUOTE", "BACKSLASH", "COLON", "COMMA", "CONCAT", "DASH", "DOLLAR", "DOT", "EQ_DOUBLE", "EQ_SINGLE", "GT_EQ", "GT", "HASH", "IREGEX_SINGLE", "IREGEX_DOUBLE", "LBRACE", "LBRACKET", "LPAREN", "LT_EQ", "LT", "NOT_EQ", "NOT_IREGEX", "NOT_REGEX", "NULL_PROPERTY", @@ -133,7 +133,7 @@ void hogqllexerLexerInitialize() { } ); static const int32_t serializedATNSegment[] = { - 4,0,160,1455,6,-1,6,-1,6,-1,2,0,7,0,2,1,7,1,2,2,7,2,2,3,7,3,2,4,7,4,2, + 4,0,162,1476,6,-1,6,-1,6,-1,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, @@ -162,111 +162,113 @@ void hogqllexerLexerInitialize() { 7,169,2,170,7,170,2,171,7,171,2,172,7,172,2,173,7,173,2,174,7,174,2,175, 7,175,2,176,7,176,2,177,7,177,2,178,7,178,2,179,7,179,2,180,7,180,2,181, 7,181,2,182,7,182,2,183,7,183,2,184,7,184,2,185,7,185,2,186,7,186,2,187, - 7,187,2,188,7,188,2,189,7,189,2,190,7,190,1,0,1,0,1,0,1,0,1,1,1,1,1,1, - 1,1,1,2,1,2,1,2,1,2,1,2,1,3,1,3,1,3,1,3,1,4,1,4,1,4,1,4,1,4,1,4,1,5,1, - 5,1,5,1,6,1,6,1,6,1,6,1,6,1,6,1,6,1,6,1,6,1,6,1,6,1,6,1,6,1,6,3,6,426, - 8,6,1,7,1,7,1,7,1,7,1,7,1,8,1,8,1,8,1,8,1,8,1,8,1,8,1,8,1,9,1,9,1,9,1, - 9,1,9,1,10,1,10,1,10,1,11,1,11,1,11,1,11,1,11,1,12,1,12,1,12,1,12,1,12, - 1,13,1,13,1,13,1,13,1,13,1,13,1,14,1,14,1,14,1,14,1,14,1,14,1,14,1,15, - 1,15,1,15,1,15,1,15,1,15,1,15,1,15,1,16,1,16,1,16,1,16,1,16,1,16,1,17, - 1,17,1,17,1,17,1,17,1,18,1,18,1,18,1,18,1,18,1,18,1,18,1,18,1,19,1,19, - 1,19,1,19,1,19,1,20,1,20,1,20,1,20,1,21,1,21,1,21,1,21,1,21,1,22,1,22, - 1,22,1,22,1,22,1,22,1,22,1,22,1,22,1,22,1,22,1,23,1,23,1,23,1,23,1,23, - 1,23,1,23,1,23,1,23,1,24,1,24,1,24,1,24,1,24,1,25,1,25,1,25,1,25,1,26, - 1,26,1,26,1,26,1,26,1,26,1,26,1,26,1,27,1,27,1,27,1,27,1,27,1,27,1,28, - 1,28,1,28,1,28,1,28,1,28,1,28,1,28,1,29,1,29,1,29,1,29,1,29,1,29,1,30, - 1,30,1,30,1,31,1,31,1,31,1,31,1,31,1,31,1,31,1,31,1,31,1,31,1,32,1,32, - 1,32,1,32,1,33,1,33,1,33,1,33,1,33,1,34,1,34,1,34,1,34,1,34,1,35,1,35, - 1,35,1,35,1,36,1,36,1,36,1,36,1,36,1,36,1,37,1,37,1,37,1,37,1,37,1,37, - 1,37,1,38,1,38,1,38,1,38,1,38,1,39,1,39,1,39,1,40,1,40,1,40,1,41,1,41, - 1,41,1,41,1,41,1,41,1,42,1,42,1,42,1,43,1,43,1,43,1,43,1,43,1,43,1,43, - 1,43,1,43,1,43,1,43,1,43,1,43,3,43,647,8,43,1,44,1,44,1,44,1,44,1,44, - 1,44,1,45,1,45,1,45,1,45,1,45,1,45,1,45,1,45,1,45,1,46,1,46,1,46,1,47, - 1,47,1,47,1,47,1,47,1,48,1,48,1,48,1,48,1,49,1,49,1,49,1,49,1,49,1,50, - 1,50,1,50,1,50,1,50,1,50,1,50,1,50,1,51,1,51,1,51,1,51,1,51,1,52,1,52, - 1,52,1,52,1,53,1,53,1,53,1,53,1,53,1,54,1,54,1,54,1,54,1,54,1,54,1,55, - 1,55,1,55,1,55,1,55,1,55,1,55,1,56,1,56,1,56,1,56,1,56,1,56,1,57,1,57, - 1,57,1,57,1,58,1,58,1,58,1,58,1,59,1,59,1,59,1,59,1,59,1,60,1,60,1,60, - 1,60,1,60,1,60,1,61,1,61,1,61,1,61,1,61,1,61,1,61,1,62,1,62,1,62,1,63, - 1,63,1,63,1,64,1,64,1,64,1,64,1,64,1,64,1,65,1,65,1,65,1,65,1,65,1,65, - 1,66,1,66,1,66,1,66,1,66,1,67,1,67,1,67,1,67,1,67,1,67,1,67,1,67,1,67, - 1,67,1,68,1,68,1,68,1,68,1,68,1,68,1,68,1,68,1,68,1,68,1,69,1,69,1,69, - 1,69,1,69,1,69,1,69,1,69,1,69,1,70,1,70,1,70,1,70,1,70,1,70,1,70,1,70, - 1,71,1,71,1,71,1,71,1,71,1,71,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,73, - 1,73,1,73,1,73,1,73,1,73,1,74,1,74,1,74,1,74,1,74,1,74,1,74,1,75,1,75, - 1,75,1,75,1,76,1,76,1,76,1,76,1,76,1,77,1,77,1,77,1,77,1,77,1,77,1,77, - 1,78,1,78,1,78,1,78,1,78,1,78,1,78,1,79,1,79,1,79,1,79,1,79,1,79,1,79, - 1,80,1,80,1,80,1,80,1,80,1,81,1,81,1,81,1,81,1,81,1,81,1,81,1,81,1,81, - 1,82,1,82,1,82,1,82,1,82,1,82,1,82,1,82,1,82,1,82,1,83,1,83,1,83,1,83, - 1,83,1,84,1,84,1,84,1,84,1,84,1,84,1,85,1,85,1,85,1,85,1,85,1,86,1,86, - 1,86,1,86,1,86,1,86,1,86,1,86,1,86,1,86,1,87,1,87,1,87,1,88,1,88,1,88, - 1,88,1,89,1,89,1,89,1,89,1,89,1,89,1,89,1,90,1,90,1,90,1,90,1,90,1,90, - 1,90,1,90,1,90,1,91,1,91,1,91,1,91,1,91,1,92,1,92,1,92,1,92,1,92,1,92, - 1,92,1,92,1,92,1,93,1,93,1,93,1,93,1,94,1,94,1,94,1,94,1,94,1,94,1,94, - 1,94,1,94,1,94,1,95,1,95,1,95,1,95,1,95,1,95,1,96,1,96,1,96,1,96,1,96, - 1,96,1,97,1,97,1,97,1,97,1,97,1,98,1,98,1,98,1,98,1,98,1,99,1,99,1,99, - 1,99,1,99,1,99,1,100,1,100,1,100,1,100,1,100,1,100,1,101,1,101,1,101, - 1,101,1,101,1,101,1,101,1,102,1,102,1,102,1,102,1,102,1,103,1,103,1,103, - 1,103,1,103,1,103,1,103,1,103,1,103,1,103,3,103,1021,8,103,1,104,1,104, - 1,104,1,104,1,104,1,104,1,104,1,104,1,104,1,104,1,104,1,104,1,104,1,104, - 1,104,1,104,1,104,1,104,1,104,1,104,1,104,1,104,1,104,1,104,1,104,1,104, - 1,104,3,104,1050,8,104,1,105,1,105,1,105,3,105,1055,8,105,1,105,1,105, - 1,105,1,105,5,105,1061,8,105,10,105,12,105,1064,9,105,1,105,1,105,1,105, - 1,105,1,105,1,105,1,105,1,105,1,105,5,105,1075,8,105,10,105,12,105,1078, - 9,105,1,105,1,105,1,105,1,105,1,105,1,105,1,105,1,105,1,105,1,105,1,105, - 5,105,1091,8,105,10,105,12,105,1094,9,105,1,105,1,105,3,105,1098,8,105, - 1,106,1,106,1,106,5,106,1103,8,106,10,106,12,106,1106,9,106,1,106,1,106, - 3,106,1110,8,106,1,106,1,106,3,106,1114,8,106,1,106,4,106,1117,8,106, - 11,106,12,106,1118,1,106,1,106,1,106,3,106,1124,8,106,1,106,1,106,3,106, - 1128,8,106,1,106,4,106,1131,8,106,11,106,12,106,1132,1,106,1,106,1,106, - 5,106,1138,8,106,10,106,12,106,1141,9,106,1,106,1,106,1,106,3,106,1146, - 8,106,1,106,4,106,1149,8,106,11,106,12,106,1150,1,106,1,106,1,106,1,106, - 1,106,3,106,1158,8,106,1,106,4,106,1161,8,106,11,106,12,106,1162,1,106, - 1,106,1,106,1,106,3,106,1169,8,106,1,106,4,106,1172,8,106,11,106,12,106, - 1173,3,106,1176,8,106,1,107,1,107,4,107,1180,8,107,11,107,12,107,1181, - 1,108,4,108,1185,8,108,11,108,12,108,1186,1,109,1,109,1,109,4,109,1192, - 8,109,11,109,12,109,1193,1,110,1,110,1,110,1,110,1,110,1,110,1,110,1, - 110,1,110,5,110,1205,8,110,10,110,12,110,1208,9,110,1,110,1,110,1,111, - 1,111,1,112,1,112,1,113,1,113,1,114,1,114,1,115,1,115,1,116,1,116,1,117, - 1,117,1,118,1,118,1,119,1,119,1,120,1,120,1,121,1,121,1,122,1,122,1,123, - 1,123,1,124,1,124,1,125,1,125,1,126,1,126,1,127,1,127,1,128,1,128,1,129, - 1,129,1,130,1,130,1,131,1,131,1,132,1,132,1,133,1,133,1,134,1,134,1,135, - 1,135,1,136,1,136,1,137,1,137,1,138,1,138,1,139,1,139,1,140,1,140,1,141, - 1,141,1,141,1,142,1,142,1,143,1,143,1,144,1,144,1,145,1,145,1,146,1,146, - 1,147,1,147,1,147,1,148,1,148,1,149,1,149,1,150,1,150,1,151,1,151,1,151, - 1,152,1,152,1,153,1,153,1,153,1,154,1,154,1,155,1,155,1,156,1,156,1,156, - 1,157,1,157,1,157,1,157,1,158,1,158,1,158,1,158,1,159,1,159,1,160,1,160, - 1,161,1,161,1,161,1,162,1,162,1,163,1,163,1,163,1,163,3,163,1330,8,163, - 1,164,1,164,1,164,1,164,1,165,1,165,1,165,1,166,1,166,1,166,1,167,1,167, - 1,167,1,168,1,168,1,169,1,169,1,170,1,170,1,171,1,171,1,172,1,172,1,172, - 1,172,1,172,1,173,1,173,1,173,1,173,1,173,1,174,1,174,1,175,1,175,1,176, - 1,176,1,176,1,177,1,177,1,177,1,177,1,178,1,178,1,179,1,179,1,180,1,180, - 1,181,1,181,1,182,1,182,1,183,1,183,1,183,1,183,5,183,1388,8,183,10,183, - 12,183,1391,9,183,1,183,1,183,1,183,1,183,1,183,1,184,1,184,1,184,1,184, - 3,184,1402,8,184,1,184,5,184,1405,8,184,10,184,12,184,1408,9,184,1,184, - 3,184,1411,8,184,1,184,1,184,1,185,1,185,1,185,1,185,1,186,1,186,1,186, - 1,186,1,186,1,186,1,186,1,186,1,186,1,186,1,186,4,186,1430,8,186,11,186, - 12,186,1431,1,187,1,187,1,187,1,187,1,188,1,188,1,188,1,188,1,188,1,189, - 1,189,1,189,1,189,1,189,4,189,1448,8,189,11,189,12,189,1449,1,190,1,190, - 1,190,1,190,1,1389,0,191,3,1,5,2,7,3,9,4,11,5,13,6,15,7,17,8,19,9,21, - 10,23,11,25,12,27,13,29,14,31,15,33,16,35,17,37,18,39,19,41,20,43,21, - 45,22,47,23,49,24,51,25,53,26,55,27,57,28,59,29,61,30,63,31,65,32,67, - 33,69,34,71,35,73,36,75,37,77,38,79,39,81,40,83,41,85,42,87,43,89,44, - 91,45,93,46,95,47,97,48,99,49,101,50,103,51,105,52,107,53,109,54,111, - 55,113,56,115,57,117,58,119,59,121,60,123,61,125,62,127,63,129,64,131, - 65,133,66,135,67,137,68,139,69,141,70,143,71,145,72,147,73,149,74,151, - 75,153,76,155,77,157,78,159,79,161,80,163,81,165,82,167,83,169,84,171, - 85,173,86,175,87,177,88,179,89,181,90,183,91,185,92,187,93,189,94,191, - 95,193,96,195,97,197,98,199,99,201,100,203,101,205,102,207,103,209,104, - 211,105,213,106,215,107,217,108,219,109,221,110,223,111,225,0,227,0,229, - 0,231,0,233,0,235,0,237,0,239,0,241,0,243,0,245,0,247,0,249,0,251,0,253, - 0,255,0,257,0,259,0,261,0,263,0,265,0,267,0,269,0,271,0,273,0,275,0,277, - 0,279,0,281,0,283,0,285,112,287,113,289,114,291,115,293,116,295,117,297, - 118,299,119,301,120,303,121,305,122,307,123,309,124,311,125,313,126,315, - 127,317,128,319,129,321,130,323,131,325,132,327,133,329,134,331,135,333, - 136,335,137,337,138,339,139,341,140,343,141,345,142,347,143,349,144,351, - 145,353,146,355,147,357,148,359,149,361,150,363,151,365,152,367,153,369, - 154,371,155,373,156,375,157,377,158,379,0,381,159,383,160,3,0,1,2,38, + 7,187,2,188,7,188,2,189,7,189,2,190,7,190,2,191,7,191,2,192,7,192,1,0, + 1,0,1,0,1,0,1,1,1,1,1,1,1,1,1,2,1,2,1,2,1,2,1,2,1,3,1,3,1,3,1,3,1,4,1, + 4,1,4,1,4,1,4,1,4,1,5,1,5,1,5,1,6,1,6,1,6,1,6,1,6,1,6,1,6,1,6,1,6,1,6, + 1,6,1,6,1,6,1,6,3,6,430,8,6,1,7,1,7,1,7,1,7,1,7,1,8,1,8,1,8,1,8,1,8,1, + 8,1,8,1,8,1,9,1,9,1,9,1,9,1,9,1,10,1,10,1,10,1,11,1,11,1,11,1,11,1,11, + 1,12,1,12,1,12,1,12,1,12,1,13,1,13,1,13,1,13,1,13,1,13,1,14,1,14,1,14, + 1,14,1,14,1,14,1,14,1,15,1,15,1,15,1,15,1,15,1,15,1,15,1,15,1,16,1,16, + 1,16,1,16,1,16,1,16,1,17,1,17,1,17,1,17,1,17,1,18,1,18,1,18,1,18,1,18, + 1,18,1,18,1,18,1,19,1,19,1,19,1,19,1,19,1,20,1,20,1,20,1,20,1,21,1,21, + 1,21,1,21,1,21,1,22,1,22,1,22,1,22,1,22,1,22,1,22,1,22,1,22,1,22,1,22, + 1,23,1,23,1,23,1,23,1,23,1,23,1,23,1,23,1,23,1,24,1,24,1,24,1,24,1,24, + 1,25,1,25,1,25,1,25,1,26,1,26,1,26,1,26,1,26,1,26,1,26,1,27,1,27,1,27, + 1,27,1,27,1,27,1,27,1,27,1,28,1,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,30,1,30,1,30,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,1,32,1,32,1,33,1,33,1,33,1,33, + 1,34,1,34,1,34,1,34,1,34,1,35,1,35,1,35,1,35,1,35,1,36,1,36,1,36,1,36, + 1,37,1,37,1,37,1,37,1,37,1,37,1,38,1,38,1,38,1,38,1,38,1,38,1,38,1,39, + 1,39,1,39,1,39,1,39,1,40,1,40,1,40,1,41,1,41,1,41,1,42,1,42,1,42,1,42, + 1,42,1,42,1,43,1,43,1,43,1,44,1,44,1,44,1,44,1,44,1,44,1,44,1,44,1,44, + 1,44,1,44,1,44,1,44,3,44,658,8,44,1,45,1,45,1,45,1,45,1,45,1,45,1,46, + 1,46,1,46,1,46,1,46,1,46,1,46,1,46,1,46,1,46,1,47,1,47,1,47,1,47,1,47, + 1,47,1,47,1,47,1,47,1,48,1,48,1,48,1,49,1,49,1,49,1,49,1,49,1,50,1,50, + 1,50,1,50,1,51,1,51,1,51,1,51,1,51,1,52,1,52,1,52,1,52,1,52,1,52,1,52, + 1,52,1,53,1,53,1,53,1,53,1,53,1,54,1,54,1,54,1,54,1,55,1,55,1,55,1,55, + 1,55,1,56,1,56,1,56,1,56,1,56,1,56,1,57,1,57,1,57,1,57,1,57,1,57,1,57, + 1,58,1,58,1,58,1,58,1,58,1,58,1,59,1,59,1,59,1,59,1,60,1,60,1,60,1,60, + 1,61,1,61,1,61,1,61,1,61,1,62,1,62,1,62,1,62,1,62,1,62,1,63,1,63,1,63, + 1,63,1,63,1,63,1,63,1,64,1,64,1,64,1,65,1,65,1,65,1,66,1,66,1,66,1,66, + 1,66,1,66,1,67,1,67,1,67,1,67,1,67,1,67,1,68,1,68,1,68,1,68,1,68,1,69, + 1,69,1,69,1,69,1,69,1,69,1,69,1,69,1,69,1,69,1,70,1,70,1,70,1,70,1,70, + 1,70,1,70,1,70,1,70,1,70,1,71,1,71,1,71,1,71,1,71,1,71,1,71,1,71,1,71, + 1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,73,1,73,1,73,1,73,1,73,1,73, + 1,74,1,74,1,74,1,74,1,74,1,74,1,74,1,75,1,75,1,75,1,75,1,75,1,75,1,76, + 1,76,1,76,1,76,1,76,1,76,1,76,1,77,1,77,1,77,1,77,1,78,1,78,1,78,1,78, + 1,78,1,79,1,79,1,79,1,79,1,79,1,79,1,79,1,80,1,80,1,80,1,80,1,80,1,80, + 1,80,1,81,1,81,1,81,1,81,1,81,1,81,1,81,1,82,1,82,1,82,1,82,1,82,1,83, + 1,83,1,83,1,83,1,83,1,83,1,83,1,83,1,83,1,84,1,84,1,84,1,84,1,84,1,84, + 1,84,1,84,1,84,1,84,1,85,1,85,1,85,1,85,1,85,1,86,1,86,1,86,1,86,1,86, + 1,86,1,87,1,87,1,87,1,87,1,87,1,88,1,88,1,88,1,88,1,88,1,88,1,88,1,88, + 1,88,1,88,1,89,1,89,1,89,1,90,1,90,1,90,1,90,1,91,1,91,1,91,1,91,1,91, + 1,91,1,91,1,92,1,92,1,92,1,92,1,92,1,92,1,92,1,92,1,92,1,93,1,93,1,93, + 1,93,1,93,1,94,1,94,1,94,1,94,1,94,1,94,1,94,1,94,1,94,1,95,1,95,1,95, + 1,95,1,96,1,96,1,96,1,96,1,96,1,96,1,96,1,96,1,96,1,96,1,97,1,97,1,97, + 1,97,1,97,1,97,1,98,1,98,1,98,1,98,1,98,1,98,1,99,1,99,1,99,1,99,1,99, + 1,100,1,100,1,100,1,100,1,100,1,101,1,101,1,101,1,101,1,101,1,101,1,102, + 1,102,1,102,1,102,1,102,1,102,1,103,1,103,1,103,1,103,1,103,1,103,1,103, + 1,104,1,104,1,104,1,104,1,104,1,105,1,105,1,105,1,105,1,105,1,105,1,105, + 1,105,1,105,1,105,3,105,1042,8,105,1,106,1,106,1,106,1,106,1,106,1,106, + 1,106,1,106,1,106,1,106,1,106,1,106,1,106,1,106,1,106,1,106,1,106,1,106, + 1,106,1,106,1,106,1,106,1,106,1,106,1,106,1,106,1,106,3,106,1071,8,106, + 1,107,1,107,1,107,3,107,1076,8,107,1,107,1,107,1,107,1,107,5,107,1082, + 8,107,10,107,12,107,1085,9,107,1,107,1,107,1,107,1,107,1,107,1,107,1, + 107,1,107,1,107,5,107,1096,8,107,10,107,12,107,1099,9,107,1,107,1,107, + 1,107,1,107,1,107,1,107,1,107,1,107,1,107,1,107,1,107,5,107,1112,8,107, + 10,107,12,107,1115,9,107,1,107,1,107,3,107,1119,8,107,1,108,1,108,1,108, + 5,108,1124,8,108,10,108,12,108,1127,9,108,1,108,1,108,3,108,1131,8,108, + 1,108,1,108,3,108,1135,8,108,1,108,4,108,1138,8,108,11,108,12,108,1139, + 1,108,1,108,1,108,3,108,1145,8,108,1,108,1,108,3,108,1149,8,108,1,108, + 4,108,1152,8,108,11,108,12,108,1153,1,108,1,108,1,108,5,108,1159,8,108, + 10,108,12,108,1162,9,108,1,108,1,108,1,108,3,108,1167,8,108,1,108,4,108, + 1170,8,108,11,108,12,108,1171,1,108,1,108,1,108,1,108,1,108,3,108,1179, + 8,108,1,108,4,108,1182,8,108,11,108,12,108,1183,1,108,1,108,1,108,1,108, + 3,108,1190,8,108,1,108,4,108,1193,8,108,11,108,12,108,1194,3,108,1197, + 8,108,1,109,1,109,4,109,1201,8,109,11,109,12,109,1202,1,110,4,110,1206, + 8,110,11,110,12,110,1207,1,111,1,111,1,111,4,111,1213,8,111,11,111,12, + 111,1214,1,112,1,112,1,112,1,112,1,112,1,112,1,112,1,112,1,112,5,112, + 1226,8,112,10,112,12,112,1229,9,112,1,112,1,112,1,113,1,113,1,114,1,114, + 1,115,1,115,1,116,1,116,1,117,1,117,1,118,1,118,1,119,1,119,1,120,1,120, + 1,121,1,121,1,122,1,122,1,123,1,123,1,124,1,124,1,125,1,125,1,126,1,126, + 1,127,1,127,1,128,1,128,1,129,1,129,1,130,1,130,1,131,1,131,1,132,1,132, + 1,133,1,133,1,134,1,134,1,135,1,135,1,136,1,136,1,137,1,137,1,138,1,138, + 1,139,1,139,1,140,1,140,1,141,1,141,1,142,1,142,1,143,1,143,1,143,1,144, + 1,144,1,145,1,145,1,146,1,146,1,147,1,147,1,148,1,148,1,149,1,149,1,149, + 1,150,1,150,1,151,1,151,1,152,1,152,1,153,1,153,1,153,1,154,1,154,1,155, + 1,155,1,155,1,156,1,156,1,157,1,157,1,158,1,158,1,158,1,159,1,159,1,159, + 1,159,1,160,1,160,1,160,1,160,1,161,1,161,1,162,1,162,1,163,1,163,1,163, + 1,164,1,164,1,165,1,165,1,165,1,165,3,165,1351,8,165,1,166,1,166,1,166, + 1,166,1,167,1,167,1,167,1,168,1,168,1,168,1,169,1,169,1,169,1,170,1,170, + 1,171,1,171,1,172,1,172,1,173,1,173,1,174,1,174,1,174,1,174,1,174,1,175, + 1,175,1,175,1,175,1,175,1,176,1,176,1,177,1,177,1,178,1,178,1,178,1,179, + 1,179,1,179,1,179,1,180,1,180,1,181,1,181,1,182,1,182,1,183,1,183,1,184, + 1,184,1,185,1,185,1,185,1,185,5,185,1409,8,185,10,185,12,185,1412,9,185, + 1,185,1,185,1,185,1,185,1,185,1,186,1,186,1,186,1,186,3,186,1423,8,186, + 1,186,5,186,1426,8,186,10,186,12,186,1429,9,186,1,186,3,186,1432,8,186, + 1,186,1,186,1,187,1,187,1,187,1,187,1,188,1,188,1,188,1,188,1,188,1,188, + 1,188,1,188,1,188,1,188,1,188,4,188,1451,8,188,11,188,12,188,1452,1,189, + 1,189,1,189,1,189,1,190,1,190,1,190,1,190,1,190,1,191,1,191,1,191,1,191, + 1,191,4,191,1469,8,191,11,191,12,191,1470,1,192,1,192,1,192,1,192,1,1410, + 0,193,3,1,5,2,7,3,9,4,11,5,13,6,15,7,17,8,19,9,21,10,23,11,25,12,27,13, + 29,14,31,15,33,16,35,17,37,18,39,19,41,20,43,21,45,22,47,23,49,24,51, + 25,53,26,55,27,57,28,59,29,61,30,63,31,65,32,67,33,69,34,71,35,73,36, + 75,37,77,38,79,39,81,40,83,41,85,42,87,43,89,44,91,45,93,46,95,47,97, + 48,99,49,101,50,103,51,105,52,107,53,109,54,111,55,113,56,115,57,117, + 58,119,59,121,60,123,61,125,62,127,63,129,64,131,65,133,66,135,67,137, + 68,139,69,141,70,143,71,145,72,147,73,149,74,151,75,153,76,155,77,157, + 78,159,79,161,80,163,81,165,82,167,83,169,84,171,85,173,86,175,87,177, + 88,179,89,181,90,183,91,185,92,187,93,189,94,191,95,193,96,195,97,197, + 98,199,99,201,100,203,101,205,102,207,103,209,104,211,105,213,106,215, + 107,217,108,219,109,221,110,223,111,225,112,227,113,229,0,231,0,233,0, + 235,0,237,0,239,0,241,0,243,0,245,0,247,0,249,0,251,0,253,0,255,0,257, + 0,259,0,261,0,263,0,265,0,267,0,269,0,271,0,273,0,275,0,277,0,279,0,281, + 0,283,0,285,0,287,0,289,114,291,115,293,116,295,117,297,118,299,119,301, + 120,303,121,305,122,307,123,309,124,311,125,313,126,315,127,317,128,319, + 129,321,130,323,131,325,132,327,133,329,134,331,135,333,136,335,137,337, + 138,339,139,341,140,343,141,345,142,347,143,349,144,351,145,353,146,355, + 147,357,148,359,149,361,150,363,151,365,152,367,153,369,154,371,155,373, + 156,375,157,377,158,379,159,381,160,383,0,385,161,387,162,3,0,1,2,38, 2,0,92,92,96,96,2,0,34,34,92,92,2,0,39,39,92,92,2,0,65,65,97,97,2,0,66, 66,98,98,2,0,67,67,99,99,2,0,68,68,100,100,2,0,69,69,101,101,2,0,70,70, 102,102,2,0,71,71,103,103,2,0,72,72,104,104,2,0,73,73,105,105,2,0,74, @@ -276,7 +278,7 @@ void hogqllexerLexerInitialize() { 2,0,86,86,118,118,2,0,87,87,119,119,2,0,88,88,120,120,2,0,89,89,121,121, 2,0,90,90,122,122,2,0,65,90,97,122,1,0,48,55,1,0,48,57,3,0,48,57,65,70, 97,102,2,0,10,10,13,13,2,1,10,10,13,13,2,0,9,13,32,32,3,0,39,39,92,92, - 123,123,1,0,123,123,1491,0,3,1,0,0,0,0,5,1,0,0,0,0,7,1,0,0,0,0,9,1,0, + 123,123,1,0,123,123,1512,0,3,1,0,0,0,0,5,1,0,0,0,0,7,1,0,0,0,0,9,1,0, 0,0,0,11,1,0,0,0,0,13,1,0,0,0,0,15,1,0,0,0,0,17,1,0,0,0,0,19,1,0,0,0, 0,21,1,0,0,0,0,23,1,0,0,0,0,25,1,0,0,0,0,27,1,0,0,0,0,29,1,0,0,0,0,31, 1,0,0,0,0,33,1,0,0,0,0,35,1,0,0,0,0,37,1,0,0,0,0,39,1,0,0,0,0,41,1,0, @@ -297,8 +299,8 @@ void hogqllexerLexerInitialize() { 0,0,0,0,187,1,0,0,0,0,189,1,0,0,0,0,191,1,0,0,0,0,193,1,0,0,0,0,195,1, 0,0,0,0,197,1,0,0,0,0,199,1,0,0,0,0,201,1,0,0,0,0,203,1,0,0,0,0,205,1, 0,0,0,0,207,1,0,0,0,0,209,1,0,0,0,0,211,1,0,0,0,0,213,1,0,0,0,0,215,1, - 0,0,0,0,217,1,0,0,0,0,219,1,0,0,0,0,221,1,0,0,0,0,223,1,0,0,0,0,285,1, - 0,0,0,0,287,1,0,0,0,0,289,1,0,0,0,0,291,1,0,0,0,0,293,1,0,0,0,0,295,1, + 0,0,0,0,217,1,0,0,0,0,219,1,0,0,0,0,221,1,0,0,0,0,223,1,0,0,0,0,225,1, + 0,0,0,0,227,1,0,0,0,0,289,1,0,0,0,0,291,1,0,0,0,0,293,1,0,0,0,0,295,1, 0,0,0,0,297,1,0,0,0,0,299,1,0,0,0,0,301,1,0,0,0,0,303,1,0,0,0,0,305,1, 0,0,0,0,307,1,0,0,0,0,309,1,0,0,0,0,311,1,0,0,0,0,313,1,0,0,0,0,315,1, 0,0,0,0,317,1,0,0,0,0,319,1,0,0,0,0,321,1,0,0,0,0,323,1,0,0,0,0,325,1, @@ -306,365 +308,371 @@ void hogqllexerLexerInitialize() { 0,0,0,0,337,1,0,0,0,0,339,1,0,0,0,0,341,1,0,0,0,0,343,1,0,0,0,0,345,1, 0,0,0,0,347,1,0,0,0,0,349,1,0,0,0,0,351,1,0,0,0,0,353,1,0,0,0,0,355,1, 0,0,0,0,357,1,0,0,0,0,359,1,0,0,0,0,361,1,0,0,0,0,363,1,0,0,0,0,365,1, - 0,0,0,0,367,1,0,0,0,0,369,1,0,0,0,0,371,1,0,0,0,0,373,1,0,0,0,1,375,1, - 0,0,0,1,377,1,0,0,0,1,379,1,0,0,0,2,381,1,0,0,0,2,383,1,0,0,0,3,385,1, - 0,0,0,5,389,1,0,0,0,7,393,1,0,0,0,9,398,1,0,0,0,11,402,1,0,0,0,13,408, - 1,0,0,0,15,425,1,0,0,0,17,427,1,0,0,0,19,432,1,0,0,0,21,440,1,0,0,0,23, - 445,1,0,0,0,25,448,1,0,0,0,27,453,1,0,0,0,29,458,1,0,0,0,31,464,1,0,0, - 0,33,471,1,0,0,0,35,479,1,0,0,0,37,485,1,0,0,0,39,490,1,0,0,0,41,498, - 1,0,0,0,43,503,1,0,0,0,45,507,1,0,0,0,47,512,1,0,0,0,49,523,1,0,0,0,51, - 532,1,0,0,0,53,537,1,0,0,0,55,541,1,0,0,0,57,549,1,0,0,0,59,555,1,0,0, - 0,61,563,1,0,0,0,63,569,1,0,0,0,65,572,1,0,0,0,67,582,1,0,0,0,69,586, - 1,0,0,0,71,591,1,0,0,0,73,596,1,0,0,0,75,600,1,0,0,0,77,606,1,0,0,0,79, - 613,1,0,0,0,81,618,1,0,0,0,83,621,1,0,0,0,85,624,1,0,0,0,87,630,1,0,0, - 0,89,646,1,0,0,0,91,648,1,0,0,0,93,654,1,0,0,0,95,663,1,0,0,0,97,666, - 1,0,0,0,99,671,1,0,0,0,101,675,1,0,0,0,103,680,1,0,0,0,105,688,1,0,0, - 0,107,693,1,0,0,0,109,697,1,0,0,0,111,702,1,0,0,0,113,708,1,0,0,0,115, - 715,1,0,0,0,117,721,1,0,0,0,119,725,1,0,0,0,121,729,1,0,0,0,123,734,1, - 0,0,0,125,740,1,0,0,0,127,747,1,0,0,0,129,750,1,0,0,0,131,753,1,0,0,0, - 133,759,1,0,0,0,135,765,1,0,0,0,137,770,1,0,0,0,139,780,1,0,0,0,141,790, - 1,0,0,0,143,799,1,0,0,0,145,807,1,0,0,0,147,813,1,0,0,0,149,820,1,0,0, - 0,151,826,1,0,0,0,153,833,1,0,0,0,155,837,1,0,0,0,157,842,1,0,0,0,159, - 849,1,0,0,0,161,856,1,0,0,0,163,863,1,0,0,0,165,868,1,0,0,0,167,877,1, - 0,0,0,169,887,1,0,0,0,171,892,1,0,0,0,173,898,1,0,0,0,175,903,1,0,0,0, - 177,913,1,0,0,0,179,916,1,0,0,0,181,920,1,0,0,0,183,927,1,0,0,0,185,936, - 1,0,0,0,187,941,1,0,0,0,189,950,1,0,0,0,191,954,1,0,0,0,193,964,1,0,0, - 0,195,970,1,0,0,0,197,976,1,0,0,0,199,981,1,0,0,0,201,986,1,0,0,0,203, - 992,1,0,0,0,205,998,1,0,0,0,207,1005,1,0,0,0,209,1020,1,0,0,0,211,1049, - 1,0,0,0,213,1097,1,0,0,0,215,1175,1,0,0,0,217,1177,1,0,0,0,219,1184,1, - 0,0,0,221,1188,1,0,0,0,223,1195,1,0,0,0,225,1211,1,0,0,0,227,1213,1,0, - 0,0,229,1215,1,0,0,0,231,1217,1,0,0,0,233,1219,1,0,0,0,235,1221,1,0,0, - 0,237,1223,1,0,0,0,239,1225,1,0,0,0,241,1227,1,0,0,0,243,1229,1,0,0,0, - 245,1231,1,0,0,0,247,1233,1,0,0,0,249,1235,1,0,0,0,251,1237,1,0,0,0,253, - 1239,1,0,0,0,255,1241,1,0,0,0,257,1243,1,0,0,0,259,1245,1,0,0,0,261,1247, - 1,0,0,0,263,1249,1,0,0,0,265,1251,1,0,0,0,267,1253,1,0,0,0,269,1255,1, - 0,0,0,271,1257,1,0,0,0,273,1259,1,0,0,0,275,1261,1,0,0,0,277,1263,1,0, - 0,0,279,1265,1,0,0,0,281,1267,1,0,0,0,283,1269,1,0,0,0,285,1271,1,0,0, - 0,287,1274,1,0,0,0,289,1276,1,0,0,0,291,1278,1,0,0,0,293,1280,1,0,0,0, - 295,1282,1,0,0,0,297,1284,1,0,0,0,299,1287,1,0,0,0,301,1289,1,0,0,0,303, - 1291,1,0,0,0,305,1293,1,0,0,0,307,1296,1,0,0,0,309,1298,1,0,0,0,311,1301, - 1,0,0,0,313,1303,1,0,0,0,315,1305,1,0,0,0,317,1308,1,0,0,0,319,1312,1, - 0,0,0,321,1316,1,0,0,0,323,1318,1,0,0,0,325,1320,1,0,0,0,327,1323,1,0, - 0,0,329,1329,1,0,0,0,331,1331,1,0,0,0,333,1335,1,0,0,0,335,1338,1,0,0, - 0,337,1341,1,0,0,0,339,1344,1,0,0,0,341,1346,1,0,0,0,343,1348,1,0,0,0, - 345,1350,1,0,0,0,347,1352,1,0,0,0,349,1357,1,0,0,0,351,1362,1,0,0,0,353, - 1364,1,0,0,0,355,1366,1,0,0,0,357,1369,1,0,0,0,359,1373,1,0,0,0,361,1375, - 1,0,0,0,363,1377,1,0,0,0,365,1379,1,0,0,0,367,1381,1,0,0,0,369,1383,1, - 0,0,0,371,1401,1,0,0,0,373,1414,1,0,0,0,375,1429,1,0,0,0,377,1433,1,0, - 0,0,379,1437,1,0,0,0,381,1447,1,0,0,0,383,1451,1,0,0,0,385,386,3,225, - 111,0,386,387,3,247,122,0,387,388,3,247,122,0,388,4,1,0,0,0,389,390,3, - 225,111,0,390,391,3,251,124,0,391,392,3,231,114,0,392,6,1,0,0,0,393,394, - 3,225,111,0,394,395,3,251,124,0,395,396,3,263,130,0,396,397,3,241,119, - 0,397,8,1,0,0,0,398,399,3,225,111,0,399,400,3,251,124,0,400,401,3,273, - 135,0,401,10,1,0,0,0,402,403,3,225,111,0,403,404,3,259,128,0,404,405, - 3,259,128,0,405,406,3,225,111,0,406,407,3,273,135,0,407,12,1,0,0,0,408, - 409,3,225,111,0,409,410,3,261,129,0,410,14,1,0,0,0,411,412,3,225,111, - 0,412,413,3,261,129,0,413,414,3,229,113,0,414,426,1,0,0,0,415,416,3,225, - 111,0,416,417,3,261,129,0,417,418,3,229,113,0,418,419,3,233,115,0,419, - 420,3,251,124,0,420,421,3,231,114,0,421,422,3,241,119,0,422,423,3,251, - 124,0,423,424,3,237,117,0,424,426,1,0,0,0,425,411,1,0,0,0,425,415,1,0, - 0,0,426,16,1,0,0,0,427,428,3,225,111,0,428,429,3,261,129,0,429,430,3, - 253,125,0,430,431,3,235,116,0,431,18,1,0,0,0,432,433,3,227,112,0,433, - 434,3,233,115,0,434,435,3,263,130,0,435,436,3,269,133,0,436,437,3,233, - 115,0,437,438,3,233,115,0,438,439,3,251,124,0,439,20,1,0,0,0,440,441, - 3,227,112,0,441,442,3,253,125,0,442,443,3,263,130,0,443,444,3,239,118, - 0,444,22,1,0,0,0,445,446,3,227,112,0,446,447,3,273,135,0,447,24,1,0,0, - 0,448,449,3,229,113,0,449,450,3,225,111,0,450,451,3,261,129,0,451,452, - 3,233,115,0,452,26,1,0,0,0,453,454,3,229,113,0,454,455,3,225,111,0,455, - 456,3,261,129,0,456,457,3,263,130,0,457,28,1,0,0,0,458,459,3,229,113, - 0,459,460,3,225,111,0,460,461,3,263,130,0,461,462,3,229,113,0,462,463, - 3,239,118,0,463,30,1,0,0,0,464,465,3,229,113,0,465,466,3,253,125,0,466, - 467,3,239,118,0,467,468,3,253,125,0,468,469,3,259,128,0,469,470,3,263, - 130,0,470,32,1,0,0,0,471,472,3,229,113,0,472,473,3,253,125,0,473,474, - 3,247,122,0,474,475,3,247,122,0,475,476,3,225,111,0,476,477,3,263,130, - 0,477,478,3,233,115,0,478,34,1,0,0,0,479,480,3,229,113,0,480,481,3,259, - 128,0,481,482,3,253,125,0,482,483,3,261,129,0,483,484,3,261,129,0,484, - 36,1,0,0,0,485,486,3,229,113,0,486,487,3,265,131,0,487,488,3,227,112, - 0,488,489,3,233,115,0,489,38,1,0,0,0,490,491,3,229,113,0,491,492,3,265, - 131,0,492,493,3,259,128,0,493,494,3,259,128,0,494,495,3,233,115,0,495, - 496,3,251,124,0,496,497,3,263,130,0,497,40,1,0,0,0,498,499,3,231,114, - 0,499,500,3,225,111,0,500,501,3,263,130,0,501,502,3,233,115,0,502,42, - 1,0,0,0,503,504,3,231,114,0,504,505,3,225,111,0,505,506,3,273,135,0,506, - 44,1,0,0,0,507,508,3,231,114,0,508,509,3,233,115,0,509,510,3,261,129, - 0,510,511,3,229,113,0,511,46,1,0,0,0,512,513,3,231,114,0,513,514,3,233, - 115,0,514,515,3,261,129,0,515,516,3,229,113,0,516,517,3,233,115,0,517, - 518,3,251,124,0,518,519,3,231,114,0,519,520,3,241,119,0,520,521,3,251, - 124,0,521,522,3,237,117,0,522,48,1,0,0,0,523,524,3,231,114,0,524,525, - 3,241,119,0,525,526,3,261,129,0,526,527,3,263,130,0,527,528,3,241,119, - 0,528,529,3,251,124,0,529,530,3,229,113,0,530,531,3,263,130,0,531,50, - 1,0,0,0,532,533,3,233,115,0,533,534,3,247,122,0,534,535,3,261,129,0,535, - 536,3,233,115,0,536,52,1,0,0,0,537,538,3,233,115,0,538,539,3,251,124, - 0,539,540,3,231,114,0,540,54,1,0,0,0,541,542,3,233,115,0,542,543,3,271, - 134,0,543,544,3,263,130,0,544,545,3,259,128,0,545,546,3,225,111,0,546, - 547,3,229,113,0,547,548,3,263,130,0,548,56,1,0,0,0,549,550,3,235,116, - 0,550,551,3,241,119,0,551,552,3,251,124,0,552,553,3,225,111,0,553,554, - 3,247,122,0,554,58,1,0,0,0,555,556,3,235,116,0,556,557,3,241,119,0,557, - 558,3,251,124,0,558,559,3,225,111,0,559,560,3,247,122,0,560,561,3,247, - 122,0,561,562,3,273,135,0,562,60,1,0,0,0,563,564,3,235,116,0,564,565, - 3,241,119,0,565,566,3,259,128,0,566,567,3,261,129,0,567,568,3,263,130, - 0,568,62,1,0,0,0,569,570,3,235,116,0,570,571,3,251,124,0,571,64,1,0,0, - 0,572,573,3,235,116,0,573,574,3,253,125,0,574,575,3,247,122,0,575,576, - 3,247,122,0,576,577,3,253,125,0,577,578,3,269,133,0,578,579,3,241,119, - 0,579,580,3,251,124,0,580,581,3,237,117,0,581,66,1,0,0,0,582,583,3,235, - 116,0,583,584,3,253,125,0,584,585,3,259,128,0,585,68,1,0,0,0,586,587, - 3,235,116,0,587,588,3,259,128,0,588,589,3,253,125,0,589,590,3,249,123, - 0,590,70,1,0,0,0,591,592,3,235,116,0,592,593,3,265,131,0,593,594,3,247, - 122,0,594,595,3,247,122,0,595,72,1,0,0,0,596,597,3,235,116,0,597,598, - 3,265,131,0,598,599,3,251,124,0,599,74,1,0,0,0,600,601,3,237,117,0,601, - 602,3,259,128,0,602,603,3,253,125,0,603,604,3,265,131,0,604,605,3,255, - 126,0,605,76,1,0,0,0,606,607,3,239,118,0,607,608,3,225,111,0,608,609, - 3,267,132,0,609,610,3,241,119,0,610,611,3,251,124,0,611,612,3,237,117, - 0,612,78,1,0,0,0,613,614,3,239,118,0,614,615,3,253,125,0,615,616,3,265, - 131,0,616,617,3,259,128,0,617,80,1,0,0,0,618,619,3,241,119,0,619,620, - 3,231,114,0,620,82,1,0,0,0,621,622,3,241,119,0,622,623,3,235,116,0,623, - 84,1,0,0,0,624,625,3,241,119,0,625,626,3,247,122,0,626,627,3,241,119, - 0,627,628,3,245,121,0,628,629,3,233,115,0,629,86,1,0,0,0,630,631,3,241, - 119,0,631,632,3,251,124,0,632,88,1,0,0,0,633,634,3,241,119,0,634,635, - 3,251,124,0,635,636,3,235,116,0,636,647,1,0,0,0,637,638,3,241,119,0,638, - 639,3,251,124,0,639,640,3,235,116,0,640,641,3,241,119,0,641,642,3,251, - 124,0,642,643,3,241,119,0,643,644,3,263,130,0,644,645,3,273,135,0,645, - 647,1,0,0,0,646,633,1,0,0,0,646,637,1,0,0,0,647,90,1,0,0,0,648,649,3, - 241,119,0,649,650,3,251,124,0,650,651,3,251,124,0,651,652,3,233,115,0, - 652,653,3,259,128,0,653,92,1,0,0,0,654,655,3,241,119,0,655,656,3,251, - 124,0,656,657,3,263,130,0,657,658,3,233,115,0,658,659,3,259,128,0,659, - 660,3,267,132,0,660,661,3,225,111,0,661,662,3,247,122,0,662,94,1,0,0, - 0,663,664,3,241,119,0,664,665,3,261,129,0,665,96,1,0,0,0,666,667,3,243, - 120,0,667,668,3,253,125,0,668,669,3,241,119,0,669,670,3,251,124,0,670, - 98,1,0,0,0,671,672,3,245,121,0,672,673,3,233,115,0,673,674,3,273,135, - 0,674,100,1,0,0,0,675,676,3,247,122,0,676,677,3,225,111,0,677,678,3,261, - 129,0,678,679,3,263,130,0,679,102,1,0,0,0,680,681,3,247,122,0,681,682, - 3,233,115,0,682,683,3,225,111,0,683,684,3,231,114,0,684,685,3,241,119, - 0,685,686,3,251,124,0,686,687,3,237,117,0,687,104,1,0,0,0,688,689,3,247, - 122,0,689,690,3,233,115,0,690,691,3,235,116,0,691,692,3,263,130,0,692, - 106,1,0,0,0,693,694,3,247,122,0,694,695,3,233,115,0,695,696,3,263,130, - 0,696,108,1,0,0,0,697,698,3,247,122,0,698,699,3,241,119,0,699,700,3,245, - 121,0,700,701,3,233,115,0,701,110,1,0,0,0,702,703,3,247,122,0,703,704, - 3,241,119,0,704,705,3,249,123,0,705,706,3,241,119,0,706,707,3,263,130, - 0,707,112,1,0,0,0,708,709,3,249,123,0,709,710,3,241,119,0,710,711,3,251, - 124,0,711,712,3,265,131,0,712,713,3,263,130,0,713,714,3,233,115,0,714, - 114,1,0,0,0,715,716,3,249,123,0,716,717,3,253,125,0,717,718,3,251,124, - 0,718,719,3,263,130,0,719,720,3,239,118,0,720,116,1,0,0,0,721,722,3,251, - 124,0,722,723,3,225,111,0,723,724,3,251,124,0,724,118,1,0,0,0,725,726, - 3,251,124,0,726,727,3,253,125,0,727,728,3,263,130,0,728,120,1,0,0,0,729, - 730,3,251,124,0,730,731,3,265,131,0,731,732,3,247,122,0,732,733,3,247, - 122,0,733,122,1,0,0,0,734,735,3,251,124,0,735,736,3,265,131,0,736,737, - 3,247,122,0,737,738,3,247,122,0,738,739,3,261,129,0,739,124,1,0,0,0,740, - 741,3,253,125,0,741,742,3,235,116,0,742,743,3,235,116,0,743,744,3,261, - 129,0,744,745,3,233,115,0,745,746,3,263,130,0,746,126,1,0,0,0,747,748, - 3,253,125,0,748,749,3,251,124,0,749,128,1,0,0,0,750,751,3,253,125,0,751, - 752,3,259,128,0,752,130,1,0,0,0,753,754,3,253,125,0,754,755,3,259,128, - 0,755,756,3,231,114,0,756,757,3,233,115,0,757,758,3,259,128,0,758,132, - 1,0,0,0,759,760,3,253,125,0,760,761,3,265,131,0,761,762,3,263,130,0,762, - 763,3,233,115,0,763,764,3,259,128,0,764,134,1,0,0,0,765,766,3,253,125, - 0,766,767,3,267,132,0,767,768,3,233,115,0,768,769,3,259,128,0,769,136, - 1,0,0,0,770,771,3,255,126,0,771,772,3,225,111,0,772,773,3,259,128,0,773, - 774,3,263,130,0,774,775,3,241,119,0,775,776,3,263,130,0,776,777,3,241, - 119,0,777,778,3,253,125,0,778,779,3,251,124,0,779,138,1,0,0,0,780,781, - 3,255,126,0,781,782,3,259,128,0,782,783,3,233,115,0,783,784,3,229,113, - 0,784,785,3,233,115,0,785,786,3,231,114,0,786,787,3,241,119,0,787,788, - 3,251,124,0,788,789,3,237,117,0,789,140,1,0,0,0,790,791,3,255,126,0,791, - 792,3,259,128,0,792,793,3,233,115,0,793,794,3,269,133,0,794,795,3,239, - 118,0,795,796,3,233,115,0,796,797,3,259,128,0,797,798,3,233,115,0,798, - 142,1,0,0,0,799,800,3,257,127,0,800,801,3,265,131,0,801,802,3,225,111, - 0,802,803,3,259,128,0,803,804,3,263,130,0,804,805,3,233,115,0,805,806, - 3,259,128,0,806,144,1,0,0,0,807,808,3,259,128,0,808,809,3,225,111,0,809, - 810,3,251,124,0,810,811,3,237,117,0,811,812,3,233,115,0,812,146,1,0,0, - 0,813,814,3,259,128,0,814,815,3,233,115,0,815,816,3,263,130,0,816,817, - 3,265,131,0,817,818,3,259,128,0,818,819,3,251,124,0,819,148,1,0,0,0,820, - 821,3,259,128,0,821,822,3,241,119,0,822,823,3,237,117,0,823,824,3,239, - 118,0,824,825,3,263,130,0,825,150,1,0,0,0,826,827,3,259,128,0,827,828, - 3,253,125,0,828,829,3,247,122,0,829,830,3,247,122,0,830,831,3,265,131, - 0,831,832,3,255,126,0,832,152,1,0,0,0,833,834,3,259,128,0,834,835,3,253, - 125,0,835,836,3,269,133,0,836,154,1,0,0,0,837,838,3,259,128,0,838,839, - 3,253,125,0,839,840,3,269,133,0,840,841,3,261,129,0,841,156,1,0,0,0,842, - 843,3,261,129,0,843,844,3,225,111,0,844,845,3,249,123,0,845,846,3,255, - 126,0,846,847,3,247,122,0,847,848,3,233,115,0,848,158,1,0,0,0,849,850, - 3,261,129,0,850,851,3,233,115,0,851,852,3,229,113,0,852,853,3,253,125, - 0,853,854,3,251,124,0,854,855,3,231,114,0,855,160,1,0,0,0,856,857,3,261, - 129,0,857,858,3,233,115,0,858,859,3,247,122,0,859,860,3,233,115,0,860, - 861,3,229,113,0,861,862,3,263,130,0,862,162,1,0,0,0,863,864,3,261,129, - 0,864,865,3,233,115,0,865,866,3,249,123,0,866,867,3,241,119,0,867,164, - 1,0,0,0,868,869,3,261,129,0,869,870,3,233,115,0,870,871,3,263,130,0,871, - 872,3,263,130,0,872,873,3,241,119,0,873,874,3,251,124,0,874,875,3,237, - 117,0,875,876,3,261,129,0,876,166,1,0,0,0,877,878,3,261,129,0,878,879, - 3,265,131,0,879,880,3,227,112,0,880,881,3,261,129,0,881,882,3,263,130, - 0,882,883,3,259,128,0,883,884,3,241,119,0,884,885,3,251,124,0,885,886, - 3,237,117,0,886,168,1,0,0,0,887,888,3,263,130,0,888,889,3,239,118,0,889, - 890,3,233,115,0,890,891,3,251,124,0,891,170,1,0,0,0,892,893,3,263,130, - 0,893,894,3,239,118,0,894,895,3,259,128,0,895,896,3,253,125,0,896,897, - 3,269,133,0,897,172,1,0,0,0,898,899,3,263,130,0,899,900,3,241,119,0,900, - 901,3,233,115,0,901,902,3,261,129,0,902,174,1,0,0,0,903,904,3,263,130, - 0,904,905,3,241,119,0,905,906,3,249,123,0,906,907,3,233,115,0,907,908, - 3,261,129,0,908,909,3,263,130,0,909,910,3,225,111,0,910,911,3,249,123, - 0,911,912,3,255,126,0,912,176,1,0,0,0,913,914,3,263,130,0,914,915,3,253, - 125,0,915,178,1,0,0,0,916,917,3,263,130,0,917,918,3,253,125,0,918,919, - 3,255,126,0,919,180,1,0,0,0,920,921,3,263,130,0,921,922,3,253,125,0,922, - 923,3,263,130,0,923,924,3,225,111,0,924,925,3,247,122,0,925,926,3,261, - 129,0,926,182,1,0,0,0,927,928,3,263,130,0,928,929,3,259,128,0,929,930, - 3,225,111,0,930,931,3,241,119,0,931,932,3,247,122,0,932,933,3,241,119, - 0,933,934,3,251,124,0,934,935,3,237,117,0,935,184,1,0,0,0,936,937,3,263, - 130,0,937,938,3,259,128,0,938,939,3,241,119,0,939,940,3,249,123,0,940, - 186,1,0,0,0,941,942,3,263,130,0,942,943,3,259,128,0,943,944,3,265,131, - 0,944,945,3,251,124,0,945,946,3,229,113,0,946,947,3,225,111,0,947,948, - 3,263,130,0,948,949,3,233,115,0,949,188,1,0,0,0,950,951,3,263,130,0,951, - 952,3,259,128,0,952,953,3,273,135,0,953,190,1,0,0,0,954,955,3,265,131, - 0,955,956,3,251,124,0,956,957,3,227,112,0,957,958,3,253,125,0,958,959, - 3,265,131,0,959,960,3,251,124,0,960,961,3,231,114,0,961,962,3,233,115, - 0,962,963,3,231,114,0,963,192,1,0,0,0,964,965,3,265,131,0,965,966,3,251, - 124,0,966,967,3,241,119,0,967,968,3,253,125,0,968,969,3,251,124,0,969, - 194,1,0,0,0,970,971,3,265,131,0,971,972,3,261,129,0,972,973,3,241,119, - 0,973,974,3,251,124,0,974,975,3,237,117,0,975,196,1,0,0,0,976,977,3,269, - 133,0,977,978,3,233,115,0,978,979,3,233,115,0,979,980,3,245,121,0,980, - 198,1,0,0,0,981,982,3,269,133,0,982,983,3,239,118,0,983,984,3,233,115, - 0,984,985,3,251,124,0,985,200,1,0,0,0,986,987,3,269,133,0,987,988,3,239, - 118,0,988,989,3,233,115,0,989,990,3,259,128,0,990,991,3,233,115,0,991, - 202,1,0,0,0,992,993,3,269,133,0,993,994,3,239,118,0,994,995,3,241,119, - 0,995,996,3,247,122,0,996,997,3,233,115,0,997,204,1,0,0,0,998,999,3,269, - 133,0,999,1000,3,241,119,0,1000,1001,3,251,124,0,1001,1002,3,231,114, - 0,1002,1003,3,253,125,0,1003,1004,3,269,133,0,1004,206,1,0,0,0,1005,1006, - 3,269,133,0,1006,1007,3,241,119,0,1007,1008,3,263,130,0,1008,1009,3,239, - 118,0,1009,208,1,0,0,0,1010,1011,3,273,135,0,1011,1012,3,233,115,0,1012, - 1013,3,225,111,0,1013,1014,3,259,128,0,1014,1021,1,0,0,0,1015,1016,3, - 273,135,0,1016,1017,3,273,135,0,1017,1018,3,273,135,0,1018,1019,3,273, - 135,0,1019,1021,1,0,0,0,1020,1010,1,0,0,0,1020,1015,1,0,0,0,1021,210, - 1,0,0,0,1022,1023,3,291,144,0,1023,1024,3,227,112,0,1024,1050,1,0,0,0, - 1025,1026,3,291,144,0,1026,1027,3,235,116,0,1027,1050,1,0,0,0,1028,1029, - 3,291,144,0,1029,1030,3,259,128,0,1030,1050,1,0,0,0,1031,1032,3,291,144, - 0,1032,1033,3,251,124,0,1033,1050,1,0,0,0,1034,1035,3,291,144,0,1035, - 1036,3,263,130,0,1036,1050,1,0,0,0,1037,1038,3,291,144,0,1038,1039,5, - 48,0,0,1039,1050,1,0,0,0,1040,1041,3,291,144,0,1041,1042,3,225,111,0, - 1042,1050,1,0,0,0,1043,1044,3,291,144,0,1044,1045,3,267,132,0,1045,1050, - 1,0,0,0,1046,1047,3,291,144,0,1047,1048,3,291,144,0,1048,1050,1,0,0,0, - 1049,1022,1,0,0,0,1049,1025,1,0,0,0,1049,1028,1,0,0,0,1049,1031,1,0,0, - 0,1049,1034,1,0,0,0,1049,1037,1,0,0,0,1049,1040,1,0,0,0,1049,1043,1,0, - 0,0,1049,1046,1,0,0,0,1050,212,1,0,0,0,1051,1055,3,277,137,0,1052,1055, - 3,367,182,0,1053,1055,3,301,149,0,1054,1051,1,0,0,0,1054,1052,1,0,0,0, - 1054,1053,1,0,0,0,1055,1062,1,0,0,0,1056,1061,3,277,137,0,1057,1061,3, - 367,182,0,1058,1061,3,281,139,0,1059,1061,3,301,149,0,1060,1056,1,0,0, - 0,1060,1057,1,0,0,0,1060,1058,1,0,0,0,1060,1059,1,0,0,0,1061,1064,1,0, - 0,0,1062,1060,1,0,0,0,1062,1063,1,0,0,0,1063,1098,1,0,0,0,1064,1062,1, - 0,0,0,1065,1076,3,289,143,0,1066,1075,8,0,0,0,1067,1075,3,211,104,0,1068, - 1069,3,291,144,0,1069,1070,3,351,174,0,1070,1075,1,0,0,0,1071,1072,3, - 289,143,0,1072,1073,3,289,143,0,1073,1075,1,0,0,0,1074,1066,1,0,0,0,1074, - 1067,1,0,0,0,1074,1068,1,0,0,0,1074,1071,1,0,0,0,1075,1078,1,0,0,0,1076, - 1074,1,0,0,0,1076,1077,1,0,0,0,1077,1079,1,0,0,0,1078,1076,1,0,0,0,1079, - 1080,3,289,143,0,1080,1098,1,0,0,0,1081,1092,3,345,171,0,1082,1091,8, - 1,0,0,1083,1091,3,211,104,0,1084,1085,3,291,144,0,1085,1086,3,345,171, - 0,1086,1091,1,0,0,0,1087,1088,3,345,171,0,1088,1089,3,345,171,0,1089, - 1091,1,0,0,0,1090,1082,1,0,0,0,1090,1083,1,0,0,0,1090,1084,1,0,0,0,1090, - 1087,1,0,0,0,1091,1094,1,0,0,0,1092,1090,1,0,0,0,1092,1093,1,0,0,0,1093, - 1095,1,0,0,0,1094,1092,1,0,0,0,1095,1096,3,345,171,0,1096,1098,1,0,0, - 0,1097,1054,1,0,0,0,1097,1065,1,0,0,0,1097,1081,1,0,0,0,1098,214,1,0, - 0,0,1099,1100,3,221,109,0,1100,1104,3,303,150,0,1101,1103,3,283,140,0, - 1102,1101,1,0,0,0,1103,1106,1,0,0,0,1104,1102,1,0,0,0,1104,1105,1,0,0, - 0,1105,1109,1,0,0,0,1106,1104,1,0,0,0,1107,1110,3,255,126,0,1108,1110, - 3,233,115,0,1109,1107,1,0,0,0,1109,1108,1,0,0,0,1110,1113,1,0,0,0,1111, - 1114,3,341,169,0,1112,1114,3,299,148,0,1113,1111,1,0,0,0,1113,1112,1, - 0,0,0,1113,1114,1,0,0,0,1114,1116,1,0,0,0,1115,1117,3,281,139,0,1116, - 1115,1,0,0,0,1117,1118,1,0,0,0,1118,1116,1,0,0,0,1118,1119,1,0,0,0,1119, - 1176,1,0,0,0,1120,1123,3,221,109,0,1121,1124,3,255,126,0,1122,1124,3, - 233,115,0,1123,1121,1,0,0,0,1123,1122,1,0,0,0,1124,1127,1,0,0,0,1125, - 1128,3,341,169,0,1126,1128,3,299,148,0,1127,1125,1,0,0,0,1127,1126,1, - 0,0,0,1127,1128,1,0,0,0,1128,1130,1,0,0,0,1129,1131,3,281,139,0,1130, - 1129,1,0,0,0,1131,1132,1,0,0,0,1132,1130,1,0,0,0,1132,1133,1,0,0,0,1133, - 1176,1,0,0,0,1134,1135,3,219,108,0,1135,1139,3,303,150,0,1136,1138,3, - 281,139,0,1137,1136,1,0,0,0,1138,1141,1,0,0,0,1139,1137,1,0,0,0,1139, - 1140,1,0,0,0,1140,1142,1,0,0,0,1141,1139,1,0,0,0,1142,1145,3,233,115, - 0,1143,1146,3,341,169,0,1144,1146,3,299,148,0,1145,1143,1,0,0,0,1145, - 1144,1,0,0,0,1145,1146,1,0,0,0,1146,1148,1,0,0,0,1147,1149,3,281,139, - 0,1148,1147,1,0,0,0,1149,1150,1,0,0,0,1150,1148,1,0,0,0,1150,1151,1,0, - 0,0,1151,1176,1,0,0,0,1152,1153,3,303,150,0,1153,1154,3,219,108,0,1154, - 1157,3,233,115,0,1155,1158,3,341,169,0,1156,1158,3,299,148,0,1157,1155, - 1,0,0,0,1157,1156,1,0,0,0,1157,1158,1,0,0,0,1158,1160,1,0,0,0,1159,1161, - 3,281,139,0,1160,1159,1,0,0,0,1161,1162,1,0,0,0,1162,1160,1,0,0,0,1162, - 1163,1,0,0,0,1163,1176,1,0,0,0,1164,1165,3,219,108,0,1165,1168,3,233, - 115,0,1166,1169,3,341,169,0,1167,1169,3,299,148,0,1168,1166,1,0,0,0,1168, - 1167,1,0,0,0,1168,1169,1,0,0,0,1169,1171,1,0,0,0,1170,1172,3,281,139, - 0,1171,1170,1,0,0,0,1172,1173,1,0,0,0,1173,1171,1,0,0,0,1173,1174,1,0, - 0,0,1174,1176,1,0,0,0,1175,1099,1,0,0,0,1175,1120,1,0,0,0,1175,1134,1, - 0,0,0,1175,1152,1,0,0,0,1175,1164,1,0,0,0,1176,216,1,0,0,0,1177,1179, - 5,48,0,0,1178,1180,3,279,138,0,1179,1178,1,0,0,0,1180,1181,1,0,0,0,1181, - 1179,1,0,0,0,1181,1182,1,0,0,0,1182,218,1,0,0,0,1183,1185,3,281,139,0, - 1184,1183,1,0,0,0,1185,1186,1,0,0,0,1186,1184,1,0,0,0,1186,1187,1,0,0, - 0,1187,220,1,0,0,0,1188,1189,5,48,0,0,1189,1191,3,271,134,0,1190,1192, - 3,283,140,0,1191,1190,1,0,0,0,1192,1193,1,0,0,0,1193,1191,1,0,0,0,1193, - 1194,1,0,0,0,1194,222,1,0,0,0,1195,1206,3,351,174,0,1196,1205,8,2,0,0, - 1197,1205,3,211,104,0,1198,1199,3,291,144,0,1199,1200,3,351,174,0,1200, - 1205,1,0,0,0,1201,1202,3,351,174,0,1202,1203,3,351,174,0,1203,1205,1, - 0,0,0,1204,1196,1,0,0,0,1204,1197,1,0,0,0,1204,1198,1,0,0,0,1204,1201, - 1,0,0,0,1205,1208,1,0,0,0,1206,1204,1,0,0,0,1206,1207,1,0,0,0,1207,1209, - 1,0,0,0,1208,1206,1,0,0,0,1209,1210,3,351,174,0,1210,224,1,0,0,0,1211, - 1212,7,3,0,0,1212,226,1,0,0,0,1213,1214,7,4,0,0,1214,228,1,0,0,0,1215, - 1216,7,5,0,0,1216,230,1,0,0,0,1217,1218,7,6,0,0,1218,232,1,0,0,0,1219, - 1220,7,7,0,0,1220,234,1,0,0,0,1221,1222,7,8,0,0,1222,236,1,0,0,0,1223, - 1224,7,9,0,0,1224,238,1,0,0,0,1225,1226,7,10,0,0,1226,240,1,0,0,0,1227, - 1228,7,11,0,0,1228,242,1,0,0,0,1229,1230,7,12,0,0,1230,244,1,0,0,0,1231, - 1232,7,13,0,0,1232,246,1,0,0,0,1233,1234,7,14,0,0,1234,248,1,0,0,0,1235, - 1236,7,15,0,0,1236,250,1,0,0,0,1237,1238,7,16,0,0,1238,252,1,0,0,0,1239, - 1240,7,17,0,0,1240,254,1,0,0,0,1241,1242,7,18,0,0,1242,256,1,0,0,0,1243, - 1244,7,19,0,0,1244,258,1,0,0,0,1245,1246,7,20,0,0,1246,260,1,0,0,0,1247, - 1248,7,21,0,0,1248,262,1,0,0,0,1249,1250,7,22,0,0,1250,264,1,0,0,0,1251, - 1252,7,23,0,0,1252,266,1,0,0,0,1253,1254,7,24,0,0,1254,268,1,0,0,0,1255, - 1256,7,25,0,0,1256,270,1,0,0,0,1257,1258,7,26,0,0,1258,272,1,0,0,0,1259, - 1260,7,27,0,0,1260,274,1,0,0,0,1261,1262,7,28,0,0,1262,276,1,0,0,0,1263, - 1264,7,29,0,0,1264,278,1,0,0,0,1265,1266,7,30,0,0,1266,280,1,0,0,0,1267, - 1268,7,31,0,0,1268,282,1,0,0,0,1269,1270,7,32,0,0,1270,284,1,0,0,0,1271, - 1272,5,45,0,0,1272,1273,5,62,0,0,1273,286,1,0,0,0,1274,1275,5,42,0,0, - 1275,288,1,0,0,0,1276,1277,5,96,0,0,1277,290,1,0,0,0,1278,1279,5,92,0, - 0,1279,292,1,0,0,0,1280,1281,5,58,0,0,1281,294,1,0,0,0,1282,1283,5,44, - 0,0,1283,296,1,0,0,0,1284,1285,5,124,0,0,1285,1286,5,124,0,0,1286,298, - 1,0,0,0,1287,1288,5,45,0,0,1288,300,1,0,0,0,1289,1290,5,36,0,0,1290,302, - 1,0,0,0,1291,1292,5,46,0,0,1292,304,1,0,0,0,1293,1294,5,61,0,0,1294,1295, - 5,61,0,0,1295,306,1,0,0,0,1296,1297,5,61,0,0,1297,308,1,0,0,0,1298,1299, - 5,62,0,0,1299,1300,5,61,0,0,1300,310,1,0,0,0,1301,1302,5,62,0,0,1302, - 312,1,0,0,0,1303,1304,5,35,0,0,1304,314,1,0,0,0,1305,1306,5,126,0,0,1306, - 1307,5,42,0,0,1307,316,1,0,0,0,1308,1309,5,61,0,0,1309,1310,5,126,0,0, - 1310,1311,5,42,0,0,1311,318,1,0,0,0,1312,1313,5,123,0,0,1313,1314,1,0, - 0,0,1314,1315,6,158,0,0,1315,320,1,0,0,0,1316,1317,5,91,0,0,1317,322, - 1,0,0,0,1318,1319,5,40,0,0,1319,324,1,0,0,0,1320,1321,5,60,0,0,1321,1322, - 5,61,0,0,1322,326,1,0,0,0,1323,1324,5,60,0,0,1324,328,1,0,0,0,1325,1326, - 5,33,0,0,1326,1330,5,61,0,0,1327,1328,5,60,0,0,1328,1330,5,62,0,0,1329, - 1325,1,0,0,0,1329,1327,1,0,0,0,1330,330,1,0,0,0,1331,1332,5,33,0,0,1332, - 1333,5,126,0,0,1333,1334,5,42,0,0,1334,332,1,0,0,0,1335,1336,5,33,0,0, - 1336,1337,5,126,0,0,1337,334,1,0,0,0,1338,1339,5,63,0,0,1339,1340,5,46, - 0,0,1340,336,1,0,0,0,1341,1342,5,63,0,0,1342,1343,5,63,0,0,1343,338,1, - 0,0,0,1344,1345,5,37,0,0,1345,340,1,0,0,0,1346,1347,5,43,0,0,1347,342, - 1,0,0,0,1348,1349,5,63,0,0,1349,344,1,0,0,0,1350,1351,5,34,0,0,1351,346, - 1,0,0,0,1352,1353,5,102,0,0,1353,1354,5,39,0,0,1354,1355,1,0,0,0,1355, - 1356,6,172,1,0,1356,348,1,0,0,0,1357,1358,5,70,0,0,1358,1359,5,39,0,0, - 1359,1360,1,0,0,0,1360,1361,6,173,2,0,1361,350,1,0,0,0,1362,1363,5,39, - 0,0,1363,352,1,0,0,0,1364,1365,5,126,0,0,1365,354,1,0,0,0,1366,1367,5, - 61,0,0,1367,1368,5,126,0,0,1368,356,1,0,0,0,1369,1370,5,125,0,0,1370, - 1371,1,0,0,0,1371,1372,6,177,3,0,1372,358,1,0,0,0,1373,1374,5,93,0,0, - 1374,360,1,0,0,0,1375,1376,5,41,0,0,1376,362,1,0,0,0,1377,1378,5,59,0, - 0,1378,364,1,0,0,0,1379,1380,5,47,0,0,1380,366,1,0,0,0,1381,1382,5,95, - 0,0,1382,368,1,0,0,0,1383,1384,5,47,0,0,1384,1385,5,42,0,0,1385,1389, - 1,0,0,0,1386,1388,9,0,0,0,1387,1386,1,0,0,0,1388,1391,1,0,0,0,1389,1390, - 1,0,0,0,1389,1387,1,0,0,0,1390,1392,1,0,0,0,1391,1389,1,0,0,0,1392,1393, - 5,42,0,0,1393,1394,5,47,0,0,1394,1395,1,0,0,0,1395,1396,6,183,4,0,1396, - 370,1,0,0,0,1397,1398,5,45,0,0,1398,1402,5,45,0,0,1399,1400,5,47,0,0, - 1400,1402,5,47,0,0,1401,1397,1,0,0,0,1401,1399,1,0,0,0,1402,1406,1,0, - 0,0,1403,1405,8,33,0,0,1404,1403,1,0,0,0,1405,1408,1,0,0,0,1406,1404, - 1,0,0,0,1406,1407,1,0,0,0,1407,1410,1,0,0,0,1408,1406,1,0,0,0,1409,1411, - 7,34,0,0,1410,1409,1,0,0,0,1411,1412,1,0,0,0,1412,1413,6,184,4,0,1413, - 372,1,0,0,0,1414,1415,7,35,0,0,1415,1416,1,0,0,0,1416,1417,6,185,5,0, - 1417,374,1,0,0,0,1418,1430,8,36,0,0,1419,1430,3,211,104,0,1420,1421,3, - 291,144,0,1421,1422,3,351,174,0,1422,1430,1,0,0,0,1423,1424,3,291,144, - 0,1424,1425,3,319,158,0,1425,1430,1,0,0,0,1426,1427,3,351,174,0,1427, - 1428,3,351,174,0,1428,1430,1,0,0,0,1429,1418,1,0,0,0,1429,1419,1,0,0, - 0,1429,1420,1,0,0,0,1429,1423,1,0,0,0,1429,1426,1,0,0,0,1430,1431,1,0, - 0,0,1431,1429,1,0,0,0,1431,1432,1,0,0,0,1432,376,1,0,0,0,1433,1434,3, - 319,158,0,1434,1435,1,0,0,0,1435,1436,6,187,0,0,1436,378,1,0,0,0,1437, - 1438,3,351,174,0,1438,1439,1,0,0,0,1439,1440,6,188,6,0,1440,1441,6,188, - 3,0,1441,380,1,0,0,0,1442,1448,8,37,0,0,1443,1448,3,211,104,0,1444,1445, - 3,291,144,0,1445,1446,3,319,158,0,1446,1448,1,0,0,0,1447,1442,1,0,0,0, - 1447,1443,1,0,0,0,1447,1444,1,0,0,0,1448,1449,1,0,0,0,1449,1447,1,0,0, - 0,1449,1450,1,0,0,0,1450,382,1,0,0,0,1451,1452,3,319,158,0,1452,1453, - 1,0,0,0,1453,1454,6,190,0,0,1454,384,1,0,0,0,44,0,1,2,425,646,1020,1049, - 1054,1060,1062,1074,1076,1090,1092,1097,1104,1109,1113,1118,1123,1127, - 1132,1139,1145,1150,1157,1162,1168,1173,1175,1181,1186,1193,1204,1206, - 1329,1389,1401,1406,1410,1429,1431,1447,1449,7,5,0,0,5,1,0,5,2,0,4,0, - 0,6,0,0,0,1,0,7,145,0 + 0,0,0,0,367,1,0,0,0,0,369,1,0,0,0,0,371,1,0,0,0,0,373,1,0,0,0,0,375,1, + 0,0,0,0,377,1,0,0,0,1,379,1,0,0,0,1,381,1,0,0,0,1,383,1,0,0,0,2,385,1, + 0,0,0,2,387,1,0,0,0,3,389,1,0,0,0,5,393,1,0,0,0,7,397,1,0,0,0,9,402,1, + 0,0,0,11,406,1,0,0,0,13,412,1,0,0,0,15,429,1,0,0,0,17,431,1,0,0,0,19, + 436,1,0,0,0,21,444,1,0,0,0,23,449,1,0,0,0,25,452,1,0,0,0,27,457,1,0,0, + 0,29,462,1,0,0,0,31,468,1,0,0,0,33,475,1,0,0,0,35,483,1,0,0,0,37,489, + 1,0,0,0,39,494,1,0,0,0,41,502,1,0,0,0,43,507,1,0,0,0,45,511,1,0,0,0,47, + 516,1,0,0,0,49,527,1,0,0,0,51,536,1,0,0,0,53,541,1,0,0,0,55,545,1,0,0, + 0,57,552,1,0,0,0,59,560,1,0,0,0,61,566,1,0,0,0,63,574,1,0,0,0,65,580, + 1,0,0,0,67,583,1,0,0,0,69,593,1,0,0,0,71,597,1,0,0,0,73,602,1,0,0,0,75, + 607,1,0,0,0,77,611,1,0,0,0,79,617,1,0,0,0,81,624,1,0,0,0,83,629,1,0,0, + 0,85,632,1,0,0,0,87,635,1,0,0,0,89,641,1,0,0,0,91,657,1,0,0,0,93,659, + 1,0,0,0,95,665,1,0,0,0,97,675,1,0,0,0,99,684,1,0,0,0,101,687,1,0,0,0, + 103,692,1,0,0,0,105,696,1,0,0,0,107,701,1,0,0,0,109,709,1,0,0,0,111,714, + 1,0,0,0,113,718,1,0,0,0,115,723,1,0,0,0,117,729,1,0,0,0,119,736,1,0,0, + 0,121,742,1,0,0,0,123,746,1,0,0,0,125,750,1,0,0,0,127,755,1,0,0,0,129, + 761,1,0,0,0,131,768,1,0,0,0,133,771,1,0,0,0,135,774,1,0,0,0,137,780,1, + 0,0,0,139,786,1,0,0,0,141,791,1,0,0,0,143,801,1,0,0,0,145,811,1,0,0,0, + 147,820,1,0,0,0,149,828,1,0,0,0,151,834,1,0,0,0,153,841,1,0,0,0,155,847, + 1,0,0,0,157,854,1,0,0,0,159,858,1,0,0,0,161,863,1,0,0,0,163,870,1,0,0, + 0,165,877,1,0,0,0,167,884,1,0,0,0,169,889,1,0,0,0,171,898,1,0,0,0,173, + 908,1,0,0,0,175,913,1,0,0,0,177,919,1,0,0,0,179,924,1,0,0,0,181,934,1, + 0,0,0,183,937,1,0,0,0,185,941,1,0,0,0,187,948,1,0,0,0,189,957,1,0,0,0, + 191,962,1,0,0,0,193,971,1,0,0,0,195,975,1,0,0,0,197,985,1,0,0,0,199,991, + 1,0,0,0,201,997,1,0,0,0,203,1002,1,0,0,0,205,1007,1,0,0,0,207,1013,1, + 0,0,0,209,1019,1,0,0,0,211,1026,1,0,0,0,213,1041,1,0,0,0,215,1070,1,0, + 0,0,217,1118,1,0,0,0,219,1196,1,0,0,0,221,1198,1,0,0,0,223,1205,1,0,0, + 0,225,1209,1,0,0,0,227,1216,1,0,0,0,229,1232,1,0,0,0,231,1234,1,0,0,0, + 233,1236,1,0,0,0,235,1238,1,0,0,0,237,1240,1,0,0,0,239,1242,1,0,0,0,241, + 1244,1,0,0,0,243,1246,1,0,0,0,245,1248,1,0,0,0,247,1250,1,0,0,0,249,1252, + 1,0,0,0,251,1254,1,0,0,0,253,1256,1,0,0,0,255,1258,1,0,0,0,257,1260,1, + 0,0,0,259,1262,1,0,0,0,261,1264,1,0,0,0,263,1266,1,0,0,0,265,1268,1,0, + 0,0,267,1270,1,0,0,0,269,1272,1,0,0,0,271,1274,1,0,0,0,273,1276,1,0,0, + 0,275,1278,1,0,0,0,277,1280,1,0,0,0,279,1282,1,0,0,0,281,1284,1,0,0,0, + 283,1286,1,0,0,0,285,1288,1,0,0,0,287,1290,1,0,0,0,289,1292,1,0,0,0,291, + 1295,1,0,0,0,293,1297,1,0,0,0,295,1299,1,0,0,0,297,1301,1,0,0,0,299,1303, + 1,0,0,0,301,1305,1,0,0,0,303,1308,1,0,0,0,305,1310,1,0,0,0,307,1312,1, + 0,0,0,309,1314,1,0,0,0,311,1317,1,0,0,0,313,1319,1,0,0,0,315,1322,1,0, + 0,0,317,1324,1,0,0,0,319,1326,1,0,0,0,321,1329,1,0,0,0,323,1333,1,0,0, + 0,325,1337,1,0,0,0,327,1339,1,0,0,0,329,1341,1,0,0,0,331,1344,1,0,0,0, + 333,1350,1,0,0,0,335,1352,1,0,0,0,337,1356,1,0,0,0,339,1359,1,0,0,0,341, + 1362,1,0,0,0,343,1365,1,0,0,0,345,1367,1,0,0,0,347,1369,1,0,0,0,349,1371, + 1,0,0,0,351,1373,1,0,0,0,353,1378,1,0,0,0,355,1383,1,0,0,0,357,1385,1, + 0,0,0,359,1387,1,0,0,0,361,1390,1,0,0,0,363,1394,1,0,0,0,365,1396,1,0, + 0,0,367,1398,1,0,0,0,369,1400,1,0,0,0,371,1402,1,0,0,0,373,1404,1,0,0, + 0,375,1422,1,0,0,0,377,1435,1,0,0,0,379,1450,1,0,0,0,381,1454,1,0,0,0, + 383,1458,1,0,0,0,385,1468,1,0,0,0,387,1472,1,0,0,0,389,390,3,229,113, + 0,390,391,3,251,124,0,391,392,3,251,124,0,392,4,1,0,0,0,393,394,3,229, + 113,0,394,395,3,255,126,0,395,396,3,235,116,0,396,6,1,0,0,0,397,398,3, + 229,113,0,398,399,3,255,126,0,399,400,3,267,132,0,400,401,3,245,121,0, + 401,8,1,0,0,0,402,403,3,229,113,0,403,404,3,255,126,0,404,405,3,277,137, + 0,405,10,1,0,0,0,406,407,3,229,113,0,407,408,3,263,130,0,408,409,3,263, + 130,0,409,410,3,229,113,0,410,411,3,277,137,0,411,12,1,0,0,0,412,413, + 3,229,113,0,413,414,3,265,131,0,414,14,1,0,0,0,415,416,3,229,113,0,416, + 417,3,265,131,0,417,418,3,233,115,0,418,430,1,0,0,0,419,420,3,229,113, + 0,420,421,3,265,131,0,421,422,3,233,115,0,422,423,3,237,117,0,423,424, + 3,255,126,0,424,425,3,235,116,0,425,426,3,245,121,0,426,427,3,255,126, + 0,427,428,3,241,119,0,428,430,1,0,0,0,429,415,1,0,0,0,429,419,1,0,0,0, + 430,16,1,0,0,0,431,432,3,229,113,0,432,433,3,265,131,0,433,434,3,257, + 127,0,434,435,3,239,118,0,435,18,1,0,0,0,436,437,3,231,114,0,437,438, + 3,237,117,0,438,439,3,267,132,0,439,440,3,273,135,0,440,441,3,237,117, + 0,441,442,3,237,117,0,442,443,3,255,126,0,443,20,1,0,0,0,444,445,3,231, + 114,0,445,446,3,257,127,0,446,447,3,267,132,0,447,448,3,243,120,0,448, + 22,1,0,0,0,449,450,3,231,114,0,450,451,3,277,137,0,451,24,1,0,0,0,452, + 453,3,233,115,0,453,454,3,229,113,0,454,455,3,265,131,0,455,456,3,237, + 117,0,456,26,1,0,0,0,457,458,3,233,115,0,458,459,3,229,113,0,459,460, + 3,265,131,0,460,461,3,267,132,0,461,28,1,0,0,0,462,463,3,233,115,0,463, + 464,3,229,113,0,464,465,3,267,132,0,465,466,3,233,115,0,466,467,3,243, + 120,0,467,30,1,0,0,0,468,469,3,233,115,0,469,470,3,257,127,0,470,471, + 3,243,120,0,471,472,3,257,127,0,472,473,3,263,130,0,473,474,3,267,132, + 0,474,32,1,0,0,0,475,476,3,233,115,0,476,477,3,257,127,0,477,478,3,251, + 124,0,478,479,3,251,124,0,479,480,3,229,113,0,480,481,3,267,132,0,481, + 482,3,237,117,0,482,34,1,0,0,0,483,484,3,233,115,0,484,485,3,263,130, + 0,485,486,3,257,127,0,486,487,3,265,131,0,487,488,3,265,131,0,488,36, + 1,0,0,0,489,490,3,233,115,0,490,491,3,269,133,0,491,492,3,231,114,0,492, + 493,3,237,117,0,493,38,1,0,0,0,494,495,3,233,115,0,495,496,3,269,133, + 0,496,497,3,263,130,0,497,498,3,263,130,0,498,499,3,237,117,0,499,500, + 3,255,126,0,500,501,3,267,132,0,501,40,1,0,0,0,502,503,3,235,116,0,503, + 504,3,229,113,0,504,505,3,267,132,0,505,506,3,237,117,0,506,42,1,0,0, + 0,507,508,3,235,116,0,508,509,3,229,113,0,509,510,3,277,137,0,510,44, + 1,0,0,0,511,512,3,235,116,0,512,513,3,237,117,0,513,514,3,265,131,0,514, + 515,3,233,115,0,515,46,1,0,0,0,516,517,3,235,116,0,517,518,3,237,117, + 0,518,519,3,265,131,0,519,520,3,233,115,0,520,521,3,237,117,0,521,522, + 3,255,126,0,522,523,3,235,116,0,523,524,3,245,121,0,524,525,3,255,126, + 0,525,526,3,241,119,0,526,48,1,0,0,0,527,528,3,235,116,0,528,529,3,245, + 121,0,529,530,3,265,131,0,530,531,3,267,132,0,531,532,3,245,121,0,532, + 533,3,255,126,0,533,534,3,233,115,0,534,535,3,267,132,0,535,50,1,0,0, + 0,536,537,3,237,117,0,537,538,3,251,124,0,538,539,3,265,131,0,539,540, + 3,237,117,0,540,52,1,0,0,0,541,542,3,237,117,0,542,543,3,255,126,0,543, + 544,3,235,116,0,544,54,1,0,0,0,545,546,3,237,117,0,546,547,3,275,136, + 0,547,548,3,233,115,0,548,549,3,237,117,0,549,550,3,259,128,0,550,551, + 3,267,132,0,551,56,1,0,0,0,552,553,3,237,117,0,553,554,3,275,136,0,554, + 555,3,267,132,0,555,556,3,263,130,0,556,557,3,229,113,0,557,558,3,233, + 115,0,558,559,3,267,132,0,559,58,1,0,0,0,560,561,3,239,118,0,561,562, + 3,245,121,0,562,563,3,255,126,0,563,564,3,229,113,0,564,565,3,251,124, + 0,565,60,1,0,0,0,566,567,3,239,118,0,567,568,3,245,121,0,568,569,3,255, + 126,0,569,570,3,229,113,0,570,571,3,251,124,0,571,572,3,251,124,0,572, + 573,3,277,137,0,573,62,1,0,0,0,574,575,3,239,118,0,575,576,3,245,121, + 0,576,577,3,263,130,0,577,578,3,265,131,0,578,579,3,267,132,0,579,64, + 1,0,0,0,580,581,3,239,118,0,581,582,3,255,126,0,582,66,1,0,0,0,583,584, + 3,239,118,0,584,585,3,257,127,0,585,586,3,251,124,0,586,587,3,251,124, + 0,587,588,3,257,127,0,588,589,3,273,135,0,589,590,3,245,121,0,590,591, + 3,255,126,0,591,592,3,241,119,0,592,68,1,0,0,0,593,594,3,239,118,0,594, + 595,3,257,127,0,595,596,3,263,130,0,596,70,1,0,0,0,597,598,3,239,118, + 0,598,599,3,263,130,0,599,600,3,257,127,0,600,601,3,253,125,0,601,72, + 1,0,0,0,602,603,3,239,118,0,603,604,3,269,133,0,604,605,3,251,124,0,605, + 606,3,251,124,0,606,74,1,0,0,0,607,608,3,239,118,0,608,609,3,269,133, + 0,609,610,3,255,126,0,610,76,1,0,0,0,611,612,3,241,119,0,612,613,3,263, + 130,0,613,614,3,257,127,0,614,615,3,269,133,0,615,616,3,259,128,0,616, + 78,1,0,0,0,617,618,3,243,120,0,618,619,3,229,113,0,619,620,3,271,134, + 0,620,621,3,245,121,0,621,622,3,255,126,0,622,623,3,241,119,0,623,80, + 1,0,0,0,624,625,3,243,120,0,625,626,3,257,127,0,626,627,3,269,133,0,627, + 628,3,263,130,0,628,82,1,0,0,0,629,630,3,245,121,0,630,631,3,235,116, + 0,631,84,1,0,0,0,632,633,3,245,121,0,633,634,3,239,118,0,634,86,1,0,0, + 0,635,636,3,245,121,0,636,637,3,251,124,0,637,638,3,245,121,0,638,639, + 3,249,123,0,639,640,3,237,117,0,640,88,1,0,0,0,641,642,3,245,121,0,642, + 643,3,255,126,0,643,90,1,0,0,0,644,645,3,245,121,0,645,646,3,255,126, + 0,646,647,3,239,118,0,647,658,1,0,0,0,648,649,3,245,121,0,649,650,3,255, + 126,0,650,651,3,239,118,0,651,652,3,245,121,0,652,653,3,255,126,0,653, + 654,3,245,121,0,654,655,3,267,132,0,655,656,3,277,137,0,656,658,1,0,0, + 0,657,644,1,0,0,0,657,648,1,0,0,0,658,92,1,0,0,0,659,660,3,245,121,0, + 660,661,3,255,126,0,661,662,3,255,126,0,662,663,3,237,117,0,663,664,3, + 263,130,0,664,94,1,0,0,0,665,666,3,245,121,0,666,667,3,255,126,0,667, + 668,3,267,132,0,668,669,3,237,117,0,669,670,3,263,130,0,670,671,3,265, + 131,0,671,672,3,237,117,0,672,673,3,233,115,0,673,674,3,267,132,0,674, + 96,1,0,0,0,675,676,3,245,121,0,676,677,3,255,126,0,677,678,3,267,132, + 0,678,679,3,237,117,0,679,680,3,263,130,0,680,681,3,271,134,0,681,682, + 3,229,113,0,682,683,3,251,124,0,683,98,1,0,0,0,684,685,3,245,121,0,685, + 686,3,265,131,0,686,100,1,0,0,0,687,688,3,247,122,0,688,689,3,257,127, + 0,689,690,3,245,121,0,690,691,3,255,126,0,691,102,1,0,0,0,692,693,3,249, + 123,0,693,694,3,237,117,0,694,695,3,277,137,0,695,104,1,0,0,0,696,697, + 3,251,124,0,697,698,3,229,113,0,698,699,3,265,131,0,699,700,3,267,132, + 0,700,106,1,0,0,0,701,702,3,251,124,0,702,703,3,237,117,0,703,704,3,229, + 113,0,704,705,3,235,116,0,705,706,3,245,121,0,706,707,3,255,126,0,707, + 708,3,241,119,0,708,108,1,0,0,0,709,710,3,251,124,0,710,711,3,237,117, + 0,711,712,3,239,118,0,712,713,3,267,132,0,713,110,1,0,0,0,714,715,3,251, + 124,0,715,716,3,237,117,0,716,717,3,267,132,0,717,112,1,0,0,0,718,719, + 3,251,124,0,719,720,3,245,121,0,720,721,3,249,123,0,721,722,3,237,117, + 0,722,114,1,0,0,0,723,724,3,251,124,0,724,725,3,245,121,0,725,726,3,253, + 125,0,726,727,3,245,121,0,727,728,3,267,132,0,728,116,1,0,0,0,729,730, + 3,253,125,0,730,731,3,245,121,0,731,732,3,255,126,0,732,733,3,269,133, + 0,733,734,3,267,132,0,734,735,3,237,117,0,735,118,1,0,0,0,736,737,3,253, + 125,0,737,738,3,257,127,0,738,739,3,255,126,0,739,740,3,267,132,0,740, + 741,3,243,120,0,741,120,1,0,0,0,742,743,3,255,126,0,743,744,3,229,113, + 0,744,745,3,255,126,0,745,122,1,0,0,0,746,747,3,255,126,0,747,748,3,257, + 127,0,748,749,3,267,132,0,749,124,1,0,0,0,750,751,3,255,126,0,751,752, + 3,269,133,0,752,753,3,251,124,0,753,754,3,251,124,0,754,126,1,0,0,0,755, + 756,3,255,126,0,756,757,3,269,133,0,757,758,3,251,124,0,758,759,3,251, + 124,0,759,760,3,265,131,0,760,128,1,0,0,0,761,762,3,257,127,0,762,763, + 3,239,118,0,763,764,3,239,118,0,764,765,3,265,131,0,765,766,3,237,117, + 0,766,767,3,267,132,0,767,130,1,0,0,0,768,769,3,257,127,0,769,770,3,255, + 126,0,770,132,1,0,0,0,771,772,3,257,127,0,772,773,3,263,130,0,773,134, + 1,0,0,0,774,775,3,257,127,0,775,776,3,263,130,0,776,777,3,235,116,0,777, + 778,3,237,117,0,778,779,3,263,130,0,779,136,1,0,0,0,780,781,3,257,127, + 0,781,782,3,269,133,0,782,783,3,267,132,0,783,784,3,237,117,0,784,785, + 3,263,130,0,785,138,1,0,0,0,786,787,3,257,127,0,787,788,3,271,134,0,788, + 789,3,237,117,0,789,790,3,263,130,0,790,140,1,0,0,0,791,792,3,259,128, + 0,792,793,3,229,113,0,793,794,3,263,130,0,794,795,3,267,132,0,795,796, + 3,245,121,0,796,797,3,267,132,0,797,798,3,245,121,0,798,799,3,257,127, + 0,799,800,3,255,126,0,800,142,1,0,0,0,801,802,3,259,128,0,802,803,3,263, + 130,0,803,804,3,237,117,0,804,805,3,233,115,0,805,806,3,237,117,0,806, + 807,3,235,116,0,807,808,3,245,121,0,808,809,3,255,126,0,809,810,3,241, + 119,0,810,144,1,0,0,0,811,812,3,259,128,0,812,813,3,263,130,0,813,814, + 3,237,117,0,814,815,3,273,135,0,815,816,3,243,120,0,816,817,3,237,117, + 0,817,818,3,263,130,0,818,819,3,237,117,0,819,146,1,0,0,0,820,821,3,261, + 129,0,821,822,3,269,133,0,822,823,3,229,113,0,823,824,3,263,130,0,824, + 825,3,267,132,0,825,826,3,237,117,0,826,827,3,263,130,0,827,148,1,0,0, + 0,828,829,3,263,130,0,829,830,3,229,113,0,830,831,3,255,126,0,831,832, + 3,241,119,0,832,833,3,237,117,0,833,150,1,0,0,0,834,835,3,263,130,0,835, + 836,3,237,117,0,836,837,3,267,132,0,837,838,3,269,133,0,838,839,3,263, + 130,0,839,840,3,255,126,0,840,152,1,0,0,0,841,842,3,263,130,0,842,843, + 3,245,121,0,843,844,3,241,119,0,844,845,3,243,120,0,845,846,3,267,132, + 0,846,154,1,0,0,0,847,848,3,263,130,0,848,849,3,257,127,0,849,850,3,251, + 124,0,850,851,3,251,124,0,851,852,3,269,133,0,852,853,3,259,128,0,853, + 156,1,0,0,0,854,855,3,263,130,0,855,856,3,257,127,0,856,857,3,273,135, + 0,857,158,1,0,0,0,858,859,3,263,130,0,859,860,3,257,127,0,860,861,3,273, + 135,0,861,862,3,265,131,0,862,160,1,0,0,0,863,864,3,265,131,0,864,865, + 3,229,113,0,865,866,3,253,125,0,866,867,3,259,128,0,867,868,3,251,124, + 0,868,869,3,237,117,0,869,162,1,0,0,0,870,871,3,265,131,0,871,872,3,237, + 117,0,872,873,3,233,115,0,873,874,3,257,127,0,874,875,3,255,126,0,875, + 876,3,235,116,0,876,164,1,0,0,0,877,878,3,265,131,0,878,879,3,237,117, + 0,879,880,3,251,124,0,880,881,3,237,117,0,881,882,3,233,115,0,882,883, + 3,267,132,0,883,166,1,0,0,0,884,885,3,265,131,0,885,886,3,237,117,0,886, + 887,3,253,125,0,887,888,3,245,121,0,888,168,1,0,0,0,889,890,3,265,131, + 0,890,891,3,237,117,0,891,892,3,267,132,0,892,893,3,267,132,0,893,894, + 3,245,121,0,894,895,3,255,126,0,895,896,3,241,119,0,896,897,3,265,131, + 0,897,170,1,0,0,0,898,899,3,265,131,0,899,900,3,269,133,0,900,901,3,231, + 114,0,901,902,3,265,131,0,902,903,3,267,132,0,903,904,3,263,130,0,904, + 905,3,245,121,0,905,906,3,255,126,0,906,907,3,241,119,0,907,172,1,0,0, + 0,908,909,3,267,132,0,909,910,3,243,120,0,910,911,3,237,117,0,911,912, + 3,255,126,0,912,174,1,0,0,0,913,914,3,267,132,0,914,915,3,243,120,0,915, + 916,3,263,130,0,916,917,3,257,127,0,917,918,3,273,135,0,918,176,1,0,0, + 0,919,920,3,267,132,0,920,921,3,245,121,0,921,922,3,237,117,0,922,923, + 3,265,131,0,923,178,1,0,0,0,924,925,3,267,132,0,925,926,3,245,121,0,926, + 927,3,253,125,0,927,928,3,237,117,0,928,929,3,265,131,0,929,930,3,267, + 132,0,930,931,3,229,113,0,931,932,3,253,125,0,932,933,3,259,128,0,933, + 180,1,0,0,0,934,935,3,267,132,0,935,936,3,257,127,0,936,182,1,0,0,0,937, + 938,3,267,132,0,938,939,3,257,127,0,939,940,3,259,128,0,940,184,1,0,0, + 0,941,942,3,267,132,0,942,943,3,257,127,0,943,944,3,267,132,0,944,945, + 3,229,113,0,945,946,3,251,124,0,946,947,3,265,131,0,947,186,1,0,0,0,948, + 949,3,267,132,0,949,950,3,263,130,0,950,951,3,229,113,0,951,952,3,245, + 121,0,952,953,3,251,124,0,953,954,3,245,121,0,954,955,3,255,126,0,955, + 956,3,241,119,0,956,188,1,0,0,0,957,958,3,267,132,0,958,959,3,263,130, + 0,959,960,3,245,121,0,960,961,3,253,125,0,961,190,1,0,0,0,962,963,3,267, + 132,0,963,964,3,263,130,0,964,965,3,269,133,0,965,966,3,255,126,0,966, + 967,3,233,115,0,967,968,3,229,113,0,968,969,3,267,132,0,969,970,3,237, + 117,0,970,192,1,0,0,0,971,972,3,267,132,0,972,973,3,263,130,0,973,974, + 3,277,137,0,974,194,1,0,0,0,975,976,3,269,133,0,976,977,3,255,126,0,977, + 978,3,231,114,0,978,979,3,257,127,0,979,980,3,269,133,0,980,981,3,255, + 126,0,981,982,3,235,116,0,982,983,3,237,117,0,983,984,3,235,116,0,984, + 196,1,0,0,0,985,986,3,269,133,0,986,987,3,255,126,0,987,988,3,245,121, + 0,988,989,3,257,127,0,989,990,3,255,126,0,990,198,1,0,0,0,991,992,3,269, + 133,0,992,993,3,265,131,0,993,994,3,245,121,0,994,995,3,255,126,0,995, + 996,3,241,119,0,996,200,1,0,0,0,997,998,3,273,135,0,998,999,3,237,117, + 0,999,1000,3,237,117,0,1000,1001,3,249,123,0,1001,202,1,0,0,0,1002,1003, + 3,273,135,0,1003,1004,3,243,120,0,1004,1005,3,237,117,0,1005,1006,3,255, + 126,0,1006,204,1,0,0,0,1007,1008,3,273,135,0,1008,1009,3,243,120,0,1009, + 1010,3,237,117,0,1010,1011,3,263,130,0,1011,1012,3,237,117,0,1012,206, + 1,0,0,0,1013,1014,3,273,135,0,1014,1015,3,243,120,0,1015,1016,3,245,121, + 0,1016,1017,3,251,124,0,1017,1018,3,237,117,0,1018,208,1,0,0,0,1019,1020, + 3,273,135,0,1020,1021,3,245,121,0,1021,1022,3,255,126,0,1022,1023,3,235, + 116,0,1023,1024,3,257,127,0,1024,1025,3,273,135,0,1025,210,1,0,0,0,1026, + 1027,3,273,135,0,1027,1028,3,245,121,0,1028,1029,3,267,132,0,1029,1030, + 3,243,120,0,1030,212,1,0,0,0,1031,1032,3,277,137,0,1032,1033,3,237,117, + 0,1033,1034,3,229,113,0,1034,1035,3,263,130,0,1035,1042,1,0,0,0,1036, + 1037,3,277,137,0,1037,1038,3,277,137,0,1038,1039,3,277,137,0,1039,1040, + 3,277,137,0,1040,1042,1,0,0,0,1041,1031,1,0,0,0,1041,1036,1,0,0,0,1042, + 214,1,0,0,0,1043,1044,3,295,146,0,1044,1045,3,231,114,0,1045,1071,1,0, + 0,0,1046,1047,3,295,146,0,1047,1048,3,239,118,0,1048,1071,1,0,0,0,1049, + 1050,3,295,146,0,1050,1051,3,263,130,0,1051,1071,1,0,0,0,1052,1053,3, + 295,146,0,1053,1054,3,255,126,0,1054,1071,1,0,0,0,1055,1056,3,295,146, + 0,1056,1057,3,267,132,0,1057,1071,1,0,0,0,1058,1059,3,295,146,0,1059, + 1060,5,48,0,0,1060,1071,1,0,0,0,1061,1062,3,295,146,0,1062,1063,3,229, + 113,0,1063,1071,1,0,0,0,1064,1065,3,295,146,0,1065,1066,3,271,134,0,1066, + 1071,1,0,0,0,1067,1068,3,295,146,0,1068,1069,3,295,146,0,1069,1071,1, + 0,0,0,1070,1043,1,0,0,0,1070,1046,1,0,0,0,1070,1049,1,0,0,0,1070,1052, + 1,0,0,0,1070,1055,1,0,0,0,1070,1058,1,0,0,0,1070,1061,1,0,0,0,1070,1064, + 1,0,0,0,1070,1067,1,0,0,0,1071,216,1,0,0,0,1072,1076,3,281,139,0,1073, + 1076,3,371,184,0,1074,1076,3,305,151,0,1075,1072,1,0,0,0,1075,1073,1, + 0,0,0,1075,1074,1,0,0,0,1076,1083,1,0,0,0,1077,1082,3,281,139,0,1078, + 1082,3,371,184,0,1079,1082,3,285,141,0,1080,1082,3,305,151,0,1081,1077, + 1,0,0,0,1081,1078,1,0,0,0,1081,1079,1,0,0,0,1081,1080,1,0,0,0,1082,1085, + 1,0,0,0,1083,1081,1,0,0,0,1083,1084,1,0,0,0,1084,1119,1,0,0,0,1085,1083, + 1,0,0,0,1086,1097,3,293,145,0,1087,1096,8,0,0,0,1088,1096,3,215,106,0, + 1089,1090,3,295,146,0,1090,1091,3,355,176,0,1091,1096,1,0,0,0,1092,1093, + 3,293,145,0,1093,1094,3,293,145,0,1094,1096,1,0,0,0,1095,1087,1,0,0,0, + 1095,1088,1,0,0,0,1095,1089,1,0,0,0,1095,1092,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,1101,3,293,145,0,1101,1119,1,0,0,0,1102,1113,3,349,173,0,1103, + 1112,8,1,0,0,1104,1112,3,215,106,0,1105,1106,3,295,146,0,1106,1107,3, + 349,173,0,1107,1112,1,0,0,0,1108,1109,3,349,173,0,1109,1110,3,349,173, + 0,1110,1112,1,0,0,0,1111,1103,1,0,0,0,1111,1104,1,0,0,0,1111,1105,1,0, + 0,0,1111,1108,1,0,0,0,1112,1115,1,0,0,0,1113,1111,1,0,0,0,1113,1114,1, + 0,0,0,1114,1116,1,0,0,0,1115,1113,1,0,0,0,1116,1117,3,349,173,0,1117, + 1119,1,0,0,0,1118,1075,1,0,0,0,1118,1086,1,0,0,0,1118,1102,1,0,0,0,1119, + 218,1,0,0,0,1120,1121,3,225,111,0,1121,1125,3,307,152,0,1122,1124,3,287, + 142,0,1123,1122,1,0,0,0,1124,1127,1,0,0,0,1125,1123,1,0,0,0,1125,1126, + 1,0,0,0,1126,1130,1,0,0,0,1127,1125,1,0,0,0,1128,1131,3,259,128,0,1129, + 1131,3,237,117,0,1130,1128,1,0,0,0,1130,1129,1,0,0,0,1131,1134,1,0,0, + 0,1132,1135,3,345,171,0,1133,1135,3,303,150,0,1134,1132,1,0,0,0,1134, + 1133,1,0,0,0,1134,1135,1,0,0,0,1135,1137,1,0,0,0,1136,1138,3,285,141, + 0,1137,1136,1,0,0,0,1138,1139,1,0,0,0,1139,1137,1,0,0,0,1139,1140,1,0, + 0,0,1140,1197,1,0,0,0,1141,1144,3,225,111,0,1142,1145,3,259,128,0,1143, + 1145,3,237,117,0,1144,1142,1,0,0,0,1144,1143,1,0,0,0,1145,1148,1,0,0, + 0,1146,1149,3,345,171,0,1147,1149,3,303,150,0,1148,1146,1,0,0,0,1148, + 1147,1,0,0,0,1148,1149,1,0,0,0,1149,1151,1,0,0,0,1150,1152,3,285,141, + 0,1151,1150,1,0,0,0,1152,1153,1,0,0,0,1153,1151,1,0,0,0,1153,1154,1,0, + 0,0,1154,1197,1,0,0,0,1155,1156,3,223,110,0,1156,1160,3,307,152,0,1157, + 1159,3,285,141,0,1158,1157,1,0,0,0,1159,1162,1,0,0,0,1160,1158,1,0,0, + 0,1160,1161,1,0,0,0,1161,1163,1,0,0,0,1162,1160,1,0,0,0,1163,1166,3,237, + 117,0,1164,1167,3,345,171,0,1165,1167,3,303,150,0,1166,1164,1,0,0,0,1166, + 1165,1,0,0,0,1166,1167,1,0,0,0,1167,1169,1,0,0,0,1168,1170,3,285,141, + 0,1169,1168,1,0,0,0,1170,1171,1,0,0,0,1171,1169,1,0,0,0,1171,1172,1,0, + 0,0,1172,1197,1,0,0,0,1173,1174,3,307,152,0,1174,1175,3,223,110,0,1175, + 1178,3,237,117,0,1176,1179,3,345,171,0,1177,1179,3,303,150,0,1178,1176, + 1,0,0,0,1178,1177,1,0,0,0,1178,1179,1,0,0,0,1179,1181,1,0,0,0,1180,1182, + 3,285,141,0,1181,1180,1,0,0,0,1182,1183,1,0,0,0,1183,1181,1,0,0,0,1183, + 1184,1,0,0,0,1184,1197,1,0,0,0,1185,1186,3,223,110,0,1186,1189,3,237, + 117,0,1187,1190,3,345,171,0,1188,1190,3,303,150,0,1189,1187,1,0,0,0,1189, + 1188,1,0,0,0,1189,1190,1,0,0,0,1190,1192,1,0,0,0,1191,1193,3,285,141, + 0,1192,1191,1,0,0,0,1193,1194,1,0,0,0,1194,1192,1,0,0,0,1194,1195,1,0, + 0,0,1195,1197,1,0,0,0,1196,1120,1,0,0,0,1196,1141,1,0,0,0,1196,1155,1, + 0,0,0,1196,1173,1,0,0,0,1196,1185,1,0,0,0,1197,220,1,0,0,0,1198,1200, + 5,48,0,0,1199,1201,3,283,140,0,1200,1199,1,0,0,0,1201,1202,1,0,0,0,1202, + 1200,1,0,0,0,1202,1203,1,0,0,0,1203,222,1,0,0,0,1204,1206,3,285,141,0, + 1205,1204,1,0,0,0,1206,1207,1,0,0,0,1207,1205,1,0,0,0,1207,1208,1,0,0, + 0,1208,224,1,0,0,0,1209,1210,5,48,0,0,1210,1212,3,275,136,0,1211,1213, + 3,287,142,0,1212,1211,1,0,0,0,1213,1214,1,0,0,0,1214,1212,1,0,0,0,1214, + 1215,1,0,0,0,1215,226,1,0,0,0,1216,1227,3,355,176,0,1217,1226,8,2,0,0, + 1218,1226,3,215,106,0,1219,1220,3,295,146,0,1220,1221,3,355,176,0,1221, + 1226,1,0,0,0,1222,1223,3,355,176,0,1223,1224,3,355,176,0,1224,1226,1, + 0,0,0,1225,1217,1,0,0,0,1225,1218,1,0,0,0,1225,1219,1,0,0,0,1225,1222, + 1,0,0,0,1226,1229,1,0,0,0,1227,1225,1,0,0,0,1227,1228,1,0,0,0,1228,1230, + 1,0,0,0,1229,1227,1,0,0,0,1230,1231,3,355,176,0,1231,228,1,0,0,0,1232, + 1233,7,3,0,0,1233,230,1,0,0,0,1234,1235,7,4,0,0,1235,232,1,0,0,0,1236, + 1237,7,5,0,0,1237,234,1,0,0,0,1238,1239,7,6,0,0,1239,236,1,0,0,0,1240, + 1241,7,7,0,0,1241,238,1,0,0,0,1242,1243,7,8,0,0,1243,240,1,0,0,0,1244, + 1245,7,9,0,0,1245,242,1,0,0,0,1246,1247,7,10,0,0,1247,244,1,0,0,0,1248, + 1249,7,11,0,0,1249,246,1,0,0,0,1250,1251,7,12,0,0,1251,248,1,0,0,0,1252, + 1253,7,13,0,0,1253,250,1,0,0,0,1254,1255,7,14,0,0,1255,252,1,0,0,0,1256, + 1257,7,15,0,0,1257,254,1,0,0,0,1258,1259,7,16,0,0,1259,256,1,0,0,0,1260, + 1261,7,17,0,0,1261,258,1,0,0,0,1262,1263,7,18,0,0,1263,260,1,0,0,0,1264, + 1265,7,19,0,0,1265,262,1,0,0,0,1266,1267,7,20,0,0,1267,264,1,0,0,0,1268, + 1269,7,21,0,0,1269,266,1,0,0,0,1270,1271,7,22,0,0,1271,268,1,0,0,0,1272, + 1273,7,23,0,0,1273,270,1,0,0,0,1274,1275,7,24,0,0,1275,272,1,0,0,0,1276, + 1277,7,25,0,0,1277,274,1,0,0,0,1278,1279,7,26,0,0,1279,276,1,0,0,0,1280, + 1281,7,27,0,0,1281,278,1,0,0,0,1282,1283,7,28,0,0,1283,280,1,0,0,0,1284, + 1285,7,29,0,0,1285,282,1,0,0,0,1286,1287,7,30,0,0,1287,284,1,0,0,0,1288, + 1289,7,31,0,0,1289,286,1,0,0,0,1290,1291,7,32,0,0,1291,288,1,0,0,0,1292, + 1293,5,45,0,0,1293,1294,5,62,0,0,1294,290,1,0,0,0,1295,1296,5,42,0,0, + 1296,292,1,0,0,0,1297,1298,5,96,0,0,1298,294,1,0,0,0,1299,1300,5,92,0, + 0,1300,296,1,0,0,0,1301,1302,5,58,0,0,1302,298,1,0,0,0,1303,1304,5,44, + 0,0,1304,300,1,0,0,0,1305,1306,5,124,0,0,1306,1307,5,124,0,0,1307,302, + 1,0,0,0,1308,1309,5,45,0,0,1309,304,1,0,0,0,1310,1311,5,36,0,0,1311,306, + 1,0,0,0,1312,1313,5,46,0,0,1313,308,1,0,0,0,1314,1315,5,61,0,0,1315,1316, + 5,61,0,0,1316,310,1,0,0,0,1317,1318,5,61,0,0,1318,312,1,0,0,0,1319,1320, + 5,62,0,0,1320,1321,5,61,0,0,1321,314,1,0,0,0,1322,1323,5,62,0,0,1323, + 316,1,0,0,0,1324,1325,5,35,0,0,1325,318,1,0,0,0,1326,1327,5,126,0,0,1327, + 1328,5,42,0,0,1328,320,1,0,0,0,1329,1330,5,61,0,0,1330,1331,5,126,0,0, + 1331,1332,5,42,0,0,1332,322,1,0,0,0,1333,1334,5,123,0,0,1334,1335,1,0, + 0,0,1335,1336,6,160,0,0,1336,324,1,0,0,0,1337,1338,5,91,0,0,1338,326, + 1,0,0,0,1339,1340,5,40,0,0,1340,328,1,0,0,0,1341,1342,5,60,0,0,1342,1343, + 5,61,0,0,1343,330,1,0,0,0,1344,1345,5,60,0,0,1345,332,1,0,0,0,1346,1347, + 5,33,0,0,1347,1351,5,61,0,0,1348,1349,5,60,0,0,1349,1351,5,62,0,0,1350, + 1346,1,0,0,0,1350,1348,1,0,0,0,1351,334,1,0,0,0,1352,1353,5,33,0,0,1353, + 1354,5,126,0,0,1354,1355,5,42,0,0,1355,336,1,0,0,0,1356,1357,5,33,0,0, + 1357,1358,5,126,0,0,1358,338,1,0,0,0,1359,1360,5,63,0,0,1360,1361,5,46, + 0,0,1361,340,1,0,0,0,1362,1363,5,63,0,0,1363,1364,5,63,0,0,1364,342,1, + 0,0,0,1365,1366,5,37,0,0,1366,344,1,0,0,0,1367,1368,5,43,0,0,1368,346, + 1,0,0,0,1369,1370,5,63,0,0,1370,348,1,0,0,0,1371,1372,5,34,0,0,1372,350, + 1,0,0,0,1373,1374,5,102,0,0,1374,1375,5,39,0,0,1375,1376,1,0,0,0,1376, + 1377,6,174,1,0,1377,352,1,0,0,0,1378,1379,5,70,0,0,1379,1380,5,39,0,0, + 1380,1381,1,0,0,0,1381,1382,6,175,2,0,1382,354,1,0,0,0,1383,1384,5,39, + 0,0,1384,356,1,0,0,0,1385,1386,5,126,0,0,1386,358,1,0,0,0,1387,1388,5, + 61,0,0,1388,1389,5,126,0,0,1389,360,1,0,0,0,1390,1391,5,125,0,0,1391, + 1392,1,0,0,0,1392,1393,6,179,3,0,1393,362,1,0,0,0,1394,1395,5,93,0,0, + 1395,364,1,0,0,0,1396,1397,5,41,0,0,1397,366,1,0,0,0,1398,1399,5,59,0, + 0,1399,368,1,0,0,0,1400,1401,5,47,0,0,1401,370,1,0,0,0,1402,1403,5,95, + 0,0,1403,372,1,0,0,0,1404,1405,5,47,0,0,1405,1406,5,42,0,0,1406,1410, + 1,0,0,0,1407,1409,9,0,0,0,1408,1407,1,0,0,0,1409,1412,1,0,0,0,1410,1411, + 1,0,0,0,1410,1408,1,0,0,0,1411,1413,1,0,0,0,1412,1410,1,0,0,0,1413,1414, + 5,42,0,0,1414,1415,5,47,0,0,1415,1416,1,0,0,0,1416,1417,6,185,4,0,1417, + 374,1,0,0,0,1418,1419,5,45,0,0,1419,1423,5,45,0,0,1420,1421,5,47,0,0, + 1421,1423,5,47,0,0,1422,1418,1,0,0,0,1422,1420,1,0,0,0,1423,1427,1,0, + 0,0,1424,1426,8,33,0,0,1425,1424,1,0,0,0,1426,1429,1,0,0,0,1427,1425, + 1,0,0,0,1427,1428,1,0,0,0,1428,1431,1,0,0,0,1429,1427,1,0,0,0,1430,1432, + 7,34,0,0,1431,1430,1,0,0,0,1432,1433,1,0,0,0,1433,1434,6,186,4,0,1434, + 376,1,0,0,0,1435,1436,7,35,0,0,1436,1437,1,0,0,0,1437,1438,6,187,5,0, + 1438,378,1,0,0,0,1439,1451,8,36,0,0,1440,1451,3,215,106,0,1441,1442,3, + 295,146,0,1442,1443,3,355,176,0,1443,1451,1,0,0,0,1444,1445,3,295,146, + 0,1445,1446,3,323,160,0,1446,1451,1,0,0,0,1447,1448,3,355,176,0,1448, + 1449,3,355,176,0,1449,1451,1,0,0,0,1450,1439,1,0,0,0,1450,1440,1,0,0, + 0,1450,1441,1,0,0,0,1450,1444,1,0,0,0,1450,1447,1,0,0,0,1451,1452,1,0, + 0,0,1452,1450,1,0,0,0,1452,1453,1,0,0,0,1453,380,1,0,0,0,1454,1455,3, + 323,160,0,1455,1456,1,0,0,0,1456,1457,6,189,0,0,1457,382,1,0,0,0,1458, + 1459,3,355,176,0,1459,1460,1,0,0,0,1460,1461,6,190,6,0,1461,1462,6,190, + 3,0,1462,384,1,0,0,0,1463,1469,8,37,0,0,1464,1469,3,215,106,0,1465,1466, + 3,295,146,0,1466,1467,3,323,160,0,1467,1469,1,0,0,0,1468,1463,1,0,0,0, + 1468,1464,1,0,0,0,1468,1465,1,0,0,0,1469,1470,1,0,0,0,1470,1468,1,0,0, + 0,1470,1471,1,0,0,0,1471,386,1,0,0,0,1472,1473,3,323,160,0,1473,1474, + 1,0,0,0,1474,1475,6,192,0,0,1475,388,1,0,0,0,44,0,1,2,429,657,1041,1070, + 1075,1081,1083,1095,1097,1111,1113,1118,1125,1130,1134,1139,1144,1148, + 1153,1160,1166,1171,1178,1183,1189,1194,1196,1202,1207,1214,1225,1227, + 1350,1410,1422,1427,1431,1450,1452,1468,1470,7,5,0,0,5,1,0,5,2,0,4,0, + 0,6,0,0,0,1,0,7,147,0 }; staticData->serializedATN = antlr4::atn::SerializedATNView(serializedATNSegment, sizeof(serializedATNSegment) / sizeof(serializedATNSegment[0])); diff --git a/hogql_parser/HogQLLexer.h b/hogql_parser/HogQLLexer.h index bb58a9f4db1d1..243379314630a 100644 --- a/hogql_parser/HogQLLexer.h +++ b/hogql_parser/HogQLLexer.h @@ -16,32 +16,33 @@ class HogQLLexer : public antlr4::Lexer { ASOF = 8, BETWEEN = 9, BOTH = 10, BY = 11, CASE = 12, CAST = 13, CATCH = 14, COHORT = 15, COLLATE = 16, CROSS = 17, CUBE = 18, CURRENT = 19, DATE = 20, DAY = 21, DESC = 22, DESCENDING = 23, DISTINCT = 24, ELSE = 25, END = 26, - EXTRACT = 27, FINAL = 28, FINALLY = 29, FIRST = 30, FN = 31, FOLLOWING = 32, - FOR = 33, FROM = 34, FULL = 35, FUN = 36, GROUP = 37, HAVING = 38, HOUR = 39, - ID = 40, IF = 41, ILIKE = 42, IN = 43, INF = 44, INNER = 45, INTERVAL = 46, - IS = 47, JOIN = 48, KEY = 49, LAST = 50, LEADING = 51, LEFT = 52, LET = 53, - LIKE = 54, LIMIT = 55, MINUTE = 56, MONTH = 57, NAN_SQL = 58, NOT = 59, - NULL_SQL = 60, NULLS = 61, OFFSET = 62, ON = 63, OR = 64, ORDER = 65, - OUTER = 66, OVER = 67, PARTITION = 68, PRECEDING = 69, PREWHERE = 70, - QUARTER = 71, RANGE = 72, RETURN = 73, RIGHT = 74, ROLLUP = 75, ROW = 76, - ROWS = 77, SAMPLE = 78, SECOND = 79, SELECT = 80, SEMI = 81, SETTINGS = 82, - SUBSTRING = 83, THEN = 84, THROW = 85, TIES = 86, TIMESTAMP = 87, TO = 88, - TOP = 89, TOTALS = 90, TRAILING = 91, TRIM = 92, TRUNCATE = 93, TRY = 94, - UNBOUNDED = 95, UNION = 96, USING = 97, WEEK = 98, WHEN = 99, WHERE = 100, - WHILE = 101, WINDOW = 102, WITH = 103, YEAR = 104, ESCAPE_CHAR_COMMON = 105, - IDENTIFIER = 106, FLOATING_LITERAL = 107, OCTAL_LITERAL = 108, DECIMAL_LITERAL = 109, - HEXADECIMAL_LITERAL = 110, STRING_LITERAL = 111, ARROW = 112, ASTERISK = 113, - BACKQUOTE = 114, BACKSLASH = 115, COLON = 116, COMMA = 117, CONCAT = 118, - DASH = 119, DOLLAR = 120, DOT = 121, EQ_DOUBLE = 122, EQ_SINGLE = 123, - GT_EQ = 124, GT = 125, HASH = 126, IREGEX_SINGLE = 127, IREGEX_DOUBLE = 128, - LBRACE = 129, LBRACKET = 130, LPAREN = 131, LT_EQ = 132, LT = 133, NOT_EQ = 134, - NOT_IREGEX = 135, NOT_REGEX = 136, NULL_PROPERTY = 137, NULLISH = 138, - PERCENT = 139, PLUS = 140, QUERY = 141, QUOTE_DOUBLE = 142, QUOTE_SINGLE_TEMPLATE = 143, - QUOTE_SINGLE_TEMPLATE_FULL = 144, QUOTE_SINGLE = 145, REGEX_SINGLE = 146, - REGEX_DOUBLE = 147, RBRACE = 148, RBRACKET = 149, RPAREN = 150, SEMICOLON = 151, - SLASH = 152, UNDERSCORE = 153, MULTI_LINE_COMMENT = 154, SINGLE_LINE_COMMENT = 155, - WHITESPACE = 156, STRING_TEXT = 157, STRING_ESCAPE_TRIGGER = 158, FULL_STRING_TEXT = 159, - FULL_STRING_ESCAPE_TRIGGER = 160 + EXCEPT = 27, EXTRACT = 28, FINAL = 29, FINALLY = 30, FIRST = 31, FN = 32, + FOLLOWING = 33, FOR = 34, FROM = 35, FULL = 36, FUN = 37, GROUP = 38, + HAVING = 39, HOUR = 40, ID = 41, IF = 42, ILIKE = 43, IN = 44, INF = 45, + INNER = 46, INTERSECT = 47, INTERVAL = 48, IS = 49, JOIN = 50, KEY = 51, + LAST = 52, LEADING = 53, LEFT = 54, LET = 55, LIKE = 56, LIMIT = 57, + MINUTE = 58, MONTH = 59, NAN_SQL = 60, NOT = 61, NULL_SQL = 62, NULLS = 63, + OFFSET = 64, ON = 65, OR = 66, ORDER = 67, OUTER = 68, OVER = 69, PARTITION = 70, + PRECEDING = 71, PREWHERE = 72, QUARTER = 73, RANGE = 74, RETURN = 75, + RIGHT = 76, ROLLUP = 77, ROW = 78, ROWS = 79, SAMPLE = 80, SECOND = 81, + SELECT = 82, SEMI = 83, SETTINGS = 84, SUBSTRING = 85, THEN = 86, THROW = 87, + TIES = 88, TIMESTAMP = 89, TO = 90, TOP = 91, TOTALS = 92, TRAILING = 93, + TRIM = 94, TRUNCATE = 95, TRY = 96, UNBOUNDED = 97, UNION = 98, USING = 99, + WEEK = 100, WHEN = 101, WHERE = 102, WHILE = 103, WINDOW = 104, WITH = 105, + YEAR = 106, ESCAPE_CHAR_COMMON = 107, IDENTIFIER = 108, FLOATING_LITERAL = 109, + OCTAL_LITERAL = 110, DECIMAL_LITERAL = 111, HEXADECIMAL_LITERAL = 112, + STRING_LITERAL = 113, ARROW = 114, ASTERISK = 115, BACKQUOTE = 116, + BACKSLASH = 117, COLON = 118, COMMA = 119, CONCAT = 120, DASH = 121, + DOLLAR = 122, DOT = 123, EQ_DOUBLE = 124, EQ_SINGLE = 125, GT_EQ = 126, + GT = 127, HASH = 128, IREGEX_SINGLE = 129, IREGEX_DOUBLE = 130, LBRACE = 131, + LBRACKET = 132, LPAREN = 133, LT_EQ = 134, LT = 135, NOT_EQ = 136, NOT_IREGEX = 137, + NOT_REGEX = 138, NULL_PROPERTY = 139, NULLISH = 140, PERCENT = 141, + PLUS = 142, QUERY = 143, QUOTE_DOUBLE = 144, QUOTE_SINGLE_TEMPLATE = 145, + QUOTE_SINGLE_TEMPLATE_FULL = 146, QUOTE_SINGLE = 147, REGEX_SINGLE = 148, + REGEX_DOUBLE = 149, RBRACE = 150, RBRACKET = 151, RPAREN = 152, SEMICOLON = 153, + SLASH = 154, UNDERSCORE = 155, MULTI_LINE_COMMENT = 156, SINGLE_LINE_COMMENT = 157, + WHITESPACE = 158, STRING_TEXT = 159, STRING_ESCAPE_TRIGGER = 160, FULL_STRING_TEXT = 161, + FULL_STRING_ESCAPE_TRIGGER = 162 }; enum { diff --git a/hogql_parser/HogQLLexer.interp b/hogql_parser/HogQLLexer.interp index dc4c26657342d..f461a8e011b30 100644 --- a/hogql_parser/HogQLLexer.interp +++ b/hogql_parser/HogQLLexer.interp @@ -111,6 +111,8 @@ null null null null +null +null '->' '*' '`' @@ -189,6 +191,7 @@ DESCENDING DISTINCT ELSE END +EXCEPT EXTRACT FINAL FINALLY @@ -208,6 +211,7 @@ ILIKE IN INF INNER +INTERSECT INTERVAL IS JOIN @@ -351,6 +355,7 @@ DESCENDING DISTINCT ELSE END +EXCEPT EXTRACT FINAL FINALLY @@ -370,6 +375,7 @@ ILIKE IN INF INNER +INTERSECT INTERVAL IS JOIN @@ -527,4 +533,4 @@ IN_TEMPLATE_STRING IN_FULL_TEMPLATE_STRING atn: -[4, 0, 160, 1455, 6, -1, 6, -1, 6, -1, 2, 0, 7, 0, 2, 1, 7, 1, 2, 2, 7, 2, 2, 3, 7, 3, 2, 4, 7, 4, 2, 5, 7, 5, 2, 6, 7, 6, 2, 7, 7, 7, 2, 8, 7, 8, 2, 9, 7, 9, 2, 10, 7, 10, 2, 11, 7, 11, 2, 12, 7, 12, 2, 13, 7, 13, 2, 14, 7, 14, 2, 15, 7, 15, 2, 16, 7, 16, 2, 17, 7, 17, 2, 18, 7, 18, 2, 19, 7, 19, 2, 20, 7, 20, 2, 21, 7, 21, 2, 22, 7, 22, 2, 23, 7, 23, 2, 24, 7, 24, 2, 25, 7, 25, 2, 26, 7, 26, 2, 27, 7, 27, 2, 28, 7, 28, 2, 29, 7, 29, 2, 30, 7, 30, 2, 31, 7, 31, 2, 32, 7, 32, 2, 33, 7, 33, 2, 34, 7, 34, 2, 35, 7, 35, 2, 36, 7, 36, 2, 37, 7, 37, 2, 38, 7, 38, 2, 39, 7, 39, 2, 40, 7, 40, 2, 41, 7, 41, 2, 42, 7, 42, 2, 43, 7, 43, 2, 44, 7, 44, 2, 45, 7, 45, 2, 46, 7, 46, 2, 47, 7, 47, 2, 48, 7, 48, 2, 49, 7, 49, 2, 50, 7, 50, 2, 51, 7, 51, 2, 52, 7, 52, 2, 53, 7, 53, 2, 54, 7, 54, 2, 55, 7, 55, 2, 56, 7, 56, 2, 57, 7, 57, 2, 58, 7, 58, 2, 59, 7, 59, 2, 60, 7, 60, 2, 61, 7, 61, 2, 62, 7, 62, 2, 63, 7, 63, 2, 64, 7, 64, 2, 65, 7, 65, 2, 66, 7, 66, 2, 67, 7, 67, 2, 68, 7, 68, 2, 69, 7, 69, 2, 70, 7, 70, 2, 71, 7, 71, 2, 72, 7, 72, 2, 73, 7, 73, 2, 74, 7, 74, 2, 75, 7, 75, 2, 76, 7, 76, 2, 77, 7, 77, 2, 78, 7, 78, 2, 79, 7, 79, 2, 80, 7, 80, 2, 81, 7, 81, 2, 82, 7, 82, 2, 83, 7, 83, 2, 84, 7, 84, 2, 85, 7, 85, 2, 86, 7, 86, 2, 87, 7, 87, 2, 88, 7, 88, 2, 89, 7, 89, 2, 90, 7, 90, 2, 91, 7, 91, 2, 92, 7, 92, 2, 93, 7, 93, 2, 94, 7, 94, 2, 95, 7, 95, 2, 96, 7, 96, 2, 97, 7, 97, 2, 98, 7, 98, 2, 99, 7, 99, 2, 100, 7, 100, 2, 101, 7, 101, 2, 102, 7, 102, 2, 103, 7, 103, 2, 104, 7, 104, 2, 105, 7, 105, 2, 106, 7, 106, 2, 107, 7, 107, 2, 108, 7, 108, 2, 109, 7, 109, 2, 110, 7, 110, 2, 111, 7, 111, 2, 112, 7, 112, 2, 113, 7, 113, 2, 114, 7, 114, 2, 115, 7, 115, 2, 116, 7, 116, 2, 117, 7, 117, 2, 118, 7, 118, 2, 119, 7, 119, 2, 120, 7, 120, 2, 121, 7, 121, 2, 122, 7, 122, 2, 123, 7, 123, 2, 124, 7, 124, 2, 125, 7, 125, 2, 126, 7, 126, 2, 127, 7, 127, 2, 128, 7, 128, 2, 129, 7, 129, 2, 130, 7, 130, 2, 131, 7, 131, 2, 132, 7, 132, 2, 133, 7, 133, 2, 134, 7, 134, 2, 135, 7, 135, 2, 136, 7, 136, 2, 137, 7, 137, 2, 138, 7, 138, 2, 139, 7, 139, 2, 140, 7, 140, 2, 141, 7, 141, 2, 142, 7, 142, 2, 143, 7, 143, 2, 144, 7, 144, 2, 145, 7, 145, 2, 146, 7, 146, 2, 147, 7, 147, 2, 148, 7, 148, 2, 149, 7, 149, 2, 150, 7, 150, 2, 151, 7, 151, 2, 152, 7, 152, 2, 153, 7, 153, 2, 154, 7, 154, 2, 155, 7, 155, 2, 156, 7, 156, 2, 157, 7, 157, 2, 158, 7, 158, 2, 159, 7, 159, 2, 160, 7, 160, 2, 161, 7, 161, 2, 162, 7, 162, 2, 163, 7, 163, 2, 164, 7, 164, 2, 165, 7, 165, 2, 166, 7, 166, 2, 167, 7, 167, 2, 168, 7, 168, 2, 169, 7, 169, 2, 170, 7, 170, 2, 171, 7, 171, 2, 172, 7, 172, 2, 173, 7, 173, 2, 174, 7, 174, 2, 175, 7, 175, 2, 176, 7, 176, 2, 177, 7, 177, 2, 178, 7, 178, 2, 179, 7, 179, 2, 180, 7, 180, 2, 181, 7, 181, 2, 182, 7, 182, 2, 183, 7, 183, 2, 184, 7, 184, 2, 185, 7, 185, 2, 186, 7, 186, 2, 187, 7, 187, 2, 188, 7, 188, 2, 189, 7, 189, 2, 190, 7, 190, 1, 0, 1, 0, 1, 0, 1, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 2, 1, 2, 1, 2, 1, 2, 1, 2, 1, 3, 1, 3, 1, 3, 1, 3, 1, 4, 1, 4, 1, 4, 1, 4, 1, 4, 1, 4, 1, 5, 1, 5, 1, 5, 1, 6, 1, 6, 1, 6, 1, 6, 1, 6, 1, 6, 1, 6, 1, 6, 1, 6, 1, 6, 1, 6, 1, 6, 1, 6, 1, 6, 3, 6, 426, 8, 6, 1, 7, 1, 7, 1, 7, 1, 7, 1, 7, 1, 8, 1, 8, 1, 8, 1, 8, 1, 8, 1, 8, 1, 8, 1, 8, 1, 9, 1, 9, 1, 9, 1, 9, 1, 9, 1, 10, 1, 10, 1, 10, 1, 11, 1, 11, 1, 11, 1, 11, 1, 11, 1, 12, 1, 12, 1, 12, 1, 12, 1, 12, 1, 13, 1, 13, 1, 13, 1, 13, 1, 13, 1, 13, 1, 14, 1, 14, 1, 14, 1, 14, 1, 14, 1, 14, 1, 14, 1, 15, 1, 15, 1, 15, 1, 15, 1, 15, 1, 15, 1, 15, 1, 15, 1, 16, 1, 16, 1, 16, 1, 16, 1, 16, 1, 16, 1, 17, 1, 17, 1, 17, 1, 17, 1, 17, 1, 18, 1, 18, 1, 18, 1, 18, 1, 18, 1, 18, 1, 18, 1, 18, 1, 19, 1, 19, 1, 19, 1, 19, 1, 19, 1, 20, 1, 20, 1, 20, 1, 20, 1, 21, 1, 21, 1, 21, 1, 21, 1, 21, 1, 22, 1, 22, 1, 22, 1, 22, 1, 22, 1, 22, 1, 22, 1, 22, 1, 22, 1, 22, 1, 22, 1, 23, 1, 23, 1, 23, 1, 23, 1, 23, 1, 23, 1, 23, 1, 23, 1, 23, 1, 24, 1, 24, 1, 24, 1, 24, 1, 24, 1, 25, 1, 25, 1, 25, 1, 25, 1, 26, 1, 26, 1, 26, 1, 26, 1, 26, 1, 26, 1, 26, 1, 26, 1, 27, 1, 27, 1, 27, 1, 27, 1, 27, 1, 27, 1, 28, 1, 28, 1, 28, 1, 28, 1, 28, 1, 28, 1, 28, 1, 28, 1, 29, 1, 29, 1, 29, 1, 29, 1, 29, 1, 29, 1, 30, 1, 30, 1, 30, 1, 31, 1, 31, 1, 31, 1, 31, 1, 31, 1, 31, 1, 31, 1, 31, 1, 31, 1, 31, 1, 32, 1, 32, 1, 32, 1, 32, 1, 33, 1, 33, 1, 33, 1, 33, 1, 33, 1, 34, 1, 34, 1, 34, 1, 34, 1, 34, 1, 35, 1, 35, 1, 35, 1, 35, 1, 36, 1, 36, 1, 36, 1, 36, 1, 36, 1, 36, 1, 37, 1, 37, 1, 37, 1, 37, 1, 37, 1, 37, 1, 37, 1, 38, 1, 38, 1, 38, 1, 38, 1, 38, 1, 39, 1, 39, 1, 39, 1, 40, 1, 40, 1, 40, 1, 41, 1, 41, 1, 41, 1, 41, 1, 41, 1, 41, 1, 42, 1, 42, 1, 42, 1, 43, 1, 43, 1, 43, 1, 43, 1, 43, 1, 43, 1, 43, 1, 43, 1, 43, 1, 43, 1, 43, 1, 43, 1, 43, 3, 43, 647, 8, 43, 1, 44, 1, 44, 1, 44, 1, 44, 1, 44, 1, 44, 1, 45, 1, 45, 1, 45, 1, 45, 1, 45, 1, 45, 1, 45, 1, 45, 1, 45, 1, 46, 1, 46, 1, 46, 1, 47, 1, 47, 1, 47, 1, 47, 1, 47, 1, 48, 1, 48, 1, 48, 1, 48, 1, 49, 1, 49, 1, 49, 1, 49, 1, 49, 1, 50, 1, 50, 1, 50, 1, 50, 1, 50, 1, 50, 1, 50, 1, 50, 1, 51, 1, 51, 1, 51, 1, 51, 1, 51, 1, 52, 1, 52, 1, 52, 1, 52, 1, 53, 1, 53, 1, 53, 1, 53, 1, 53, 1, 54, 1, 54, 1, 54, 1, 54, 1, 54, 1, 54, 1, 55, 1, 55, 1, 55, 1, 55, 1, 55, 1, 55, 1, 55, 1, 56, 1, 56, 1, 56, 1, 56, 1, 56, 1, 56, 1, 57, 1, 57, 1, 57, 1, 57, 1, 58, 1, 58, 1, 58, 1, 58, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 60, 1, 60, 1, 60, 1, 60, 1, 60, 1, 60, 1, 61, 1, 61, 1, 61, 1, 61, 1, 61, 1, 61, 1, 61, 1, 62, 1, 62, 1, 62, 1, 63, 1, 63, 1, 63, 1, 64, 1, 64, 1, 64, 1, 64, 1, 64, 1, 64, 1, 65, 1, 65, 1, 65, 1, 65, 1, 65, 1, 65, 1, 66, 1, 66, 1, 66, 1, 66, 1, 66, 1, 67, 1, 67, 1, 67, 1, 67, 1, 67, 1, 67, 1, 67, 1, 67, 1, 67, 1, 67, 1, 68, 1, 68, 1, 68, 1, 68, 1, 68, 1, 68, 1, 68, 1, 68, 1, 68, 1, 68, 1, 69, 1, 69, 1, 69, 1, 69, 1, 69, 1, 69, 1, 69, 1, 69, 1, 69, 1, 70, 1, 70, 1, 70, 1, 70, 1, 70, 1, 70, 1, 70, 1, 70, 1, 71, 1, 71, 1, 71, 1, 71, 1, 71, 1, 71, 1, 72, 1, 72, 1, 72, 1, 72, 1, 72, 1, 72, 1, 72, 1, 73, 1, 73, 1, 73, 1, 73, 1, 73, 1, 73, 1, 74, 1, 74, 1, 74, 1, 74, 1, 74, 1, 74, 1, 74, 1, 75, 1, 75, 1, 75, 1, 75, 1, 76, 1, 76, 1, 76, 1, 76, 1, 76, 1, 77, 1, 77, 1, 77, 1, 77, 1, 77, 1, 77, 1, 77, 1, 78, 1, 78, 1, 78, 1, 78, 1, 78, 1, 78, 1, 78, 1, 79, 1, 79, 1, 79, 1, 79, 1, 79, 1, 79, 1, 79, 1, 80, 1, 80, 1, 80, 1, 80, 1, 80, 1, 81, 1, 81, 1, 81, 1, 81, 1, 81, 1, 81, 1, 81, 1, 81, 1, 81, 1, 82, 1, 82, 1, 82, 1, 82, 1, 82, 1, 82, 1, 82, 1, 82, 1, 82, 1, 82, 1, 83, 1, 83, 1, 83, 1, 83, 1, 83, 1, 84, 1, 84, 1, 84, 1, 84, 1, 84, 1, 84, 1, 85, 1, 85, 1, 85, 1, 85, 1, 85, 1, 86, 1, 86, 1, 86, 1, 86, 1, 86, 1, 86, 1, 86, 1, 86, 1, 86, 1, 86, 1, 87, 1, 87, 1, 87, 1, 88, 1, 88, 1, 88, 1, 88, 1, 89, 1, 89, 1, 89, 1, 89, 1, 89, 1, 89, 1, 89, 1, 90, 1, 90, 1, 90, 1, 90, 1, 90, 1, 90, 1, 90, 1, 90, 1, 90, 1, 91, 1, 91, 1, 91, 1, 91, 1, 91, 1, 92, 1, 92, 1, 92, 1, 92, 1, 92, 1, 92, 1, 92, 1, 92, 1, 92, 1, 93, 1, 93, 1, 93, 1, 93, 1, 94, 1, 94, 1, 94, 1, 94, 1, 94, 1, 94, 1, 94, 1, 94, 1, 94, 1, 94, 1, 95, 1, 95, 1, 95, 1, 95, 1, 95, 1, 95, 1, 96, 1, 96, 1, 96, 1, 96, 1, 96, 1, 96, 1, 97, 1, 97, 1, 97, 1, 97, 1, 97, 1, 98, 1, 98, 1, 98, 1, 98, 1, 98, 1, 99, 1, 99, 1, 99, 1, 99, 1, 99, 1, 99, 1, 100, 1, 100, 1, 100, 1, 100, 1, 100, 1, 100, 1, 101, 1, 101, 1, 101, 1, 101, 1, 101, 1, 101, 1, 101, 1, 102, 1, 102, 1, 102, 1, 102, 1, 102, 1, 103, 1, 103, 1, 103, 1, 103, 1, 103, 1, 103, 1, 103, 1, 103, 1, 103, 1, 103, 3, 103, 1021, 8, 103, 1, 104, 1, 104, 1, 104, 1, 104, 1, 104, 1, 104, 1, 104, 1, 104, 1, 104, 1, 104, 1, 104, 1, 104, 1, 104, 1, 104, 1, 104, 1, 104, 1, 104, 1, 104, 1, 104, 1, 104, 1, 104, 1, 104, 1, 104, 1, 104, 1, 104, 1, 104, 1, 104, 3, 104, 1050, 8, 104, 1, 105, 1, 105, 1, 105, 3, 105, 1055, 8, 105, 1, 105, 1, 105, 1, 105, 1, 105, 5, 105, 1061, 8, 105, 10, 105, 12, 105, 1064, 9, 105, 1, 105, 1, 105, 1, 105, 1, 105, 1, 105, 1, 105, 1, 105, 1, 105, 1, 105, 5, 105, 1075, 8, 105, 10, 105, 12, 105, 1078, 9, 105, 1, 105, 1, 105, 1, 105, 1, 105, 1, 105, 1, 105, 1, 105, 1, 105, 1, 105, 1, 105, 1, 105, 5, 105, 1091, 8, 105, 10, 105, 12, 105, 1094, 9, 105, 1, 105, 1, 105, 3, 105, 1098, 8, 105, 1, 106, 1, 106, 1, 106, 5, 106, 1103, 8, 106, 10, 106, 12, 106, 1106, 9, 106, 1, 106, 1, 106, 3, 106, 1110, 8, 106, 1, 106, 1, 106, 3, 106, 1114, 8, 106, 1, 106, 4, 106, 1117, 8, 106, 11, 106, 12, 106, 1118, 1, 106, 1, 106, 1, 106, 3, 106, 1124, 8, 106, 1, 106, 1, 106, 3, 106, 1128, 8, 106, 1, 106, 4, 106, 1131, 8, 106, 11, 106, 12, 106, 1132, 1, 106, 1, 106, 1, 106, 5, 106, 1138, 8, 106, 10, 106, 12, 106, 1141, 9, 106, 1, 106, 1, 106, 1, 106, 3, 106, 1146, 8, 106, 1, 106, 4, 106, 1149, 8, 106, 11, 106, 12, 106, 1150, 1, 106, 1, 106, 1, 106, 1, 106, 1, 106, 3, 106, 1158, 8, 106, 1, 106, 4, 106, 1161, 8, 106, 11, 106, 12, 106, 1162, 1, 106, 1, 106, 1, 106, 1, 106, 3, 106, 1169, 8, 106, 1, 106, 4, 106, 1172, 8, 106, 11, 106, 12, 106, 1173, 3, 106, 1176, 8, 106, 1, 107, 1, 107, 4, 107, 1180, 8, 107, 11, 107, 12, 107, 1181, 1, 108, 4, 108, 1185, 8, 108, 11, 108, 12, 108, 1186, 1, 109, 1, 109, 1, 109, 4, 109, 1192, 8, 109, 11, 109, 12, 109, 1193, 1, 110, 1, 110, 1, 110, 1, 110, 1, 110, 1, 110, 1, 110, 1, 110, 1, 110, 5, 110, 1205, 8, 110, 10, 110, 12, 110, 1208, 9, 110, 1, 110, 1, 110, 1, 111, 1, 111, 1, 112, 1, 112, 1, 113, 1, 113, 1, 114, 1, 114, 1, 115, 1, 115, 1, 116, 1, 116, 1, 117, 1, 117, 1, 118, 1, 118, 1, 119, 1, 119, 1, 120, 1, 120, 1, 121, 1, 121, 1, 122, 1, 122, 1, 123, 1, 123, 1, 124, 1, 124, 1, 125, 1, 125, 1, 126, 1, 126, 1, 127, 1, 127, 1, 128, 1, 128, 1, 129, 1, 129, 1, 130, 1, 130, 1, 131, 1, 131, 1, 132, 1, 132, 1, 133, 1, 133, 1, 134, 1, 134, 1, 135, 1, 135, 1, 136, 1, 136, 1, 137, 1, 137, 1, 138, 1, 138, 1, 139, 1, 139, 1, 140, 1, 140, 1, 141, 1, 141, 1, 141, 1, 142, 1, 142, 1, 143, 1, 143, 1, 144, 1, 144, 1, 145, 1, 145, 1, 146, 1, 146, 1, 147, 1, 147, 1, 147, 1, 148, 1, 148, 1, 149, 1, 149, 1, 150, 1, 150, 1, 151, 1, 151, 1, 151, 1, 152, 1, 152, 1, 153, 1, 153, 1, 153, 1, 154, 1, 154, 1, 155, 1, 155, 1, 156, 1, 156, 1, 156, 1, 157, 1, 157, 1, 157, 1, 157, 1, 158, 1, 158, 1, 158, 1, 158, 1, 159, 1, 159, 1, 160, 1, 160, 1, 161, 1, 161, 1, 161, 1, 162, 1, 162, 1, 163, 1, 163, 1, 163, 1, 163, 3, 163, 1330, 8, 163, 1, 164, 1, 164, 1, 164, 1, 164, 1, 165, 1, 165, 1, 165, 1, 166, 1, 166, 1, 166, 1, 167, 1, 167, 1, 167, 1, 168, 1, 168, 1, 169, 1, 169, 1, 170, 1, 170, 1, 171, 1, 171, 1, 172, 1, 172, 1, 172, 1, 172, 1, 172, 1, 173, 1, 173, 1, 173, 1, 173, 1, 173, 1, 174, 1, 174, 1, 175, 1, 175, 1, 176, 1, 176, 1, 176, 1, 177, 1, 177, 1, 177, 1, 177, 1, 178, 1, 178, 1, 179, 1, 179, 1, 180, 1, 180, 1, 181, 1, 181, 1, 182, 1, 182, 1, 183, 1, 183, 1, 183, 1, 183, 5, 183, 1388, 8, 183, 10, 183, 12, 183, 1391, 9, 183, 1, 183, 1, 183, 1, 183, 1, 183, 1, 183, 1, 184, 1, 184, 1, 184, 1, 184, 3, 184, 1402, 8, 184, 1, 184, 5, 184, 1405, 8, 184, 10, 184, 12, 184, 1408, 9, 184, 1, 184, 3, 184, 1411, 8, 184, 1, 184, 1, 184, 1, 185, 1, 185, 1, 185, 1, 185, 1, 186, 1, 186, 1, 186, 1, 186, 1, 186, 1, 186, 1, 186, 1, 186, 1, 186, 1, 186, 1, 186, 4, 186, 1430, 8, 186, 11, 186, 12, 186, 1431, 1, 187, 1, 187, 1, 187, 1, 187, 1, 188, 1, 188, 1, 188, 1, 188, 1, 188, 1, 189, 1, 189, 1, 189, 1, 189, 1, 189, 4, 189, 1448, 8, 189, 11, 189, 12, 189, 1449, 1, 190, 1, 190, 1, 190, 1, 190, 1, 1389, 0, 191, 3, 1, 5, 2, 7, 3, 9, 4, 11, 5, 13, 6, 15, 7, 17, 8, 19, 9, 21, 10, 23, 11, 25, 12, 27, 13, 29, 14, 31, 15, 33, 16, 35, 17, 37, 18, 39, 19, 41, 20, 43, 21, 45, 22, 47, 23, 49, 24, 51, 25, 53, 26, 55, 27, 57, 28, 59, 29, 61, 30, 63, 31, 65, 32, 67, 33, 69, 34, 71, 35, 73, 36, 75, 37, 77, 38, 79, 39, 81, 40, 83, 41, 85, 42, 87, 43, 89, 44, 91, 45, 93, 46, 95, 47, 97, 48, 99, 49, 101, 50, 103, 51, 105, 52, 107, 53, 109, 54, 111, 55, 113, 56, 115, 57, 117, 58, 119, 59, 121, 60, 123, 61, 125, 62, 127, 63, 129, 64, 131, 65, 133, 66, 135, 67, 137, 68, 139, 69, 141, 70, 143, 71, 145, 72, 147, 73, 149, 74, 151, 75, 153, 76, 155, 77, 157, 78, 159, 79, 161, 80, 163, 81, 165, 82, 167, 83, 169, 84, 171, 85, 173, 86, 175, 87, 177, 88, 179, 89, 181, 90, 183, 91, 185, 92, 187, 93, 189, 94, 191, 95, 193, 96, 195, 97, 197, 98, 199, 99, 201, 100, 203, 101, 205, 102, 207, 103, 209, 104, 211, 105, 213, 106, 215, 107, 217, 108, 219, 109, 221, 110, 223, 111, 225, 0, 227, 0, 229, 0, 231, 0, 233, 0, 235, 0, 237, 0, 239, 0, 241, 0, 243, 0, 245, 0, 247, 0, 249, 0, 251, 0, 253, 0, 255, 0, 257, 0, 259, 0, 261, 0, 263, 0, 265, 0, 267, 0, 269, 0, 271, 0, 273, 0, 275, 0, 277, 0, 279, 0, 281, 0, 283, 0, 285, 112, 287, 113, 289, 114, 291, 115, 293, 116, 295, 117, 297, 118, 299, 119, 301, 120, 303, 121, 305, 122, 307, 123, 309, 124, 311, 125, 313, 126, 315, 127, 317, 128, 319, 129, 321, 130, 323, 131, 325, 132, 327, 133, 329, 134, 331, 135, 333, 136, 335, 137, 337, 138, 339, 139, 341, 140, 343, 141, 345, 142, 347, 143, 349, 144, 351, 145, 353, 146, 355, 147, 357, 148, 359, 149, 361, 150, 363, 151, 365, 152, 367, 153, 369, 154, 371, 155, 373, 156, 375, 157, 377, 158, 379, 0, 381, 159, 383, 160, 3, 0, 1, 2, 38, 2, 0, 92, 92, 96, 96, 2, 0, 34, 34, 92, 92, 2, 0, 39, 39, 92, 92, 2, 0, 65, 65, 97, 97, 2, 0, 66, 66, 98, 98, 2, 0, 67, 67, 99, 99, 2, 0, 68, 68, 100, 100, 2, 0, 69, 69, 101, 101, 2, 0, 70, 70, 102, 102, 2, 0, 71, 71, 103, 103, 2, 0, 72, 72, 104, 104, 2, 0, 73, 73, 105, 105, 2, 0, 74, 74, 106, 106, 2, 0, 75, 75, 107, 107, 2, 0, 76, 76, 108, 108, 2, 0, 77, 77, 109, 109, 2, 0, 78, 78, 110, 110, 2, 0, 79, 79, 111, 111, 2, 0, 80, 80, 112, 112, 2, 0, 81, 81, 113, 113, 2, 0, 82, 82, 114, 114, 2, 0, 83, 83, 115, 115, 2, 0, 84, 84, 116, 116, 2, 0, 85, 85, 117, 117, 2, 0, 86, 86, 118, 118, 2, 0, 87, 87, 119, 119, 2, 0, 88, 88, 120, 120, 2, 0, 89, 89, 121, 121, 2, 0, 90, 90, 122, 122, 2, 0, 65, 90, 97, 122, 1, 0, 48, 55, 1, 0, 48, 57, 3, 0, 48, 57, 65, 70, 97, 102, 2, 0, 10, 10, 13, 13, 2, 1, 10, 10, 13, 13, 2, 0, 9, 13, 32, 32, 3, 0, 39, 39, 92, 92, 123, 123, 1, 0, 123, 123, 1491, 0, 3, 1, 0, 0, 0, 0, 5, 1, 0, 0, 0, 0, 7, 1, 0, 0, 0, 0, 9, 1, 0, 0, 0, 0, 11, 1, 0, 0, 0, 0, 13, 1, 0, 0, 0, 0, 15, 1, 0, 0, 0, 0, 17, 1, 0, 0, 0, 0, 19, 1, 0, 0, 0, 0, 21, 1, 0, 0, 0, 0, 23, 1, 0, 0, 0, 0, 25, 1, 0, 0, 0, 0, 27, 1, 0, 0, 0, 0, 29, 1, 0, 0, 0, 0, 31, 1, 0, 0, 0, 0, 33, 1, 0, 0, 0, 0, 35, 1, 0, 0, 0, 0, 37, 1, 0, 0, 0, 0, 39, 1, 0, 0, 0, 0, 41, 1, 0, 0, 0, 0, 43, 1, 0, 0, 0, 0, 45, 1, 0, 0, 0, 0, 47, 1, 0, 0, 0, 0, 49, 1, 0, 0, 0, 0, 51, 1, 0, 0, 0, 0, 53, 1, 0, 0, 0, 0, 55, 1, 0, 0, 0, 0, 57, 1, 0, 0, 0, 0, 59, 1, 0, 0, 0, 0, 61, 1, 0, 0, 0, 0, 63, 1, 0, 0, 0, 0, 65, 1, 0, 0, 0, 0, 67, 1, 0, 0, 0, 0, 69, 1, 0, 0, 0, 0, 71, 1, 0, 0, 0, 0, 73, 1, 0, 0, 0, 0, 75, 1, 0, 0, 0, 0, 77, 1, 0, 0, 0, 0, 79, 1, 0, 0, 0, 0, 81, 1, 0, 0, 0, 0, 83, 1, 0, 0, 0, 0, 85, 1, 0, 0, 0, 0, 87, 1, 0, 0, 0, 0, 89, 1, 0, 0, 0, 0, 91, 1, 0, 0, 0, 0, 93, 1, 0, 0, 0, 0, 95, 1, 0, 0, 0, 0, 97, 1, 0, 0, 0, 0, 99, 1, 0, 0, 0, 0, 101, 1, 0, 0, 0, 0, 103, 1, 0, 0, 0, 0, 105, 1, 0, 0, 0, 0, 107, 1, 0, 0, 0, 0, 109, 1, 0, 0, 0, 0, 111, 1, 0, 0, 0, 0, 113, 1, 0, 0, 0, 0, 115, 1, 0, 0, 0, 0, 117, 1, 0, 0, 0, 0, 119, 1, 0, 0, 0, 0, 121, 1, 0, 0, 0, 0, 123, 1, 0, 0, 0, 0, 125, 1, 0, 0, 0, 0, 127, 1, 0, 0, 0, 0, 129, 1, 0, 0, 0, 0, 131, 1, 0, 0, 0, 0, 133, 1, 0, 0, 0, 0, 135, 1, 0, 0, 0, 0, 137, 1, 0, 0, 0, 0, 139, 1, 0, 0, 0, 0, 141, 1, 0, 0, 0, 0, 143, 1, 0, 0, 0, 0, 145, 1, 0, 0, 0, 0, 147, 1, 0, 0, 0, 0, 149, 1, 0, 0, 0, 0, 151, 1, 0, 0, 0, 0, 153, 1, 0, 0, 0, 0, 155, 1, 0, 0, 0, 0, 157, 1, 0, 0, 0, 0, 159, 1, 0, 0, 0, 0, 161, 1, 0, 0, 0, 0, 163, 1, 0, 0, 0, 0, 165, 1, 0, 0, 0, 0, 167, 1, 0, 0, 0, 0, 169, 1, 0, 0, 0, 0, 171, 1, 0, 0, 0, 0, 173, 1, 0, 0, 0, 0, 175, 1, 0, 0, 0, 0, 177, 1, 0, 0, 0, 0, 179, 1, 0, 0, 0, 0, 181, 1, 0, 0, 0, 0, 183, 1, 0, 0, 0, 0, 185, 1, 0, 0, 0, 0, 187, 1, 0, 0, 0, 0, 189, 1, 0, 0, 0, 0, 191, 1, 0, 0, 0, 0, 193, 1, 0, 0, 0, 0, 195, 1, 0, 0, 0, 0, 197, 1, 0, 0, 0, 0, 199, 1, 0, 0, 0, 0, 201, 1, 0, 0, 0, 0, 203, 1, 0, 0, 0, 0, 205, 1, 0, 0, 0, 0, 207, 1, 0, 0, 0, 0, 209, 1, 0, 0, 0, 0, 211, 1, 0, 0, 0, 0, 213, 1, 0, 0, 0, 0, 215, 1, 0, 0, 0, 0, 217, 1, 0, 0, 0, 0, 219, 1, 0, 0, 0, 0, 221, 1, 0, 0, 0, 0, 223, 1, 0, 0, 0, 0, 285, 1, 0, 0, 0, 0, 287, 1, 0, 0, 0, 0, 289, 1, 0, 0, 0, 0, 291, 1, 0, 0, 0, 0, 293, 1, 0, 0, 0, 0, 295, 1, 0, 0, 0, 0, 297, 1, 0, 0, 0, 0, 299, 1, 0, 0, 0, 0, 301, 1, 0, 0, 0, 0, 303, 1, 0, 0, 0, 0, 305, 1, 0, 0, 0, 0, 307, 1, 0, 0, 0, 0, 309, 1, 0, 0, 0, 0, 311, 1, 0, 0, 0, 0, 313, 1, 0, 0, 0, 0, 315, 1, 0, 0, 0, 0, 317, 1, 0, 0, 0, 0, 319, 1, 0, 0, 0, 0, 321, 1, 0, 0, 0, 0, 323, 1, 0, 0, 0, 0, 325, 1, 0, 0, 0, 0, 327, 1, 0, 0, 0, 0, 329, 1, 0, 0, 0, 0, 331, 1, 0, 0, 0, 0, 333, 1, 0, 0, 0, 0, 335, 1, 0, 0, 0, 0, 337, 1, 0, 0, 0, 0, 339, 1, 0, 0, 0, 0, 341, 1, 0, 0, 0, 0, 343, 1, 0, 0, 0, 0, 345, 1, 0, 0, 0, 0, 347, 1, 0, 0, 0, 0, 349, 1, 0, 0, 0, 0, 351, 1, 0, 0, 0, 0, 353, 1, 0, 0, 0, 0, 355, 1, 0, 0, 0, 0, 357, 1, 0, 0, 0, 0, 359, 1, 0, 0, 0, 0, 361, 1, 0, 0, 0, 0, 363, 1, 0, 0, 0, 0, 365, 1, 0, 0, 0, 0, 367, 1, 0, 0, 0, 0, 369, 1, 0, 0, 0, 0, 371, 1, 0, 0, 0, 0, 373, 1, 0, 0, 0, 1, 375, 1, 0, 0, 0, 1, 377, 1, 0, 0, 0, 1, 379, 1, 0, 0, 0, 2, 381, 1, 0, 0, 0, 2, 383, 1, 0, 0, 0, 3, 385, 1, 0, 0, 0, 5, 389, 1, 0, 0, 0, 7, 393, 1, 0, 0, 0, 9, 398, 1, 0, 0, 0, 11, 402, 1, 0, 0, 0, 13, 408, 1, 0, 0, 0, 15, 425, 1, 0, 0, 0, 17, 427, 1, 0, 0, 0, 19, 432, 1, 0, 0, 0, 21, 440, 1, 0, 0, 0, 23, 445, 1, 0, 0, 0, 25, 448, 1, 0, 0, 0, 27, 453, 1, 0, 0, 0, 29, 458, 1, 0, 0, 0, 31, 464, 1, 0, 0, 0, 33, 471, 1, 0, 0, 0, 35, 479, 1, 0, 0, 0, 37, 485, 1, 0, 0, 0, 39, 490, 1, 0, 0, 0, 41, 498, 1, 0, 0, 0, 43, 503, 1, 0, 0, 0, 45, 507, 1, 0, 0, 0, 47, 512, 1, 0, 0, 0, 49, 523, 1, 0, 0, 0, 51, 532, 1, 0, 0, 0, 53, 537, 1, 0, 0, 0, 55, 541, 1, 0, 0, 0, 57, 549, 1, 0, 0, 0, 59, 555, 1, 0, 0, 0, 61, 563, 1, 0, 0, 0, 63, 569, 1, 0, 0, 0, 65, 572, 1, 0, 0, 0, 67, 582, 1, 0, 0, 0, 69, 586, 1, 0, 0, 0, 71, 591, 1, 0, 0, 0, 73, 596, 1, 0, 0, 0, 75, 600, 1, 0, 0, 0, 77, 606, 1, 0, 0, 0, 79, 613, 1, 0, 0, 0, 81, 618, 1, 0, 0, 0, 83, 621, 1, 0, 0, 0, 85, 624, 1, 0, 0, 0, 87, 630, 1, 0, 0, 0, 89, 646, 1, 0, 0, 0, 91, 648, 1, 0, 0, 0, 93, 654, 1, 0, 0, 0, 95, 663, 1, 0, 0, 0, 97, 666, 1, 0, 0, 0, 99, 671, 1, 0, 0, 0, 101, 675, 1, 0, 0, 0, 103, 680, 1, 0, 0, 0, 105, 688, 1, 0, 0, 0, 107, 693, 1, 0, 0, 0, 109, 697, 1, 0, 0, 0, 111, 702, 1, 0, 0, 0, 113, 708, 1, 0, 0, 0, 115, 715, 1, 0, 0, 0, 117, 721, 1, 0, 0, 0, 119, 725, 1, 0, 0, 0, 121, 729, 1, 0, 0, 0, 123, 734, 1, 0, 0, 0, 125, 740, 1, 0, 0, 0, 127, 747, 1, 0, 0, 0, 129, 750, 1, 0, 0, 0, 131, 753, 1, 0, 0, 0, 133, 759, 1, 0, 0, 0, 135, 765, 1, 0, 0, 0, 137, 770, 1, 0, 0, 0, 139, 780, 1, 0, 0, 0, 141, 790, 1, 0, 0, 0, 143, 799, 1, 0, 0, 0, 145, 807, 1, 0, 0, 0, 147, 813, 1, 0, 0, 0, 149, 820, 1, 0, 0, 0, 151, 826, 1, 0, 0, 0, 153, 833, 1, 0, 0, 0, 155, 837, 1, 0, 0, 0, 157, 842, 1, 0, 0, 0, 159, 849, 1, 0, 0, 0, 161, 856, 1, 0, 0, 0, 163, 863, 1, 0, 0, 0, 165, 868, 1, 0, 0, 0, 167, 877, 1, 0, 0, 0, 169, 887, 1, 0, 0, 0, 171, 892, 1, 0, 0, 0, 173, 898, 1, 0, 0, 0, 175, 903, 1, 0, 0, 0, 177, 913, 1, 0, 0, 0, 179, 916, 1, 0, 0, 0, 181, 920, 1, 0, 0, 0, 183, 927, 1, 0, 0, 0, 185, 936, 1, 0, 0, 0, 187, 941, 1, 0, 0, 0, 189, 950, 1, 0, 0, 0, 191, 954, 1, 0, 0, 0, 193, 964, 1, 0, 0, 0, 195, 970, 1, 0, 0, 0, 197, 976, 1, 0, 0, 0, 199, 981, 1, 0, 0, 0, 201, 986, 1, 0, 0, 0, 203, 992, 1, 0, 0, 0, 205, 998, 1, 0, 0, 0, 207, 1005, 1, 0, 0, 0, 209, 1020, 1, 0, 0, 0, 211, 1049, 1, 0, 0, 0, 213, 1097, 1, 0, 0, 0, 215, 1175, 1, 0, 0, 0, 217, 1177, 1, 0, 0, 0, 219, 1184, 1, 0, 0, 0, 221, 1188, 1, 0, 0, 0, 223, 1195, 1, 0, 0, 0, 225, 1211, 1, 0, 0, 0, 227, 1213, 1, 0, 0, 0, 229, 1215, 1, 0, 0, 0, 231, 1217, 1, 0, 0, 0, 233, 1219, 1, 0, 0, 0, 235, 1221, 1, 0, 0, 0, 237, 1223, 1, 0, 0, 0, 239, 1225, 1, 0, 0, 0, 241, 1227, 1, 0, 0, 0, 243, 1229, 1, 0, 0, 0, 245, 1231, 1, 0, 0, 0, 247, 1233, 1, 0, 0, 0, 249, 1235, 1, 0, 0, 0, 251, 1237, 1, 0, 0, 0, 253, 1239, 1, 0, 0, 0, 255, 1241, 1, 0, 0, 0, 257, 1243, 1, 0, 0, 0, 259, 1245, 1, 0, 0, 0, 261, 1247, 1, 0, 0, 0, 263, 1249, 1, 0, 0, 0, 265, 1251, 1, 0, 0, 0, 267, 1253, 1, 0, 0, 0, 269, 1255, 1, 0, 0, 0, 271, 1257, 1, 0, 0, 0, 273, 1259, 1, 0, 0, 0, 275, 1261, 1, 0, 0, 0, 277, 1263, 1, 0, 0, 0, 279, 1265, 1, 0, 0, 0, 281, 1267, 1, 0, 0, 0, 283, 1269, 1, 0, 0, 0, 285, 1271, 1, 0, 0, 0, 287, 1274, 1, 0, 0, 0, 289, 1276, 1, 0, 0, 0, 291, 1278, 1, 0, 0, 0, 293, 1280, 1, 0, 0, 0, 295, 1282, 1, 0, 0, 0, 297, 1284, 1, 0, 0, 0, 299, 1287, 1, 0, 0, 0, 301, 1289, 1, 0, 0, 0, 303, 1291, 1, 0, 0, 0, 305, 1293, 1, 0, 0, 0, 307, 1296, 1, 0, 0, 0, 309, 1298, 1, 0, 0, 0, 311, 1301, 1, 0, 0, 0, 313, 1303, 1, 0, 0, 0, 315, 1305, 1, 0, 0, 0, 317, 1308, 1, 0, 0, 0, 319, 1312, 1, 0, 0, 0, 321, 1316, 1, 0, 0, 0, 323, 1318, 1, 0, 0, 0, 325, 1320, 1, 0, 0, 0, 327, 1323, 1, 0, 0, 0, 329, 1329, 1, 0, 0, 0, 331, 1331, 1, 0, 0, 0, 333, 1335, 1, 0, 0, 0, 335, 1338, 1, 0, 0, 0, 337, 1341, 1, 0, 0, 0, 339, 1344, 1, 0, 0, 0, 341, 1346, 1, 0, 0, 0, 343, 1348, 1, 0, 0, 0, 345, 1350, 1, 0, 0, 0, 347, 1352, 1, 0, 0, 0, 349, 1357, 1, 0, 0, 0, 351, 1362, 1, 0, 0, 0, 353, 1364, 1, 0, 0, 0, 355, 1366, 1, 0, 0, 0, 357, 1369, 1, 0, 0, 0, 359, 1373, 1, 0, 0, 0, 361, 1375, 1, 0, 0, 0, 363, 1377, 1, 0, 0, 0, 365, 1379, 1, 0, 0, 0, 367, 1381, 1, 0, 0, 0, 369, 1383, 1, 0, 0, 0, 371, 1401, 1, 0, 0, 0, 373, 1414, 1, 0, 0, 0, 375, 1429, 1, 0, 0, 0, 377, 1433, 1, 0, 0, 0, 379, 1437, 1, 0, 0, 0, 381, 1447, 1, 0, 0, 0, 383, 1451, 1, 0, 0, 0, 385, 386, 3, 225, 111, 0, 386, 387, 3, 247, 122, 0, 387, 388, 3, 247, 122, 0, 388, 4, 1, 0, 0, 0, 389, 390, 3, 225, 111, 0, 390, 391, 3, 251, 124, 0, 391, 392, 3, 231, 114, 0, 392, 6, 1, 0, 0, 0, 393, 394, 3, 225, 111, 0, 394, 395, 3, 251, 124, 0, 395, 396, 3, 263, 130, 0, 396, 397, 3, 241, 119, 0, 397, 8, 1, 0, 0, 0, 398, 399, 3, 225, 111, 0, 399, 400, 3, 251, 124, 0, 400, 401, 3, 273, 135, 0, 401, 10, 1, 0, 0, 0, 402, 403, 3, 225, 111, 0, 403, 404, 3, 259, 128, 0, 404, 405, 3, 259, 128, 0, 405, 406, 3, 225, 111, 0, 406, 407, 3, 273, 135, 0, 407, 12, 1, 0, 0, 0, 408, 409, 3, 225, 111, 0, 409, 410, 3, 261, 129, 0, 410, 14, 1, 0, 0, 0, 411, 412, 3, 225, 111, 0, 412, 413, 3, 261, 129, 0, 413, 414, 3, 229, 113, 0, 414, 426, 1, 0, 0, 0, 415, 416, 3, 225, 111, 0, 416, 417, 3, 261, 129, 0, 417, 418, 3, 229, 113, 0, 418, 419, 3, 233, 115, 0, 419, 420, 3, 251, 124, 0, 420, 421, 3, 231, 114, 0, 421, 422, 3, 241, 119, 0, 422, 423, 3, 251, 124, 0, 423, 424, 3, 237, 117, 0, 424, 426, 1, 0, 0, 0, 425, 411, 1, 0, 0, 0, 425, 415, 1, 0, 0, 0, 426, 16, 1, 0, 0, 0, 427, 428, 3, 225, 111, 0, 428, 429, 3, 261, 129, 0, 429, 430, 3, 253, 125, 0, 430, 431, 3, 235, 116, 0, 431, 18, 1, 0, 0, 0, 432, 433, 3, 227, 112, 0, 433, 434, 3, 233, 115, 0, 434, 435, 3, 263, 130, 0, 435, 436, 3, 269, 133, 0, 436, 437, 3, 233, 115, 0, 437, 438, 3, 233, 115, 0, 438, 439, 3, 251, 124, 0, 439, 20, 1, 0, 0, 0, 440, 441, 3, 227, 112, 0, 441, 442, 3, 253, 125, 0, 442, 443, 3, 263, 130, 0, 443, 444, 3, 239, 118, 0, 444, 22, 1, 0, 0, 0, 445, 446, 3, 227, 112, 0, 446, 447, 3, 273, 135, 0, 447, 24, 1, 0, 0, 0, 448, 449, 3, 229, 113, 0, 449, 450, 3, 225, 111, 0, 450, 451, 3, 261, 129, 0, 451, 452, 3, 233, 115, 0, 452, 26, 1, 0, 0, 0, 453, 454, 3, 229, 113, 0, 454, 455, 3, 225, 111, 0, 455, 456, 3, 261, 129, 0, 456, 457, 3, 263, 130, 0, 457, 28, 1, 0, 0, 0, 458, 459, 3, 229, 113, 0, 459, 460, 3, 225, 111, 0, 460, 461, 3, 263, 130, 0, 461, 462, 3, 229, 113, 0, 462, 463, 3, 239, 118, 0, 463, 30, 1, 0, 0, 0, 464, 465, 3, 229, 113, 0, 465, 466, 3, 253, 125, 0, 466, 467, 3, 239, 118, 0, 467, 468, 3, 253, 125, 0, 468, 469, 3, 259, 128, 0, 469, 470, 3, 263, 130, 0, 470, 32, 1, 0, 0, 0, 471, 472, 3, 229, 113, 0, 472, 473, 3, 253, 125, 0, 473, 474, 3, 247, 122, 0, 474, 475, 3, 247, 122, 0, 475, 476, 3, 225, 111, 0, 476, 477, 3, 263, 130, 0, 477, 478, 3, 233, 115, 0, 478, 34, 1, 0, 0, 0, 479, 480, 3, 229, 113, 0, 480, 481, 3, 259, 128, 0, 481, 482, 3, 253, 125, 0, 482, 483, 3, 261, 129, 0, 483, 484, 3, 261, 129, 0, 484, 36, 1, 0, 0, 0, 485, 486, 3, 229, 113, 0, 486, 487, 3, 265, 131, 0, 487, 488, 3, 227, 112, 0, 488, 489, 3, 233, 115, 0, 489, 38, 1, 0, 0, 0, 490, 491, 3, 229, 113, 0, 491, 492, 3, 265, 131, 0, 492, 493, 3, 259, 128, 0, 493, 494, 3, 259, 128, 0, 494, 495, 3, 233, 115, 0, 495, 496, 3, 251, 124, 0, 496, 497, 3, 263, 130, 0, 497, 40, 1, 0, 0, 0, 498, 499, 3, 231, 114, 0, 499, 500, 3, 225, 111, 0, 500, 501, 3, 263, 130, 0, 501, 502, 3, 233, 115, 0, 502, 42, 1, 0, 0, 0, 503, 504, 3, 231, 114, 0, 504, 505, 3, 225, 111, 0, 505, 506, 3, 273, 135, 0, 506, 44, 1, 0, 0, 0, 507, 508, 3, 231, 114, 0, 508, 509, 3, 233, 115, 0, 509, 510, 3, 261, 129, 0, 510, 511, 3, 229, 113, 0, 511, 46, 1, 0, 0, 0, 512, 513, 3, 231, 114, 0, 513, 514, 3, 233, 115, 0, 514, 515, 3, 261, 129, 0, 515, 516, 3, 229, 113, 0, 516, 517, 3, 233, 115, 0, 517, 518, 3, 251, 124, 0, 518, 519, 3, 231, 114, 0, 519, 520, 3, 241, 119, 0, 520, 521, 3, 251, 124, 0, 521, 522, 3, 237, 117, 0, 522, 48, 1, 0, 0, 0, 523, 524, 3, 231, 114, 0, 524, 525, 3, 241, 119, 0, 525, 526, 3, 261, 129, 0, 526, 527, 3, 263, 130, 0, 527, 528, 3, 241, 119, 0, 528, 529, 3, 251, 124, 0, 529, 530, 3, 229, 113, 0, 530, 531, 3, 263, 130, 0, 531, 50, 1, 0, 0, 0, 532, 533, 3, 233, 115, 0, 533, 534, 3, 247, 122, 0, 534, 535, 3, 261, 129, 0, 535, 536, 3, 233, 115, 0, 536, 52, 1, 0, 0, 0, 537, 538, 3, 233, 115, 0, 538, 539, 3, 251, 124, 0, 539, 540, 3, 231, 114, 0, 540, 54, 1, 0, 0, 0, 541, 542, 3, 233, 115, 0, 542, 543, 3, 271, 134, 0, 543, 544, 3, 263, 130, 0, 544, 545, 3, 259, 128, 0, 545, 546, 3, 225, 111, 0, 546, 547, 3, 229, 113, 0, 547, 548, 3, 263, 130, 0, 548, 56, 1, 0, 0, 0, 549, 550, 3, 235, 116, 0, 550, 551, 3, 241, 119, 0, 551, 552, 3, 251, 124, 0, 552, 553, 3, 225, 111, 0, 553, 554, 3, 247, 122, 0, 554, 58, 1, 0, 0, 0, 555, 556, 3, 235, 116, 0, 556, 557, 3, 241, 119, 0, 557, 558, 3, 251, 124, 0, 558, 559, 3, 225, 111, 0, 559, 560, 3, 247, 122, 0, 560, 561, 3, 247, 122, 0, 561, 562, 3, 273, 135, 0, 562, 60, 1, 0, 0, 0, 563, 564, 3, 235, 116, 0, 564, 565, 3, 241, 119, 0, 565, 566, 3, 259, 128, 0, 566, 567, 3, 261, 129, 0, 567, 568, 3, 263, 130, 0, 568, 62, 1, 0, 0, 0, 569, 570, 3, 235, 116, 0, 570, 571, 3, 251, 124, 0, 571, 64, 1, 0, 0, 0, 572, 573, 3, 235, 116, 0, 573, 574, 3, 253, 125, 0, 574, 575, 3, 247, 122, 0, 575, 576, 3, 247, 122, 0, 576, 577, 3, 253, 125, 0, 577, 578, 3, 269, 133, 0, 578, 579, 3, 241, 119, 0, 579, 580, 3, 251, 124, 0, 580, 581, 3, 237, 117, 0, 581, 66, 1, 0, 0, 0, 582, 583, 3, 235, 116, 0, 583, 584, 3, 253, 125, 0, 584, 585, 3, 259, 128, 0, 585, 68, 1, 0, 0, 0, 586, 587, 3, 235, 116, 0, 587, 588, 3, 259, 128, 0, 588, 589, 3, 253, 125, 0, 589, 590, 3, 249, 123, 0, 590, 70, 1, 0, 0, 0, 591, 592, 3, 235, 116, 0, 592, 593, 3, 265, 131, 0, 593, 594, 3, 247, 122, 0, 594, 595, 3, 247, 122, 0, 595, 72, 1, 0, 0, 0, 596, 597, 3, 235, 116, 0, 597, 598, 3, 265, 131, 0, 598, 599, 3, 251, 124, 0, 599, 74, 1, 0, 0, 0, 600, 601, 3, 237, 117, 0, 601, 602, 3, 259, 128, 0, 602, 603, 3, 253, 125, 0, 603, 604, 3, 265, 131, 0, 604, 605, 3, 255, 126, 0, 605, 76, 1, 0, 0, 0, 606, 607, 3, 239, 118, 0, 607, 608, 3, 225, 111, 0, 608, 609, 3, 267, 132, 0, 609, 610, 3, 241, 119, 0, 610, 611, 3, 251, 124, 0, 611, 612, 3, 237, 117, 0, 612, 78, 1, 0, 0, 0, 613, 614, 3, 239, 118, 0, 614, 615, 3, 253, 125, 0, 615, 616, 3, 265, 131, 0, 616, 617, 3, 259, 128, 0, 617, 80, 1, 0, 0, 0, 618, 619, 3, 241, 119, 0, 619, 620, 3, 231, 114, 0, 620, 82, 1, 0, 0, 0, 621, 622, 3, 241, 119, 0, 622, 623, 3, 235, 116, 0, 623, 84, 1, 0, 0, 0, 624, 625, 3, 241, 119, 0, 625, 626, 3, 247, 122, 0, 626, 627, 3, 241, 119, 0, 627, 628, 3, 245, 121, 0, 628, 629, 3, 233, 115, 0, 629, 86, 1, 0, 0, 0, 630, 631, 3, 241, 119, 0, 631, 632, 3, 251, 124, 0, 632, 88, 1, 0, 0, 0, 633, 634, 3, 241, 119, 0, 634, 635, 3, 251, 124, 0, 635, 636, 3, 235, 116, 0, 636, 647, 1, 0, 0, 0, 637, 638, 3, 241, 119, 0, 638, 639, 3, 251, 124, 0, 639, 640, 3, 235, 116, 0, 640, 641, 3, 241, 119, 0, 641, 642, 3, 251, 124, 0, 642, 643, 3, 241, 119, 0, 643, 644, 3, 263, 130, 0, 644, 645, 3, 273, 135, 0, 645, 647, 1, 0, 0, 0, 646, 633, 1, 0, 0, 0, 646, 637, 1, 0, 0, 0, 647, 90, 1, 0, 0, 0, 648, 649, 3, 241, 119, 0, 649, 650, 3, 251, 124, 0, 650, 651, 3, 251, 124, 0, 651, 652, 3, 233, 115, 0, 652, 653, 3, 259, 128, 0, 653, 92, 1, 0, 0, 0, 654, 655, 3, 241, 119, 0, 655, 656, 3, 251, 124, 0, 656, 657, 3, 263, 130, 0, 657, 658, 3, 233, 115, 0, 658, 659, 3, 259, 128, 0, 659, 660, 3, 267, 132, 0, 660, 661, 3, 225, 111, 0, 661, 662, 3, 247, 122, 0, 662, 94, 1, 0, 0, 0, 663, 664, 3, 241, 119, 0, 664, 665, 3, 261, 129, 0, 665, 96, 1, 0, 0, 0, 666, 667, 3, 243, 120, 0, 667, 668, 3, 253, 125, 0, 668, 669, 3, 241, 119, 0, 669, 670, 3, 251, 124, 0, 670, 98, 1, 0, 0, 0, 671, 672, 3, 245, 121, 0, 672, 673, 3, 233, 115, 0, 673, 674, 3, 273, 135, 0, 674, 100, 1, 0, 0, 0, 675, 676, 3, 247, 122, 0, 676, 677, 3, 225, 111, 0, 677, 678, 3, 261, 129, 0, 678, 679, 3, 263, 130, 0, 679, 102, 1, 0, 0, 0, 680, 681, 3, 247, 122, 0, 681, 682, 3, 233, 115, 0, 682, 683, 3, 225, 111, 0, 683, 684, 3, 231, 114, 0, 684, 685, 3, 241, 119, 0, 685, 686, 3, 251, 124, 0, 686, 687, 3, 237, 117, 0, 687, 104, 1, 0, 0, 0, 688, 689, 3, 247, 122, 0, 689, 690, 3, 233, 115, 0, 690, 691, 3, 235, 116, 0, 691, 692, 3, 263, 130, 0, 692, 106, 1, 0, 0, 0, 693, 694, 3, 247, 122, 0, 694, 695, 3, 233, 115, 0, 695, 696, 3, 263, 130, 0, 696, 108, 1, 0, 0, 0, 697, 698, 3, 247, 122, 0, 698, 699, 3, 241, 119, 0, 699, 700, 3, 245, 121, 0, 700, 701, 3, 233, 115, 0, 701, 110, 1, 0, 0, 0, 702, 703, 3, 247, 122, 0, 703, 704, 3, 241, 119, 0, 704, 705, 3, 249, 123, 0, 705, 706, 3, 241, 119, 0, 706, 707, 3, 263, 130, 0, 707, 112, 1, 0, 0, 0, 708, 709, 3, 249, 123, 0, 709, 710, 3, 241, 119, 0, 710, 711, 3, 251, 124, 0, 711, 712, 3, 265, 131, 0, 712, 713, 3, 263, 130, 0, 713, 714, 3, 233, 115, 0, 714, 114, 1, 0, 0, 0, 715, 716, 3, 249, 123, 0, 716, 717, 3, 253, 125, 0, 717, 718, 3, 251, 124, 0, 718, 719, 3, 263, 130, 0, 719, 720, 3, 239, 118, 0, 720, 116, 1, 0, 0, 0, 721, 722, 3, 251, 124, 0, 722, 723, 3, 225, 111, 0, 723, 724, 3, 251, 124, 0, 724, 118, 1, 0, 0, 0, 725, 726, 3, 251, 124, 0, 726, 727, 3, 253, 125, 0, 727, 728, 3, 263, 130, 0, 728, 120, 1, 0, 0, 0, 729, 730, 3, 251, 124, 0, 730, 731, 3, 265, 131, 0, 731, 732, 3, 247, 122, 0, 732, 733, 3, 247, 122, 0, 733, 122, 1, 0, 0, 0, 734, 735, 3, 251, 124, 0, 735, 736, 3, 265, 131, 0, 736, 737, 3, 247, 122, 0, 737, 738, 3, 247, 122, 0, 738, 739, 3, 261, 129, 0, 739, 124, 1, 0, 0, 0, 740, 741, 3, 253, 125, 0, 741, 742, 3, 235, 116, 0, 742, 743, 3, 235, 116, 0, 743, 744, 3, 261, 129, 0, 744, 745, 3, 233, 115, 0, 745, 746, 3, 263, 130, 0, 746, 126, 1, 0, 0, 0, 747, 748, 3, 253, 125, 0, 748, 749, 3, 251, 124, 0, 749, 128, 1, 0, 0, 0, 750, 751, 3, 253, 125, 0, 751, 752, 3, 259, 128, 0, 752, 130, 1, 0, 0, 0, 753, 754, 3, 253, 125, 0, 754, 755, 3, 259, 128, 0, 755, 756, 3, 231, 114, 0, 756, 757, 3, 233, 115, 0, 757, 758, 3, 259, 128, 0, 758, 132, 1, 0, 0, 0, 759, 760, 3, 253, 125, 0, 760, 761, 3, 265, 131, 0, 761, 762, 3, 263, 130, 0, 762, 763, 3, 233, 115, 0, 763, 764, 3, 259, 128, 0, 764, 134, 1, 0, 0, 0, 765, 766, 3, 253, 125, 0, 766, 767, 3, 267, 132, 0, 767, 768, 3, 233, 115, 0, 768, 769, 3, 259, 128, 0, 769, 136, 1, 0, 0, 0, 770, 771, 3, 255, 126, 0, 771, 772, 3, 225, 111, 0, 772, 773, 3, 259, 128, 0, 773, 774, 3, 263, 130, 0, 774, 775, 3, 241, 119, 0, 775, 776, 3, 263, 130, 0, 776, 777, 3, 241, 119, 0, 777, 778, 3, 253, 125, 0, 778, 779, 3, 251, 124, 0, 779, 138, 1, 0, 0, 0, 780, 781, 3, 255, 126, 0, 781, 782, 3, 259, 128, 0, 782, 783, 3, 233, 115, 0, 783, 784, 3, 229, 113, 0, 784, 785, 3, 233, 115, 0, 785, 786, 3, 231, 114, 0, 786, 787, 3, 241, 119, 0, 787, 788, 3, 251, 124, 0, 788, 789, 3, 237, 117, 0, 789, 140, 1, 0, 0, 0, 790, 791, 3, 255, 126, 0, 791, 792, 3, 259, 128, 0, 792, 793, 3, 233, 115, 0, 793, 794, 3, 269, 133, 0, 794, 795, 3, 239, 118, 0, 795, 796, 3, 233, 115, 0, 796, 797, 3, 259, 128, 0, 797, 798, 3, 233, 115, 0, 798, 142, 1, 0, 0, 0, 799, 800, 3, 257, 127, 0, 800, 801, 3, 265, 131, 0, 801, 802, 3, 225, 111, 0, 802, 803, 3, 259, 128, 0, 803, 804, 3, 263, 130, 0, 804, 805, 3, 233, 115, 0, 805, 806, 3, 259, 128, 0, 806, 144, 1, 0, 0, 0, 807, 808, 3, 259, 128, 0, 808, 809, 3, 225, 111, 0, 809, 810, 3, 251, 124, 0, 810, 811, 3, 237, 117, 0, 811, 812, 3, 233, 115, 0, 812, 146, 1, 0, 0, 0, 813, 814, 3, 259, 128, 0, 814, 815, 3, 233, 115, 0, 815, 816, 3, 263, 130, 0, 816, 817, 3, 265, 131, 0, 817, 818, 3, 259, 128, 0, 818, 819, 3, 251, 124, 0, 819, 148, 1, 0, 0, 0, 820, 821, 3, 259, 128, 0, 821, 822, 3, 241, 119, 0, 822, 823, 3, 237, 117, 0, 823, 824, 3, 239, 118, 0, 824, 825, 3, 263, 130, 0, 825, 150, 1, 0, 0, 0, 826, 827, 3, 259, 128, 0, 827, 828, 3, 253, 125, 0, 828, 829, 3, 247, 122, 0, 829, 830, 3, 247, 122, 0, 830, 831, 3, 265, 131, 0, 831, 832, 3, 255, 126, 0, 832, 152, 1, 0, 0, 0, 833, 834, 3, 259, 128, 0, 834, 835, 3, 253, 125, 0, 835, 836, 3, 269, 133, 0, 836, 154, 1, 0, 0, 0, 837, 838, 3, 259, 128, 0, 838, 839, 3, 253, 125, 0, 839, 840, 3, 269, 133, 0, 840, 841, 3, 261, 129, 0, 841, 156, 1, 0, 0, 0, 842, 843, 3, 261, 129, 0, 843, 844, 3, 225, 111, 0, 844, 845, 3, 249, 123, 0, 845, 846, 3, 255, 126, 0, 846, 847, 3, 247, 122, 0, 847, 848, 3, 233, 115, 0, 848, 158, 1, 0, 0, 0, 849, 850, 3, 261, 129, 0, 850, 851, 3, 233, 115, 0, 851, 852, 3, 229, 113, 0, 852, 853, 3, 253, 125, 0, 853, 854, 3, 251, 124, 0, 854, 855, 3, 231, 114, 0, 855, 160, 1, 0, 0, 0, 856, 857, 3, 261, 129, 0, 857, 858, 3, 233, 115, 0, 858, 859, 3, 247, 122, 0, 859, 860, 3, 233, 115, 0, 860, 861, 3, 229, 113, 0, 861, 862, 3, 263, 130, 0, 862, 162, 1, 0, 0, 0, 863, 864, 3, 261, 129, 0, 864, 865, 3, 233, 115, 0, 865, 866, 3, 249, 123, 0, 866, 867, 3, 241, 119, 0, 867, 164, 1, 0, 0, 0, 868, 869, 3, 261, 129, 0, 869, 870, 3, 233, 115, 0, 870, 871, 3, 263, 130, 0, 871, 872, 3, 263, 130, 0, 872, 873, 3, 241, 119, 0, 873, 874, 3, 251, 124, 0, 874, 875, 3, 237, 117, 0, 875, 876, 3, 261, 129, 0, 876, 166, 1, 0, 0, 0, 877, 878, 3, 261, 129, 0, 878, 879, 3, 265, 131, 0, 879, 880, 3, 227, 112, 0, 880, 881, 3, 261, 129, 0, 881, 882, 3, 263, 130, 0, 882, 883, 3, 259, 128, 0, 883, 884, 3, 241, 119, 0, 884, 885, 3, 251, 124, 0, 885, 886, 3, 237, 117, 0, 886, 168, 1, 0, 0, 0, 887, 888, 3, 263, 130, 0, 888, 889, 3, 239, 118, 0, 889, 890, 3, 233, 115, 0, 890, 891, 3, 251, 124, 0, 891, 170, 1, 0, 0, 0, 892, 893, 3, 263, 130, 0, 893, 894, 3, 239, 118, 0, 894, 895, 3, 259, 128, 0, 895, 896, 3, 253, 125, 0, 896, 897, 3, 269, 133, 0, 897, 172, 1, 0, 0, 0, 898, 899, 3, 263, 130, 0, 899, 900, 3, 241, 119, 0, 900, 901, 3, 233, 115, 0, 901, 902, 3, 261, 129, 0, 902, 174, 1, 0, 0, 0, 903, 904, 3, 263, 130, 0, 904, 905, 3, 241, 119, 0, 905, 906, 3, 249, 123, 0, 906, 907, 3, 233, 115, 0, 907, 908, 3, 261, 129, 0, 908, 909, 3, 263, 130, 0, 909, 910, 3, 225, 111, 0, 910, 911, 3, 249, 123, 0, 911, 912, 3, 255, 126, 0, 912, 176, 1, 0, 0, 0, 913, 914, 3, 263, 130, 0, 914, 915, 3, 253, 125, 0, 915, 178, 1, 0, 0, 0, 916, 917, 3, 263, 130, 0, 917, 918, 3, 253, 125, 0, 918, 919, 3, 255, 126, 0, 919, 180, 1, 0, 0, 0, 920, 921, 3, 263, 130, 0, 921, 922, 3, 253, 125, 0, 922, 923, 3, 263, 130, 0, 923, 924, 3, 225, 111, 0, 924, 925, 3, 247, 122, 0, 925, 926, 3, 261, 129, 0, 926, 182, 1, 0, 0, 0, 927, 928, 3, 263, 130, 0, 928, 929, 3, 259, 128, 0, 929, 930, 3, 225, 111, 0, 930, 931, 3, 241, 119, 0, 931, 932, 3, 247, 122, 0, 932, 933, 3, 241, 119, 0, 933, 934, 3, 251, 124, 0, 934, 935, 3, 237, 117, 0, 935, 184, 1, 0, 0, 0, 936, 937, 3, 263, 130, 0, 937, 938, 3, 259, 128, 0, 938, 939, 3, 241, 119, 0, 939, 940, 3, 249, 123, 0, 940, 186, 1, 0, 0, 0, 941, 942, 3, 263, 130, 0, 942, 943, 3, 259, 128, 0, 943, 944, 3, 265, 131, 0, 944, 945, 3, 251, 124, 0, 945, 946, 3, 229, 113, 0, 946, 947, 3, 225, 111, 0, 947, 948, 3, 263, 130, 0, 948, 949, 3, 233, 115, 0, 949, 188, 1, 0, 0, 0, 950, 951, 3, 263, 130, 0, 951, 952, 3, 259, 128, 0, 952, 953, 3, 273, 135, 0, 953, 190, 1, 0, 0, 0, 954, 955, 3, 265, 131, 0, 955, 956, 3, 251, 124, 0, 956, 957, 3, 227, 112, 0, 957, 958, 3, 253, 125, 0, 958, 959, 3, 265, 131, 0, 959, 960, 3, 251, 124, 0, 960, 961, 3, 231, 114, 0, 961, 962, 3, 233, 115, 0, 962, 963, 3, 231, 114, 0, 963, 192, 1, 0, 0, 0, 964, 965, 3, 265, 131, 0, 965, 966, 3, 251, 124, 0, 966, 967, 3, 241, 119, 0, 967, 968, 3, 253, 125, 0, 968, 969, 3, 251, 124, 0, 969, 194, 1, 0, 0, 0, 970, 971, 3, 265, 131, 0, 971, 972, 3, 261, 129, 0, 972, 973, 3, 241, 119, 0, 973, 974, 3, 251, 124, 0, 974, 975, 3, 237, 117, 0, 975, 196, 1, 0, 0, 0, 976, 977, 3, 269, 133, 0, 977, 978, 3, 233, 115, 0, 978, 979, 3, 233, 115, 0, 979, 980, 3, 245, 121, 0, 980, 198, 1, 0, 0, 0, 981, 982, 3, 269, 133, 0, 982, 983, 3, 239, 118, 0, 983, 984, 3, 233, 115, 0, 984, 985, 3, 251, 124, 0, 985, 200, 1, 0, 0, 0, 986, 987, 3, 269, 133, 0, 987, 988, 3, 239, 118, 0, 988, 989, 3, 233, 115, 0, 989, 990, 3, 259, 128, 0, 990, 991, 3, 233, 115, 0, 991, 202, 1, 0, 0, 0, 992, 993, 3, 269, 133, 0, 993, 994, 3, 239, 118, 0, 994, 995, 3, 241, 119, 0, 995, 996, 3, 247, 122, 0, 996, 997, 3, 233, 115, 0, 997, 204, 1, 0, 0, 0, 998, 999, 3, 269, 133, 0, 999, 1000, 3, 241, 119, 0, 1000, 1001, 3, 251, 124, 0, 1001, 1002, 3, 231, 114, 0, 1002, 1003, 3, 253, 125, 0, 1003, 1004, 3, 269, 133, 0, 1004, 206, 1, 0, 0, 0, 1005, 1006, 3, 269, 133, 0, 1006, 1007, 3, 241, 119, 0, 1007, 1008, 3, 263, 130, 0, 1008, 1009, 3, 239, 118, 0, 1009, 208, 1, 0, 0, 0, 1010, 1011, 3, 273, 135, 0, 1011, 1012, 3, 233, 115, 0, 1012, 1013, 3, 225, 111, 0, 1013, 1014, 3, 259, 128, 0, 1014, 1021, 1, 0, 0, 0, 1015, 1016, 3, 273, 135, 0, 1016, 1017, 3, 273, 135, 0, 1017, 1018, 3, 273, 135, 0, 1018, 1019, 3, 273, 135, 0, 1019, 1021, 1, 0, 0, 0, 1020, 1010, 1, 0, 0, 0, 1020, 1015, 1, 0, 0, 0, 1021, 210, 1, 0, 0, 0, 1022, 1023, 3, 291, 144, 0, 1023, 1024, 3, 227, 112, 0, 1024, 1050, 1, 0, 0, 0, 1025, 1026, 3, 291, 144, 0, 1026, 1027, 3, 235, 116, 0, 1027, 1050, 1, 0, 0, 0, 1028, 1029, 3, 291, 144, 0, 1029, 1030, 3, 259, 128, 0, 1030, 1050, 1, 0, 0, 0, 1031, 1032, 3, 291, 144, 0, 1032, 1033, 3, 251, 124, 0, 1033, 1050, 1, 0, 0, 0, 1034, 1035, 3, 291, 144, 0, 1035, 1036, 3, 263, 130, 0, 1036, 1050, 1, 0, 0, 0, 1037, 1038, 3, 291, 144, 0, 1038, 1039, 5, 48, 0, 0, 1039, 1050, 1, 0, 0, 0, 1040, 1041, 3, 291, 144, 0, 1041, 1042, 3, 225, 111, 0, 1042, 1050, 1, 0, 0, 0, 1043, 1044, 3, 291, 144, 0, 1044, 1045, 3, 267, 132, 0, 1045, 1050, 1, 0, 0, 0, 1046, 1047, 3, 291, 144, 0, 1047, 1048, 3, 291, 144, 0, 1048, 1050, 1, 0, 0, 0, 1049, 1022, 1, 0, 0, 0, 1049, 1025, 1, 0, 0, 0, 1049, 1028, 1, 0, 0, 0, 1049, 1031, 1, 0, 0, 0, 1049, 1034, 1, 0, 0, 0, 1049, 1037, 1, 0, 0, 0, 1049, 1040, 1, 0, 0, 0, 1049, 1043, 1, 0, 0, 0, 1049, 1046, 1, 0, 0, 0, 1050, 212, 1, 0, 0, 0, 1051, 1055, 3, 277, 137, 0, 1052, 1055, 3, 367, 182, 0, 1053, 1055, 3, 301, 149, 0, 1054, 1051, 1, 0, 0, 0, 1054, 1052, 1, 0, 0, 0, 1054, 1053, 1, 0, 0, 0, 1055, 1062, 1, 0, 0, 0, 1056, 1061, 3, 277, 137, 0, 1057, 1061, 3, 367, 182, 0, 1058, 1061, 3, 281, 139, 0, 1059, 1061, 3, 301, 149, 0, 1060, 1056, 1, 0, 0, 0, 1060, 1057, 1, 0, 0, 0, 1060, 1058, 1, 0, 0, 0, 1060, 1059, 1, 0, 0, 0, 1061, 1064, 1, 0, 0, 0, 1062, 1060, 1, 0, 0, 0, 1062, 1063, 1, 0, 0, 0, 1063, 1098, 1, 0, 0, 0, 1064, 1062, 1, 0, 0, 0, 1065, 1076, 3, 289, 143, 0, 1066, 1075, 8, 0, 0, 0, 1067, 1075, 3, 211, 104, 0, 1068, 1069, 3, 291, 144, 0, 1069, 1070, 3, 351, 174, 0, 1070, 1075, 1, 0, 0, 0, 1071, 1072, 3, 289, 143, 0, 1072, 1073, 3, 289, 143, 0, 1073, 1075, 1, 0, 0, 0, 1074, 1066, 1, 0, 0, 0, 1074, 1067, 1, 0, 0, 0, 1074, 1068, 1, 0, 0, 0, 1074, 1071, 1, 0, 0, 0, 1075, 1078, 1, 0, 0, 0, 1076, 1074, 1, 0, 0, 0, 1076, 1077, 1, 0, 0, 0, 1077, 1079, 1, 0, 0, 0, 1078, 1076, 1, 0, 0, 0, 1079, 1080, 3, 289, 143, 0, 1080, 1098, 1, 0, 0, 0, 1081, 1092, 3, 345, 171, 0, 1082, 1091, 8, 1, 0, 0, 1083, 1091, 3, 211, 104, 0, 1084, 1085, 3, 291, 144, 0, 1085, 1086, 3, 345, 171, 0, 1086, 1091, 1, 0, 0, 0, 1087, 1088, 3, 345, 171, 0, 1088, 1089, 3, 345, 171, 0, 1089, 1091, 1, 0, 0, 0, 1090, 1082, 1, 0, 0, 0, 1090, 1083, 1, 0, 0, 0, 1090, 1084, 1, 0, 0, 0, 1090, 1087, 1, 0, 0, 0, 1091, 1094, 1, 0, 0, 0, 1092, 1090, 1, 0, 0, 0, 1092, 1093, 1, 0, 0, 0, 1093, 1095, 1, 0, 0, 0, 1094, 1092, 1, 0, 0, 0, 1095, 1096, 3, 345, 171, 0, 1096, 1098, 1, 0, 0, 0, 1097, 1054, 1, 0, 0, 0, 1097, 1065, 1, 0, 0, 0, 1097, 1081, 1, 0, 0, 0, 1098, 214, 1, 0, 0, 0, 1099, 1100, 3, 221, 109, 0, 1100, 1104, 3, 303, 150, 0, 1101, 1103, 3, 283, 140, 0, 1102, 1101, 1, 0, 0, 0, 1103, 1106, 1, 0, 0, 0, 1104, 1102, 1, 0, 0, 0, 1104, 1105, 1, 0, 0, 0, 1105, 1109, 1, 0, 0, 0, 1106, 1104, 1, 0, 0, 0, 1107, 1110, 3, 255, 126, 0, 1108, 1110, 3, 233, 115, 0, 1109, 1107, 1, 0, 0, 0, 1109, 1108, 1, 0, 0, 0, 1110, 1113, 1, 0, 0, 0, 1111, 1114, 3, 341, 169, 0, 1112, 1114, 3, 299, 148, 0, 1113, 1111, 1, 0, 0, 0, 1113, 1112, 1, 0, 0, 0, 1113, 1114, 1, 0, 0, 0, 1114, 1116, 1, 0, 0, 0, 1115, 1117, 3, 281, 139, 0, 1116, 1115, 1, 0, 0, 0, 1117, 1118, 1, 0, 0, 0, 1118, 1116, 1, 0, 0, 0, 1118, 1119, 1, 0, 0, 0, 1119, 1176, 1, 0, 0, 0, 1120, 1123, 3, 221, 109, 0, 1121, 1124, 3, 255, 126, 0, 1122, 1124, 3, 233, 115, 0, 1123, 1121, 1, 0, 0, 0, 1123, 1122, 1, 0, 0, 0, 1124, 1127, 1, 0, 0, 0, 1125, 1128, 3, 341, 169, 0, 1126, 1128, 3, 299, 148, 0, 1127, 1125, 1, 0, 0, 0, 1127, 1126, 1, 0, 0, 0, 1127, 1128, 1, 0, 0, 0, 1128, 1130, 1, 0, 0, 0, 1129, 1131, 3, 281, 139, 0, 1130, 1129, 1, 0, 0, 0, 1131, 1132, 1, 0, 0, 0, 1132, 1130, 1, 0, 0, 0, 1132, 1133, 1, 0, 0, 0, 1133, 1176, 1, 0, 0, 0, 1134, 1135, 3, 219, 108, 0, 1135, 1139, 3, 303, 150, 0, 1136, 1138, 3, 281, 139, 0, 1137, 1136, 1, 0, 0, 0, 1138, 1141, 1, 0, 0, 0, 1139, 1137, 1, 0, 0, 0, 1139, 1140, 1, 0, 0, 0, 1140, 1142, 1, 0, 0, 0, 1141, 1139, 1, 0, 0, 0, 1142, 1145, 3, 233, 115, 0, 1143, 1146, 3, 341, 169, 0, 1144, 1146, 3, 299, 148, 0, 1145, 1143, 1, 0, 0, 0, 1145, 1144, 1, 0, 0, 0, 1145, 1146, 1, 0, 0, 0, 1146, 1148, 1, 0, 0, 0, 1147, 1149, 3, 281, 139, 0, 1148, 1147, 1, 0, 0, 0, 1149, 1150, 1, 0, 0, 0, 1150, 1148, 1, 0, 0, 0, 1150, 1151, 1, 0, 0, 0, 1151, 1176, 1, 0, 0, 0, 1152, 1153, 3, 303, 150, 0, 1153, 1154, 3, 219, 108, 0, 1154, 1157, 3, 233, 115, 0, 1155, 1158, 3, 341, 169, 0, 1156, 1158, 3, 299, 148, 0, 1157, 1155, 1, 0, 0, 0, 1157, 1156, 1, 0, 0, 0, 1157, 1158, 1, 0, 0, 0, 1158, 1160, 1, 0, 0, 0, 1159, 1161, 3, 281, 139, 0, 1160, 1159, 1, 0, 0, 0, 1161, 1162, 1, 0, 0, 0, 1162, 1160, 1, 0, 0, 0, 1162, 1163, 1, 0, 0, 0, 1163, 1176, 1, 0, 0, 0, 1164, 1165, 3, 219, 108, 0, 1165, 1168, 3, 233, 115, 0, 1166, 1169, 3, 341, 169, 0, 1167, 1169, 3, 299, 148, 0, 1168, 1166, 1, 0, 0, 0, 1168, 1167, 1, 0, 0, 0, 1168, 1169, 1, 0, 0, 0, 1169, 1171, 1, 0, 0, 0, 1170, 1172, 3, 281, 139, 0, 1171, 1170, 1, 0, 0, 0, 1172, 1173, 1, 0, 0, 0, 1173, 1171, 1, 0, 0, 0, 1173, 1174, 1, 0, 0, 0, 1174, 1176, 1, 0, 0, 0, 1175, 1099, 1, 0, 0, 0, 1175, 1120, 1, 0, 0, 0, 1175, 1134, 1, 0, 0, 0, 1175, 1152, 1, 0, 0, 0, 1175, 1164, 1, 0, 0, 0, 1176, 216, 1, 0, 0, 0, 1177, 1179, 5, 48, 0, 0, 1178, 1180, 3, 279, 138, 0, 1179, 1178, 1, 0, 0, 0, 1180, 1181, 1, 0, 0, 0, 1181, 1179, 1, 0, 0, 0, 1181, 1182, 1, 0, 0, 0, 1182, 218, 1, 0, 0, 0, 1183, 1185, 3, 281, 139, 0, 1184, 1183, 1, 0, 0, 0, 1185, 1186, 1, 0, 0, 0, 1186, 1184, 1, 0, 0, 0, 1186, 1187, 1, 0, 0, 0, 1187, 220, 1, 0, 0, 0, 1188, 1189, 5, 48, 0, 0, 1189, 1191, 3, 271, 134, 0, 1190, 1192, 3, 283, 140, 0, 1191, 1190, 1, 0, 0, 0, 1192, 1193, 1, 0, 0, 0, 1193, 1191, 1, 0, 0, 0, 1193, 1194, 1, 0, 0, 0, 1194, 222, 1, 0, 0, 0, 1195, 1206, 3, 351, 174, 0, 1196, 1205, 8, 2, 0, 0, 1197, 1205, 3, 211, 104, 0, 1198, 1199, 3, 291, 144, 0, 1199, 1200, 3, 351, 174, 0, 1200, 1205, 1, 0, 0, 0, 1201, 1202, 3, 351, 174, 0, 1202, 1203, 3, 351, 174, 0, 1203, 1205, 1, 0, 0, 0, 1204, 1196, 1, 0, 0, 0, 1204, 1197, 1, 0, 0, 0, 1204, 1198, 1, 0, 0, 0, 1204, 1201, 1, 0, 0, 0, 1205, 1208, 1, 0, 0, 0, 1206, 1204, 1, 0, 0, 0, 1206, 1207, 1, 0, 0, 0, 1207, 1209, 1, 0, 0, 0, 1208, 1206, 1, 0, 0, 0, 1209, 1210, 3, 351, 174, 0, 1210, 224, 1, 0, 0, 0, 1211, 1212, 7, 3, 0, 0, 1212, 226, 1, 0, 0, 0, 1213, 1214, 7, 4, 0, 0, 1214, 228, 1, 0, 0, 0, 1215, 1216, 7, 5, 0, 0, 1216, 230, 1, 0, 0, 0, 1217, 1218, 7, 6, 0, 0, 1218, 232, 1, 0, 0, 0, 1219, 1220, 7, 7, 0, 0, 1220, 234, 1, 0, 0, 0, 1221, 1222, 7, 8, 0, 0, 1222, 236, 1, 0, 0, 0, 1223, 1224, 7, 9, 0, 0, 1224, 238, 1, 0, 0, 0, 1225, 1226, 7, 10, 0, 0, 1226, 240, 1, 0, 0, 0, 1227, 1228, 7, 11, 0, 0, 1228, 242, 1, 0, 0, 0, 1229, 1230, 7, 12, 0, 0, 1230, 244, 1, 0, 0, 0, 1231, 1232, 7, 13, 0, 0, 1232, 246, 1, 0, 0, 0, 1233, 1234, 7, 14, 0, 0, 1234, 248, 1, 0, 0, 0, 1235, 1236, 7, 15, 0, 0, 1236, 250, 1, 0, 0, 0, 1237, 1238, 7, 16, 0, 0, 1238, 252, 1, 0, 0, 0, 1239, 1240, 7, 17, 0, 0, 1240, 254, 1, 0, 0, 0, 1241, 1242, 7, 18, 0, 0, 1242, 256, 1, 0, 0, 0, 1243, 1244, 7, 19, 0, 0, 1244, 258, 1, 0, 0, 0, 1245, 1246, 7, 20, 0, 0, 1246, 260, 1, 0, 0, 0, 1247, 1248, 7, 21, 0, 0, 1248, 262, 1, 0, 0, 0, 1249, 1250, 7, 22, 0, 0, 1250, 264, 1, 0, 0, 0, 1251, 1252, 7, 23, 0, 0, 1252, 266, 1, 0, 0, 0, 1253, 1254, 7, 24, 0, 0, 1254, 268, 1, 0, 0, 0, 1255, 1256, 7, 25, 0, 0, 1256, 270, 1, 0, 0, 0, 1257, 1258, 7, 26, 0, 0, 1258, 272, 1, 0, 0, 0, 1259, 1260, 7, 27, 0, 0, 1260, 274, 1, 0, 0, 0, 1261, 1262, 7, 28, 0, 0, 1262, 276, 1, 0, 0, 0, 1263, 1264, 7, 29, 0, 0, 1264, 278, 1, 0, 0, 0, 1265, 1266, 7, 30, 0, 0, 1266, 280, 1, 0, 0, 0, 1267, 1268, 7, 31, 0, 0, 1268, 282, 1, 0, 0, 0, 1269, 1270, 7, 32, 0, 0, 1270, 284, 1, 0, 0, 0, 1271, 1272, 5, 45, 0, 0, 1272, 1273, 5, 62, 0, 0, 1273, 286, 1, 0, 0, 0, 1274, 1275, 5, 42, 0, 0, 1275, 288, 1, 0, 0, 0, 1276, 1277, 5, 96, 0, 0, 1277, 290, 1, 0, 0, 0, 1278, 1279, 5, 92, 0, 0, 1279, 292, 1, 0, 0, 0, 1280, 1281, 5, 58, 0, 0, 1281, 294, 1, 0, 0, 0, 1282, 1283, 5, 44, 0, 0, 1283, 296, 1, 0, 0, 0, 1284, 1285, 5, 124, 0, 0, 1285, 1286, 5, 124, 0, 0, 1286, 298, 1, 0, 0, 0, 1287, 1288, 5, 45, 0, 0, 1288, 300, 1, 0, 0, 0, 1289, 1290, 5, 36, 0, 0, 1290, 302, 1, 0, 0, 0, 1291, 1292, 5, 46, 0, 0, 1292, 304, 1, 0, 0, 0, 1293, 1294, 5, 61, 0, 0, 1294, 1295, 5, 61, 0, 0, 1295, 306, 1, 0, 0, 0, 1296, 1297, 5, 61, 0, 0, 1297, 308, 1, 0, 0, 0, 1298, 1299, 5, 62, 0, 0, 1299, 1300, 5, 61, 0, 0, 1300, 310, 1, 0, 0, 0, 1301, 1302, 5, 62, 0, 0, 1302, 312, 1, 0, 0, 0, 1303, 1304, 5, 35, 0, 0, 1304, 314, 1, 0, 0, 0, 1305, 1306, 5, 126, 0, 0, 1306, 1307, 5, 42, 0, 0, 1307, 316, 1, 0, 0, 0, 1308, 1309, 5, 61, 0, 0, 1309, 1310, 5, 126, 0, 0, 1310, 1311, 5, 42, 0, 0, 1311, 318, 1, 0, 0, 0, 1312, 1313, 5, 123, 0, 0, 1313, 1314, 1, 0, 0, 0, 1314, 1315, 6, 158, 0, 0, 1315, 320, 1, 0, 0, 0, 1316, 1317, 5, 91, 0, 0, 1317, 322, 1, 0, 0, 0, 1318, 1319, 5, 40, 0, 0, 1319, 324, 1, 0, 0, 0, 1320, 1321, 5, 60, 0, 0, 1321, 1322, 5, 61, 0, 0, 1322, 326, 1, 0, 0, 0, 1323, 1324, 5, 60, 0, 0, 1324, 328, 1, 0, 0, 0, 1325, 1326, 5, 33, 0, 0, 1326, 1330, 5, 61, 0, 0, 1327, 1328, 5, 60, 0, 0, 1328, 1330, 5, 62, 0, 0, 1329, 1325, 1, 0, 0, 0, 1329, 1327, 1, 0, 0, 0, 1330, 330, 1, 0, 0, 0, 1331, 1332, 5, 33, 0, 0, 1332, 1333, 5, 126, 0, 0, 1333, 1334, 5, 42, 0, 0, 1334, 332, 1, 0, 0, 0, 1335, 1336, 5, 33, 0, 0, 1336, 1337, 5, 126, 0, 0, 1337, 334, 1, 0, 0, 0, 1338, 1339, 5, 63, 0, 0, 1339, 1340, 5, 46, 0, 0, 1340, 336, 1, 0, 0, 0, 1341, 1342, 5, 63, 0, 0, 1342, 1343, 5, 63, 0, 0, 1343, 338, 1, 0, 0, 0, 1344, 1345, 5, 37, 0, 0, 1345, 340, 1, 0, 0, 0, 1346, 1347, 5, 43, 0, 0, 1347, 342, 1, 0, 0, 0, 1348, 1349, 5, 63, 0, 0, 1349, 344, 1, 0, 0, 0, 1350, 1351, 5, 34, 0, 0, 1351, 346, 1, 0, 0, 0, 1352, 1353, 5, 102, 0, 0, 1353, 1354, 5, 39, 0, 0, 1354, 1355, 1, 0, 0, 0, 1355, 1356, 6, 172, 1, 0, 1356, 348, 1, 0, 0, 0, 1357, 1358, 5, 70, 0, 0, 1358, 1359, 5, 39, 0, 0, 1359, 1360, 1, 0, 0, 0, 1360, 1361, 6, 173, 2, 0, 1361, 350, 1, 0, 0, 0, 1362, 1363, 5, 39, 0, 0, 1363, 352, 1, 0, 0, 0, 1364, 1365, 5, 126, 0, 0, 1365, 354, 1, 0, 0, 0, 1366, 1367, 5, 61, 0, 0, 1367, 1368, 5, 126, 0, 0, 1368, 356, 1, 0, 0, 0, 1369, 1370, 5, 125, 0, 0, 1370, 1371, 1, 0, 0, 0, 1371, 1372, 6, 177, 3, 0, 1372, 358, 1, 0, 0, 0, 1373, 1374, 5, 93, 0, 0, 1374, 360, 1, 0, 0, 0, 1375, 1376, 5, 41, 0, 0, 1376, 362, 1, 0, 0, 0, 1377, 1378, 5, 59, 0, 0, 1378, 364, 1, 0, 0, 0, 1379, 1380, 5, 47, 0, 0, 1380, 366, 1, 0, 0, 0, 1381, 1382, 5, 95, 0, 0, 1382, 368, 1, 0, 0, 0, 1383, 1384, 5, 47, 0, 0, 1384, 1385, 5, 42, 0, 0, 1385, 1389, 1, 0, 0, 0, 1386, 1388, 9, 0, 0, 0, 1387, 1386, 1, 0, 0, 0, 1388, 1391, 1, 0, 0, 0, 1389, 1390, 1, 0, 0, 0, 1389, 1387, 1, 0, 0, 0, 1390, 1392, 1, 0, 0, 0, 1391, 1389, 1, 0, 0, 0, 1392, 1393, 5, 42, 0, 0, 1393, 1394, 5, 47, 0, 0, 1394, 1395, 1, 0, 0, 0, 1395, 1396, 6, 183, 4, 0, 1396, 370, 1, 0, 0, 0, 1397, 1398, 5, 45, 0, 0, 1398, 1402, 5, 45, 0, 0, 1399, 1400, 5, 47, 0, 0, 1400, 1402, 5, 47, 0, 0, 1401, 1397, 1, 0, 0, 0, 1401, 1399, 1, 0, 0, 0, 1402, 1406, 1, 0, 0, 0, 1403, 1405, 8, 33, 0, 0, 1404, 1403, 1, 0, 0, 0, 1405, 1408, 1, 0, 0, 0, 1406, 1404, 1, 0, 0, 0, 1406, 1407, 1, 0, 0, 0, 1407, 1410, 1, 0, 0, 0, 1408, 1406, 1, 0, 0, 0, 1409, 1411, 7, 34, 0, 0, 1410, 1409, 1, 0, 0, 0, 1411, 1412, 1, 0, 0, 0, 1412, 1413, 6, 184, 4, 0, 1413, 372, 1, 0, 0, 0, 1414, 1415, 7, 35, 0, 0, 1415, 1416, 1, 0, 0, 0, 1416, 1417, 6, 185, 5, 0, 1417, 374, 1, 0, 0, 0, 1418, 1430, 8, 36, 0, 0, 1419, 1430, 3, 211, 104, 0, 1420, 1421, 3, 291, 144, 0, 1421, 1422, 3, 351, 174, 0, 1422, 1430, 1, 0, 0, 0, 1423, 1424, 3, 291, 144, 0, 1424, 1425, 3, 319, 158, 0, 1425, 1430, 1, 0, 0, 0, 1426, 1427, 3, 351, 174, 0, 1427, 1428, 3, 351, 174, 0, 1428, 1430, 1, 0, 0, 0, 1429, 1418, 1, 0, 0, 0, 1429, 1419, 1, 0, 0, 0, 1429, 1420, 1, 0, 0, 0, 1429, 1423, 1, 0, 0, 0, 1429, 1426, 1, 0, 0, 0, 1430, 1431, 1, 0, 0, 0, 1431, 1429, 1, 0, 0, 0, 1431, 1432, 1, 0, 0, 0, 1432, 376, 1, 0, 0, 0, 1433, 1434, 3, 319, 158, 0, 1434, 1435, 1, 0, 0, 0, 1435, 1436, 6, 187, 0, 0, 1436, 378, 1, 0, 0, 0, 1437, 1438, 3, 351, 174, 0, 1438, 1439, 1, 0, 0, 0, 1439, 1440, 6, 188, 6, 0, 1440, 1441, 6, 188, 3, 0, 1441, 380, 1, 0, 0, 0, 1442, 1448, 8, 37, 0, 0, 1443, 1448, 3, 211, 104, 0, 1444, 1445, 3, 291, 144, 0, 1445, 1446, 3, 319, 158, 0, 1446, 1448, 1, 0, 0, 0, 1447, 1442, 1, 0, 0, 0, 1447, 1443, 1, 0, 0, 0, 1447, 1444, 1, 0, 0, 0, 1448, 1449, 1, 0, 0, 0, 1449, 1447, 1, 0, 0, 0, 1449, 1450, 1, 0, 0, 0, 1450, 382, 1, 0, 0, 0, 1451, 1452, 3, 319, 158, 0, 1452, 1453, 1, 0, 0, 0, 1453, 1454, 6, 190, 0, 0, 1454, 384, 1, 0, 0, 0, 44, 0, 1, 2, 425, 646, 1020, 1049, 1054, 1060, 1062, 1074, 1076, 1090, 1092, 1097, 1104, 1109, 1113, 1118, 1123, 1127, 1132, 1139, 1145, 1150, 1157, 1162, 1168, 1173, 1175, 1181, 1186, 1193, 1204, 1206, 1329, 1389, 1401, 1406, 1410, 1429, 1431, 1447, 1449, 7, 5, 0, 0, 5, 1, 0, 5, 2, 0, 4, 0, 0, 6, 0, 0, 0, 1, 0, 7, 145, 0] \ No newline at end of file +[4, 0, 162, 1476, 6, -1, 6, -1, 6, -1, 2, 0, 7, 0, 2, 1, 7, 1, 2, 2, 7, 2, 2, 3, 7, 3, 2, 4, 7, 4, 2, 5, 7, 5, 2, 6, 7, 6, 2, 7, 7, 7, 2, 8, 7, 8, 2, 9, 7, 9, 2, 10, 7, 10, 2, 11, 7, 11, 2, 12, 7, 12, 2, 13, 7, 13, 2, 14, 7, 14, 2, 15, 7, 15, 2, 16, 7, 16, 2, 17, 7, 17, 2, 18, 7, 18, 2, 19, 7, 19, 2, 20, 7, 20, 2, 21, 7, 21, 2, 22, 7, 22, 2, 23, 7, 23, 2, 24, 7, 24, 2, 25, 7, 25, 2, 26, 7, 26, 2, 27, 7, 27, 2, 28, 7, 28, 2, 29, 7, 29, 2, 30, 7, 30, 2, 31, 7, 31, 2, 32, 7, 32, 2, 33, 7, 33, 2, 34, 7, 34, 2, 35, 7, 35, 2, 36, 7, 36, 2, 37, 7, 37, 2, 38, 7, 38, 2, 39, 7, 39, 2, 40, 7, 40, 2, 41, 7, 41, 2, 42, 7, 42, 2, 43, 7, 43, 2, 44, 7, 44, 2, 45, 7, 45, 2, 46, 7, 46, 2, 47, 7, 47, 2, 48, 7, 48, 2, 49, 7, 49, 2, 50, 7, 50, 2, 51, 7, 51, 2, 52, 7, 52, 2, 53, 7, 53, 2, 54, 7, 54, 2, 55, 7, 55, 2, 56, 7, 56, 2, 57, 7, 57, 2, 58, 7, 58, 2, 59, 7, 59, 2, 60, 7, 60, 2, 61, 7, 61, 2, 62, 7, 62, 2, 63, 7, 63, 2, 64, 7, 64, 2, 65, 7, 65, 2, 66, 7, 66, 2, 67, 7, 67, 2, 68, 7, 68, 2, 69, 7, 69, 2, 70, 7, 70, 2, 71, 7, 71, 2, 72, 7, 72, 2, 73, 7, 73, 2, 74, 7, 74, 2, 75, 7, 75, 2, 76, 7, 76, 2, 77, 7, 77, 2, 78, 7, 78, 2, 79, 7, 79, 2, 80, 7, 80, 2, 81, 7, 81, 2, 82, 7, 82, 2, 83, 7, 83, 2, 84, 7, 84, 2, 85, 7, 85, 2, 86, 7, 86, 2, 87, 7, 87, 2, 88, 7, 88, 2, 89, 7, 89, 2, 90, 7, 90, 2, 91, 7, 91, 2, 92, 7, 92, 2, 93, 7, 93, 2, 94, 7, 94, 2, 95, 7, 95, 2, 96, 7, 96, 2, 97, 7, 97, 2, 98, 7, 98, 2, 99, 7, 99, 2, 100, 7, 100, 2, 101, 7, 101, 2, 102, 7, 102, 2, 103, 7, 103, 2, 104, 7, 104, 2, 105, 7, 105, 2, 106, 7, 106, 2, 107, 7, 107, 2, 108, 7, 108, 2, 109, 7, 109, 2, 110, 7, 110, 2, 111, 7, 111, 2, 112, 7, 112, 2, 113, 7, 113, 2, 114, 7, 114, 2, 115, 7, 115, 2, 116, 7, 116, 2, 117, 7, 117, 2, 118, 7, 118, 2, 119, 7, 119, 2, 120, 7, 120, 2, 121, 7, 121, 2, 122, 7, 122, 2, 123, 7, 123, 2, 124, 7, 124, 2, 125, 7, 125, 2, 126, 7, 126, 2, 127, 7, 127, 2, 128, 7, 128, 2, 129, 7, 129, 2, 130, 7, 130, 2, 131, 7, 131, 2, 132, 7, 132, 2, 133, 7, 133, 2, 134, 7, 134, 2, 135, 7, 135, 2, 136, 7, 136, 2, 137, 7, 137, 2, 138, 7, 138, 2, 139, 7, 139, 2, 140, 7, 140, 2, 141, 7, 141, 2, 142, 7, 142, 2, 143, 7, 143, 2, 144, 7, 144, 2, 145, 7, 145, 2, 146, 7, 146, 2, 147, 7, 147, 2, 148, 7, 148, 2, 149, 7, 149, 2, 150, 7, 150, 2, 151, 7, 151, 2, 152, 7, 152, 2, 153, 7, 153, 2, 154, 7, 154, 2, 155, 7, 155, 2, 156, 7, 156, 2, 157, 7, 157, 2, 158, 7, 158, 2, 159, 7, 159, 2, 160, 7, 160, 2, 161, 7, 161, 2, 162, 7, 162, 2, 163, 7, 163, 2, 164, 7, 164, 2, 165, 7, 165, 2, 166, 7, 166, 2, 167, 7, 167, 2, 168, 7, 168, 2, 169, 7, 169, 2, 170, 7, 170, 2, 171, 7, 171, 2, 172, 7, 172, 2, 173, 7, 173, 2, 174, 7, 174, 2, 175, 7, 175, 2, 176, 7, 176, 2, 177, 7, 177, 2, 178, 7, 178, 2, 179, 7, 179, 2, 180, 7, 180, 2, 181, 7, 181, 2, 182, 7, 182, 2, 183, 7, 183, 2, 184, 7, 184, 2, 185, 7, 185, 2, 186, 7, 186, 2, 187, 7, 187, 2, 188, 7, 188, 2, 189, 7, 189, 2, 190, 7, 190, 2, 191, 7, 191, 2, 192, 7, 192, 1, 0, 1, 0, 1, 0, 1, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 2, 1, 2, 1, 2, 1, 2, 1, 2, 1, 3, 1, 3, 1, 3, 1, 3, 1, 4, 1, 4, 1, 4, 1, 4, 1, 4, 1, 4, 1, 5, 1, 5, 1, 5, 1, 6, 1, 6, 1, 6, 1, 6, 1, 6, 1, 6, 1, 6, 1, 6, 1, 6, 1, 6, 1, 6, 1, 6, 1, 6, 1, 6, 3, 6, 430, 8, 6, 1, 7, 1, 7, 1, 7, 1, 7, 1, 7, 1, 8, 1, 8, 1, 8, 1, 8, 1, 8, 1, 8, 1, 8, 1, 8, 1, 9, 1, 9, 1, 9, 1, 9, 1, 9, 1, 10, 1, 10, 1, 10, 1, 11, 1, 11, 1, 11, 1, 11, 1, 11, 1, 12, 1, 12, 1, 12, 1, 12, 1, 12, 1, 13, 1, 13, 1, 13, 1, 13, 1, 13, 1, 13, 1, 14, 1, 14, 1, 14, 1, 14, 1, 14, 1, 14, 1, 14, 1, 15, 1, 15, 1, 15, 1, 15, 1, 15, 1, 15, 1, 15, 1, 15, 1, 16, 1, 16, 1, 16, 1, 16, 1, 16, 1, 16, 1, 17, 1, 17, 1, 17, 1, 17, 1, 17, 1, 18, 1, 18, 1, 18, 1, 18, 1, 18, 1, 18, 1, 18, 1, 18, 1, 19, 1, 19, 1, 19, 1, 19, 1, 19, 1, 20, 1, 20, 1, 20, 1, 20, 1, 21, 1, 21, 1, 21, 1, 21, 1, 21, 1, 22, 1, 22, 1, 22, 1, 22, 1, 22, 1, 22, 1, 22, 1, 22, 1, 22, 1, 22, 1, 22, 1, 23, 1, 23, 1, 23, 1, 23, 1, 23, 1, 23, 1, 23, 1, 23, 1, 23, 1, 24, 1, 24, 1, 24, 1, 24, 1, 24, 1, 25, 1, 25, 1, 25, 1, 25, 1, 26, 1, 26, 1, 26, 1, 26, 1, 26, 1, 26, 1, 26, 1, 27, 1, 27, 1, 27, 1, 27, 1, 27, 1, 27, 1, 27, 1, 27, 1, 28, 1, 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, 30, 1, 30, 1, 30, 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, 1, 32, 1, 32, 1, 33, 1, 33, 1, 33, 1, 33, 1, 34, 1, 34, 1, 34, 1, 34, 1, 34, 1, 35, 1, 35, 1, 35, 1, 35, 1, 35, 1, 36, 1, 36, 1, 36, 1, 36, 1, 37, 1, 37, 1, 37, 1, 37, 1, 37, 1, 37, 1, 38, 1, 38, 1, 38, 1, 38, 1, 38, 1, 38, 1, 38, 1, 39, 1, 39, 1, 39, 1, 39, 1, 39, 1, 40, 1, 40, 1, 40, 1, 41, 1, 41, 1, 41, 1, 42, 1, 42, 1, 42, 1, 42, 1, 42, 1, 42, 1, 43, 1, 43, 1, 43, 1, 44, 1, 44, 1, 44, 1, 44, 1, 44, 1, 44, 1, 44, 1, 44, 1, 44, 1, 44, 1, 44, 1, 44, 1, 44, 3, 44, 658, 8, 44, 1, 45, 1, 45, 1, 45, 1, 45, 1, 45, 1, 45, 1, 46, 1, 46, 1, 46, 1, 46, 1, 46, 1, 46, 1, 46, 1, 46, 1, 46, 1, 46, 1, 47, 1, 47, 1, 47, 1, 47, 1, 47, 1, 47, 1, 47, 1, 47, 1, 47, 1, 48, 1, 48, 1, 48, 1, 49, 1, 49, 1, 49, 1, 49, 1, 49, 1, 50, 1, 50, 1, 50, 1, 50, 1, 51, 1, 51, 1, 51, 1, 51, 1, 51, 1, 52, 1, 52, 1, 52, 1, 52, 1, 52, 1, 52, 1, 52, 1, 52, 1, 53, 1, 53, 1, 53, 1, 53, 1, 53, 1, 54, 1, 54, 1, 54, 1, 54, 1, 55, 1, 55, 1, 55, 1, 55, 1, 55, 1, 56, 1, 56, 1, 56, 1, 56, 1, 56, 1, 56, 1, 57, 1, 57, 1, 57, 1, 57, 1, 57, 1, 57, 1, 57, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 59, 1, 59, 1, 59, 1, 59, 1, 60, 1, 60, 1, 60, 1, 60, 1, 61, 1, 61, 1, 61, 1, 61, 1, 61, 1, 62, 1, 62, 1, 62, 1, 62, 1, 62, 1, 62, 1, 63, 1, 63, 1, 63, 1, 63, 1, 63, 1, 63, 1, 63, 1, 64, 1, 64, 1, 64, 1, 65, 1, 65, 1, 65, 1, 66, 1, 66, 1, 66, 1, 66, 1, 66, 1, 66, 1, 67, 1, 67, 1, 67, 1, 67, 1, 67, 1, 67, 1, 68, 1, 68, 1, 68, 1, 68, 1, 68, 1, 69, 1, 69, 1, 69, 1, 69, 1, 69, 1, 69, 1, 69, 1, 69, 1, 69, 1, 69, 1, 70, 1, 70, 1, 70, 1, 70, 1, 70, 1, 70, 1, 70, 1, 70, 1, 70, 1, 70, 1, 71, 1, 71, 1, 71, 1, 71, 1, 71, 1, 71, 1, 71, 1, 71, 1, 71, 1, 72, 1, 72, 1, 72, 1, 72, 1, 72, 1, 72, 1, 72, 1, 72, 1, 73, 1, 73, 1, 73, 1, 73, 1, 73, 1, 73, 1, 74, 1, 74, 1, 74, 1, 74, 1, 74, 1, 74, 1, 74, 1, 75, 1, 75, 1, 75, 1, 75, 1, 75, 1, 75, 1, 76, 1, 76, 1, 76, 1, 76, 1, 76, 1, 76, 1, 76, 1, 77, 1, 77, 1, 77, 1, 77, 1, 78, 1, 78, 1, 78, 1, 78, 1, 78, 1, 79, 1, 79, 1, 79, 1, 79, 1, 79, 1, 79, 1, 79, 1, 80, 1, 80, 1, 80, 1, 80, 1, 80, 1, 80, 1, 80, 1, 81, 1, 81, 1, 81, 1, 81, 1, 81, 1, 81, 1, 81, 1, 82, 1, 82, 1, 82, 1, 82, 1, 82, 1, 83, 1, 83, 1, 83, 1, 83, 1, 83, 1, 83, 1, 83, 1, 83, 1, 83, 1, 84, 1, 84, 1, 84, 1, 84, 1, 84, 1, 84, 1, 84, 1, 84, 1, 84, 1, 84, 1, 85, 1, 85, 1, 85, 1, 85, 1, 85, 1, 86, 1, 86, 1, 86, 1, 86, 1, 86, 1, 86, 1, 87, 1, 87, 1, 87, 1, 87, 1, 87, 1, 88, 1, 88, 1, 88, 1, 88, 1, 88, 1, 88, 1, 88, 1, 88, 1, 88, 1, 88, 1, 89, 1, 89, 1, 89, 1, 90, 1, 90, 1, 90, 1, 90, 1, 91, 1, 91, 1, 91, 1, 91, 1, 91, 1, 91, 1, 91, 1, 92, 1, 92, 1, 92, 1, 92, 1, 92, 1, 92, 1, 92, 1, 92, 1, 92, 1, 93, 1, 93, 1, 93, 1, 93, 1, 93, 1, 94, 1, 94, 1, 94, 1, 94, 1, 94, 1, 94, 1, 94, 1, 94, 1, 94, 1, 95, 1, 95, 1, 95, 1, 95, 1, 96, 1, 96, 1, 96, 1, 96, 1, 96, 1, 96, 1, 96, 1, 96, 1, 96, 1, 96, 1, 97, 1, 97, 1, 97, 1, 97, 1, 97, 1, 97, 1, 98, 1, 98, 1, 98, 1, 98, 1, 98, 1, 98, 1, 99, 1, 99, 1, 99, 1, 99, 1, 99, 1, 100, 1, 100, 1, 100, 1, 100, 1, 100, 1, 101, 1, 101, 1, 101, 1, 101, 1, 101, 1, 101, 1, 102, 1, 102, 1, 102, 1, 102, 1, 102, 1, 102, 1, 103, 1, 103, 1, 103, 1, 103, 1, 103, 1, 103, 1, 103, 1, 104, 1, 104, 1, 104, 1, 104, 1, 104, 1, 105, 1, 105, 1, 105, 1, 105, 1, 105, 1, 105, 1, 105, 1, 105, 1, 105, 1, 105, 3, 105, 1042, 8, 105, 1, 106, 1, 106, 1, 106, 1, 106, 1, 106, 1, 106, 1, 106, 1, 106, 1, 106, 1, 106, 1, 106, 1, 106, 1, 106, 1, 106, 1, 106, 1, 106, 1, 106, 1, 106, 1, 106, 1, 106, 1, 106, 1, 106, 1, 106, 1, 106, 1, 106, 1, 106, 1, 106, 3, 106, 1071, 8, 106, 1, 107, 1, 107, 1, 107, 3, 107, 1076, 8, 107, 1, 107, 1, 107, 1, 107, 1, 107, 5, 107, 1082, 8, 107, 10, 107, 12, 107, 1085, 9, 107, 1, 107, 1, 107, 1, 107, 1, 107, 1, 107, 1, 107, 1, 107, 1, 107, 1, 107, 5, 107, 1096, 8, 107, 10, 107, 12, 107, 1099, 9, 107, 1, 107, 1, 107, 1, 107, 1, 107, 1, 107, 1, 107, 1, 107, 1, 107, 1, 107, 1, 107, 1, 107, 5, 107, 1112, 8, 107, 10, 107, 12, 107, 1115, 9, 107, 1, 107, 1, 107, 3, 107, 1119, 8, 107, 1, 108, 1, 108, 1, 108, 5, 108, 1124, 8, 108, 10, 108, 12, 108, 1127, 9, 108, 1, 108, 1, 108, 3, 108, 1131, 8, 108, 1, 108, 1, 108, 3, 108, 1135, 8, 108, 1, 108, 4, 108, 1138, 8, 108, 11, 108, 12, 108, 1139, 1, 108, 1, 108, 1, 108, 3, 108, 1145, 8, 108, 1, 108, 1, 108, 3, 108, 1149, 8, 108, 1, 108, 4, 108, 1152, 8, 108, 11, 108, 12, 108, 1153, 1, 108, 1, 108, 1, 108, 5, 108, 1159, 8, 108, 10, 108, 12, 108, 1162, 9, 108, 1, 108, 1, 108, 1, 108, 3, 108, 1167, 8, 108, 1, 108, 4, 108, 1170, 8, 108, 11, 108, 12, 108, 1171, 1, 108, 1, 108, 1, 108, 1, 108, 1, 108, 3, 108, 1179, 8, 108, 1, 108, 4, 108, 1182, 8, 108, 11, 108, 12, 108, 1183, 1, 108, 1, 108, 1, 108, 1, 108, 3, 108, 1190, 8, 108, 1, 108, 4, 108, 1193, 8, 108, 11, 108, 12, 108, 1194, 3, 108, 1197, 8, 108, 1, 109, 1, 109, 4, 109, 1201, 8, 109, 11, 109, 12, 109, 1202, 1, 110, 4, 110, 1206, 8, 110, 11, 110, 12, 110, 1207, 1, 111, 1, 111, 1, 111, 4, 111, 1213, 8, 111, 11, 111, 12, 111, 1214, 1, 112, 1, 112, 1, 112, 1, 112, 1, 112, 1, 112, 1, 112, 1, 112, 1, 112, 5, 112, 1226, 8, 112, 10, 112, 12, 112, 1229, 9, 112, 1, 112, 1, 112, 1, 113, 1, 113, 1, 114, 1, 114, 1, 115, 1, 115, 1, 116, 1, 116, 1, 117, 1, 117, 1, 118, 1, 118, 1, 119, 1, 119, 1, 120, 1, 120, 1, 121, 1, 121, 1, 122, 1, 122, 1, 123, 1, 123, 1, 124, 1, 124, 1, 125, 1, 125, 1, 126, 1, 126, 1, 127, 1, 127, 1, 128, 1, 128, 1, 129, 1, 129, 1, 130, 1, 130, 1, 131, 1, 131, 1, 132, 1, 132, 1, 133, 1, 133, 1, 134, 1, 134, 1, 135, 1, 135, 1, 136, 1, 136, 1, 137, 1, 137, 1, 138, 1, 138, 1, 139, 1, 139, 1, 140, 1, 140, 1, 141, 1, 141, 1, 142, 1, 142, 1, 143, 1, 143, 1, 143, 1, 144, 1, 144, 1, 145, 1, 145, 1, 146, 1, 146, 1, 147, 1, 147, 1, 148, 1, 148, 1, 149, 1, 149, 1, 149, 1, 150, 1, 150, 1, 151, 1, 151, 1, 152, 1, 152, 1, 153, 1, 153, 1, 153, 1, 154, 1, 154, 1, 155, 1, 155, 1, 155, 1, 156, 1, 156, 1, 157, 1, 157, 1, 158, 1, 158, 1, 158, 1, 159, 1, 159, 1, 159, 1, 159, 1, 160, 1, 160, 1, 160, 1, 160, 1, 161, 1, 161, 1, 162, 1, 162, 1, 163, 1, 163, 1, 163, 1, 164, 1, 164, 1, 165, 1, 165, 1, 165, 1, 165, 3, 165, 1351, 8, 165, 1, 166, 1, 166, 1, 166, 1, 166, 1, 167, 1, 167, 1, 167, 1, 168, 1, 168, 1, 168, 1, 169, 1, 169, 1, 169, 1, 170, 1, 170, 1, 171, 1, 171, 1, 172, 1, 172, 1, 173, 1, 173, 1, 174, 1, 174, 1, 174, 1, 174, 1, 174, 1, 175, 1, 175, 1, 175, 1, 175, 1, 175, 1, 176, 1, 176, 1, 177, 1, 177, 1, 178, 1, 178, 1, 178, 1, 179, 1, 179, 1, 179, 1, 179, 1, 180, 1, 180, 1, 181, 1, 181, 1, 182, 1, 182, 1, 183, 1, 183, 1, 184, 1, 184, 1, 185, 1, 185, 1, 185, 1, 185, 5, 185, 1409, 8, 185, 10, 185, 12, 185, 1412, 9, 185, 1, 185, 1, 185, 1, 185, 1, 185, 1, 185, 1, 186, 1, 186, 1, 186, 1, 186, 3, 186, 1423, 8, 186, 1, 186, 5, 186, 1426, 8, 186, 10, 186, 12, 186, 1429, 9, 186, 1, 186, 3, 186, 1432, 8, 186, 1, 186, 1, 186, 1, 187, 1, 187, 1, 187, 1, 187, 1, 188, 1, 188, 1, 188, 1, 188, 1, 188, 1, 188, 1, 188, 1, 188, 1, 188, 1, 188, 1, 188, 4, 188, 1451, 8, 188, 11, 188, 12, 188, 1452, 1, 189, 1, 189, 1, 189, 1, 189, 1, 190, 1, 190, 1, 190, 1, 190, 1, 190, 1, 191, 1, 191, 1, 191, 1, 191, 1, 191, 4, 191, 1469, 8, 191, 11, 191, 12, 191, 1470, 1, 192, 1, 192, 1, 192, 1, 192, 1, 1410, 0, 193, 3, 1, 5, 2, 7, 3, 9, 4, 11, 5, 13, 6, 15, 7, 17, 8, 19, 9, 21, 10, 23, 11, 25, 12, 27, 13, 29, 14, 31, 15, 33, 16, 35, 17, 37, 18, 39, 19, 41, 20, 43, 21, 45, 22, 47, 23, 49, 24, 51, 25, 53, 26, 55, 27, 57, 28, 59, 29, 61, 30, 63, 31, 65, 32, 67, 33, 69, 34, 71, 35, 73, 36, 75, 37, 77, 38, 79, 39, 81, 40, 83, 41, 85, 42, 87, 43, 89, 44, 91, 45, 93, 46, 95, 47, 97, 48, 99, 49, 101, 50, 103, 51, 105, 52, 107, 53, 109, 54, 111, 55, 113, 56, 115, 57, 117, 58, 119, 59, 121, 60, 123, 61, 125, 62, 127, 63, 129, 64, 131, 65, 133, 66, 135, 67, 137, 68, 139, 69, 141, 70, 143, 71, 145, 72, 147, 73, 149, 74, 151, 75, 153, 76, 155, 77, 157, 78, 159, 79, 161, 80, 163, 81, 165, 82, 167, 83, 169, 84, 171, 85, 173, 86, 175, 87, 177, 88, 179, 89, 181, 90, 183, 91, 185, 92, 187, 93, 189, 94, 191, 95, 193, 96, 195, 97, 197, 98, 199, 99, 201, 100, 203, 101, 205, 102, 207, 103, 209, 104, 211, 105, 213, 106, 215, 107, 217, 108, 219, 109, 221, 110, 223, 111, 225, 112, 227, 113, 229, 0, 231, 0, 233, 0, 235, 0, 237, 0, 239, 0, 241, 0, 243, 0, 245, 0, 247, 0, 249, 0, 251, 0, 253, 0, 255, 0, 257, 0, 259, 0, 261, 0, 263, 0, 265, 0, 267, 0, 269, 0, 271, 0, 273, 0, 275, 0, 277, 0, 279, 0, 281, 0, 283, 0, 285, 0, 287, 0, 289, 114, 291, 115, 293, 116, 295, 117, 297, 118, 299, 119, 301, 120, 303, 121, 305, 122, 307, 123, 309, 124, 311, 125, 313, 126, 315, 127, 317, 128, 319, 129, 321, 130, 323, 131, 325, 132, 327, 133, 329, 134, 331, 135, 333, 136, 335, 137, 337, 138, 339, 139, 341, 140, 343, 141, 345, 142, 347, 143, 349, 144, 351, 145, 353, 146, 355, 147, 357, 148, 359, 149, 361, 150, 363, 151, 365, 152, 367, 153, 369, 154, 371, 155, 373, 156, 375, 157, 377, 158, 379, 159, 381, 160, 383, 0, 385, 161, 387, 162, 3, 0, 1, 2, 38, 2, 0, 92, 92, 96, 96, 2, 0, 34, 34, 92, 92, 2, 0, 39, 39, 92, 92, 2, 0, 65, 65, 97, 97, 2, 0, 66, 66, 98, 98, 2, 0, 67, 67, 99, 99, 2, 0, 68, 68, 100, 100, 2, 0, 69, 69, 101, 101, 2, 0, 70, 70, 102, 102, 2, 0, 71, 71, 103, 103, 2, 0, 72, 72, 104, 104, 2, 0, 73, 73, 105, 105, 2, 0, 74, 74, 106, 106, 2, 0, 75, 75, 107, 107, 2, 0, 76, 76, 108, 108, 2, 0, 77, 77, 109, 109, 2, 0, 78, 78, 110, 110, 2, 0, 79, 79, 111, 111, 2, 0, 80, 80, 112, 112, 2, 0, 81, 81, 113, 113, 2, 0, 82, 82, 114, 114, 2, 0, 83, 83, 115, 115, 2, 0, 84, 84, 116, 116, 2, 0, 85, 85, 117, 117, 2, 0, 86, 86, 118, 118, 2, 0, 87, 87, 119, 119, 2, 0, 88, 88, 120, 120, 2, 0, 89, 89, 121, 121, 2, 0, 90, 90, 122, 122, 2, 0, 65, 90, 97, 122, 1, 0, 48, 55, 1, 0, 48, 57, 3, 0, 48, 57, 65, 70, 97, 102, 2, 0, 10, 10, 13, 13, 2, 1, 10, 10, 13, 13, 2, 0, 9, 13, 32, 32, 3, 0, 39, 39, 92, 92, 123, 123, 1, 0, 123, 123, 1512, 0, 3, 1, 0, 0, 0, 0, 5, 1, 0, 0, 0, 0, 7, 1, 0, 0, 0, 0, 9, 1, 0, 0, 0, 0, 11, 1, 0, 0, 0, 0, 13, 1, 0, 0, 0, 0, 15, 1, 0, 0, 0, 0, 17, 1, 0, 0, 0, 0, 19, 1, 0, 0, 0, 0, 21, 1, 0, 0, 0, 0, 23, 1, 0, 0, 0, 0, 25, 1, 0, 0, 0, 0, 27, 1, 0, 0, 0, 0, 29, 1, 0, 0, 0, 0, 31, 1, 0, 0, 0, 0, 33, 1, 0, 0, 0, 0, 35, 1, 0, 0, 0, 0, 37, 1, 0, 0, 0, 0, 39, 1, 0, 0, 0, 0, 41, 1, 0, 0, 0, 0, 43, 1, 0, 0, 0, 0, 45, 1, 0, 0, 0, 0, 47, 1, 0, 0, 0, 0, 49, 1, 0, 0, 0, 0, 51, 1, 0, 0, 0, 0, 53, 1, 0, 0, 0, 0, 55, 1, 0, 0, 0, 0, 57, 1, 0, 0, 0, 0, 59, 1, 0, 0, 0, 0, 61, 1, 0, 0, 0, 0, 63, 1, 0, 0, 0, 0, 65, 1, 0, 0, 0, 0, 67, 1, 0, 0, 0, 0, 69, 1, 0, 0, 0, 0, 71, 1, 0, 0, 0, 0, 73, 1, 0, 0, 0, 0, 75, 1, 0, 0, 0, 0, 77, 1, 0, 0, 0, 0, 79, 1, 0, 0, 0, 0, 81, 1, 0, 0, 0, 0, 83, 1, 0, 0, 0, 0, 85, 1, 0, 0, 0, 0, 87, 1, 0, 0, 0, 0, 89, 1, 0, 0, 0, 0, 91, 1, 0, 0, 0, 0, 93, 1, 0, 0, 0, 0, 95, 1, 0, 0, 0, 0, 97, 1, 0, 0, 0, 0, 99, 1, 0, 0, 0, 0, 101, 1, 0, 0, 0, 0, 103, 1, 0, 0, 0, 0, 105, 1, 0, 0, 0, 0, 107, 1, 0, 0, 0, 0, 109, 1, 0, 0, 0, 0, 111, 1, 0, 0, 0, 0, 113, 1, 0, 0, 0, 0, 115, 1, 0, 0, 0, 0, 117, 1, 0, 0, 0, 0, 119, 1, 0, 0, 0, 0, 121, 1, 0, 0, 0, 0, 123, 1, 0, 0, 0, 0, 125, 1, 0, 0, 0, 0, 127, 1, 0, 0, 0, 0, 129, 1, 0, 0, 0, 0, 131, 1, 0, 0, 0, 0, 133, 1, 0, 0, 0, 0, 135, 1, 0, 0, 0, 0, 137, 1, 0, 0, 0, 0, 139, 1, 0, 0, 0, 0, 141, 1, 0, 0, 0, 0, 143, 1, 0, 0, 0, 0, 145, 1, 0, 0, 0, 0, 147, 1, 0, 0, 0, 0, 149, 1, 0, 0, 0, 0, 151, 1, 0, 0, 0, 0, 153, 1, 0, 0, 0, 0, 155, 1, 0, 0, 0, 0, 157, 1, 0, 0, 0, 0, 159, 1, 0, 0, 0, 0, 161, 1, 0, 0, 0, 0, 163, 1, 0, 0, 0, 0, 165, 1, 0, 0, 0, 0, 167, 1, 0, 0, 0, 0, 169, 1, 0, 0, 0, 0, 171, 1, 0, 0, 0, 0, 173, 1, 0, 0, 0, 0, 175, 1, 0, 0, 0, 0, 177, 1, 0, 0, 0, 0, 179, 1, 0, 0, 0, 0, 181, 1, 0, 0, 0, 0, 183, 1, 0, 0, 0, 0, 185, 1, 0, 0, 0, 0, 187, 1, 0, 0, 0, 0, 189, 1, 0, 0, 0, 0, 191, 1, 0, 0, 0, 0, 193, 1, 0, 0, 0, 0, 195, 1, 0, 0, 0, 0, 197, 1, 0, 0, 0, 0, 199, 1, 0, 0, 0, 0, 201, 1, 0, 0, 0, 0, 203, 1, 0, 0, 0, 0, 205, 1, 0, 0, 0, 0, 207, 1, 0, 0, 0, 0, 209, 1, 0, 0, 0, 0, 211, 1, 0, 0, 0, 0, 213, 1, 0, 0, 0, 0, 215, 1, 0, 0, 0, 0, 217, 1, 0, 0, 0, 0, 219, 1, 0, 0, 0, 0, 221, 1, 0, 0, 0, 0, 223, 1, 0, 0, 0, 0, 225, 1, 0, 0, 0, 0, 227, 1, 0, 0, 0, 0, 289, 1, 0, 0, 0, 0, 291, 1, 0, 0, 0, 0, 293, 1, 0, 0, 0, 0, 295, 1, 0, 0, 0, 0, 297, 1, 0, 0, 0, 0, 299, 1, 0, 0, 0, 0, 301, 1, 0, 0, 0, 0, 303, 1, 0, 0, 0, 0, 305, 1, 0, 0, 0, 0, 307, 1, 0, 0, 0, 0, 309, 1, 0, 0, 0, 0, 311, 1, 0, 0, 0, 0, 313, 1, 0, 0, 0, 0, 315, 1, 0, 0, 0, 0, 317, 1, 0, 0, 0, 0, 319, 1, 0, 0, 0, 0, 321, 1, 0, 0, 0, 0, 323, 1, 0, 0, 0, 0, 325, 1, 0, 0, 0, 0, 327, 1, 0, 0, 0, 0, 329, 1, 0, 0, 0, 0, 331, 1, 0, 0, 0, 0, 333, 1, 0, 0, 0, 0, 335, 1, 0, 0, 0, 0, 337, 1, 0, 0, 0, 0, 339, 1, 0, 0, 0, 0, 341, 1, 0, 0, 0, 0, 343, 1, 0, 0, 0, 0, 345, 1, 0, 0, 0, 0, 347, 1, 0, 0, 0, 0, 349, 1, 0, 0, 0, 0, 351, 1, 0, 0, 0, 0, 353, 1, 0, 0, 0, 0, 355, 1, 0, 0, 0, 0, 357, 1, 0, 0, 0, 0, 359, 1, 0, 0, 0, 0, 361, 1, 0, 0, 0, 0, 363, 1, 0, 0, 0, 0, 365, 1, 0, 0, 0, 0, 367, 1, 0, 0, 0, 0, 369, 1, 0, 0, 0, 0, 371, 1, 0, 0, 0, 0, 373, 1, 0, 0, 0, 0, 375, 1, 0, 0, 0, 0, 377, 1, 0, 0, 0, 1, 379, 1, 0, 0, 0, 1, 381, 1, 0, 0, 0, 1, 383, 1, 0, 0, 0, 2, 385, 1, 0, 0, 0, 2, 387, 1, 0, 0, 0, 3, 389, 1, 0, 0, 0, 5, 393, 1, 0, 0, 0, 7, 397, 1, 0, 0, 0, 9, 402, 1, 0, 0, 0, 11, 406, 1, 0, 0, 0, 13, 412, 1, 0, 0, 0, 15, 429, 1, 0, 0, 0, 17, 431, 1, 0, 0, 0, 19, 436, 1, 0, 0, 0, 21, 444, 1, 0, 0, 0, 23, 449, 1, 0, 0, 0, 25, 452, 1, 0, 0, 0, 27, 457, 1, 0, 0, 0, 29, 462, 1, 0, 0, 0, 31, 468, 1, 0, 0, 0, 33, 475, 1, 0, 0, 0, 35, 483, 1, 0, 0, 0, 37, 489, 1, 0, 0, 0, 39, 494, 1, 0, 0, 0, 41, 502, 1, 0, 0, 0, 43, 507, 1, 0, 0, 0, 45, 511, 1, 0, 0, 0, 47, 516, 1, 0, 0, 0, 49, 527, 1, 0, 0, 0, 51, 536, 1, 0, 0, 0, 53, 541, 1, 0, 0, 0, 55, 545, 1, 0, 0, 0, 57, 552, 1, 0, 0, 0, 59, 560, 1, 0, 0, 0, 61, 566, 1, 0, 0, 0, 63, 574, 1, 0, 0, 0, 65, 580, 1, 0, 0, 0, 67, 583, 1, 0, 0, 0, 69, 593, 1, 0, 0, 0, 71, 597, 1, 0, 0, 0, 73, 602, 1, 0, 0, 0, 75, 607, 1, 0, 0, 0, 77, 611, 1, 0, 0, 0, 79, 617, 1, 0, 0, 0, 81, 624, 1, 0, 0, 0, 83, 629, 1, 0, 0, 0, 85, 632, 1, 0, 0, 0, 87, 635, 1, 0, 0, 0, 89, 641, 1, 0, 0, 0, 91, 657, 1, 0, 0, 0, 93, 659, 1, 0, 0, 0, 95, 665, 1, 0, 0, 0, 97, 675, 1, 0, 0, 0, 99, 684, 1, 0, 0, 0, 101, 687, 1, 0, 0, 0, 103, 692, 1, 0, 0, 0, 105, 696, 1, 0, 0, 0, 107, 701, 1, 0, 0, 0, 109, 709, 1, 0, 0, 0, 111, 714, 1, 0, 0, 0, 113, 718, 1, 0, 0, 0, 115, 723, 1, 0, 0, 0, 117, 729, 1, 0, 0, 0, 119, 736, 1, 0, 0, 0, 121, 742, 1, 0, 0, 0, 123, 746, 1, 0, 0, 0, 125, 750, 1, 0, 0, 0, 127, 755, 1, 0, 0, 0, 129, 761, 1, 0, 0, 0, 131, 768, 1, 0, 0, 0, 133, 771, 1, 0, 0, 0, 135, 774, 1, 0, 0, 0, 137, 780, 1, 0, 0, 0, 139, 786, 1, 0, 0, 0, 141, 791, 1, 0, 0, 0, 143, 801, 1, 0, 0, 0, 145, 811, 1, 0, 0, 0, 147, 820, 1, 0, 0, 0, 149, 828, 1, 0, 0, 0, 151, 834, 1, 0, 0, 0, 153, 841, 1, 0, 0, 0, 155, 847, 1, 0, 0, 0, 157, 854, 1, 0, 0, 0, 159, 858, 1, 0, 0, 0, 161, 863, 1, 0, 0, 0, 163, 870, 1, 0, 0, 0, 165, 877, 1, 0, 0, 0, 167, 884, 1, 0, 0, 0, 169, 889, 1, 0, 0, 0, 171, 898, 1, 0, 0, 0, 173, 908, 1, 0, 0, 0, 175, 913, 1, 0, 0, 0, 177, 919, 1, 0, 0, 0, 179, 924, 1, 0, 0, 0, 181, 934, 1, 0, 0, 0, 183, 937, 1, 0, 0, 0, 185, 941, 1, 0, 0, 0, 187, 948, 1, 0, 0, 0, 189, 957, 1, 0, 0, 0, 191, 962, 1, 0, 0, 0, 193, 971, 1, 0, 0, 0, 195, 975, 1, 0, 0, 0, 197, 985, 1, 0, 0, 0, 199, 991, 1, 0, 0, 0, 201, 997, 1, 0, 0, 0, 203, 1002, 1, 0, 0, 0, 205, 1007, 1, 0, 0, 0, 207, 1013, 1, 0, 0, 0, 209, 1019, 1, 0, 0, 0, 211, 1026, 1, 0, 0, 0, 213, 1041, 1, 0, 0, 0, 215, 1070, 1, 0, 0, 0, 217, 1118, 1, 0, 0, 0, 219, 1196, 1, 0, 0, 0, 221, 1198, 1, 0, 0, 0, 223, 1205, 1, 0, 0, 0, 225, 1209, 1, 0, 0, 0, 227, 1216, 1, 0, 0, 0, 229, 1232, 1, 0, 0, 0, 231, 1234, 1, 0, 0, 0, 233, 1236, 1, 0, 0, 0, 235, 1238, 1, 0, 0, 0, 237, 1240, 1, 0, 0, 0, 239, 1242, 1, 0, 0, 0, 241, 1244, 1, 0, 0, 0, 243, 1246, 1, 0, 0, 0, 245, 1248, 1, 0, 0, 0, 247, 1250, 1, 0, 0, 0, 249, 1252, 1, 0, 0, 0, 251, 1254, 1, 0, 0, 0, 253, 1256, 1, 0, 0, 0, 255, 1258, 1, 0, 0, 0, 257, 1260, 1, 0, 0, 0, 259, 1262, 1, 0, 0, 0, 261, 1264, 1, 0, 0, 0, 263, 1266, 1, 0, 0, 0, 265, 1268, 1, 0, 0, 0, 267, 1270, 1, 0, 0, 0, 269, 1272, 1, 0, 0, 0, 271, 1274, 1, 0, 0, 0, 273, 1276, 1, 0, 0, 0, 275, 1278, 1, 0, 0, 0, 277, 1280, 1, 0, 0, 0, 279, 1282, 1, 0, 0, 0, 281, 1284, 1, 0, 0, 0, 283, 1286, 1, 0, 0, 0, 285, 1288, 1, 0, 0, 0, 287, 1290, 1, 0, 0, 0, 289, 1292, 1, 0, 0, 0, 291, 1295, 1, 0, 0, 0, 293, 1297, 1, 0, 0, 0, 295, 1299, 1, 0, 0, 0, 297, 1301, 1, 0, 0, 0, 299, 1303, 1, 0, 0, 0, 301, 1305, 1, 0, 0, 0, 303, 1308, 1, 0, 0, 0, 305, 1310, 1, 0, 0, 0, 307, 1312, 1, 0, 0, 0, 309, 1314, 1, 0, 0, 0, 311, 1317, 1, 0, 0, 0, 313, 1319, 1, 0, 0, 0, 315, 1322, 1, 0, 0, 0, 317, 1324, 1, 0, 0, 0, 319, 1326, 1, 0, 0, 0, 321, 1329, 1, 0, 0, 0, 323, 1333, 1, 0, 0, 0, 325, 1337, 1, 0, 0, 0, 327, 1339, 1, 0, 0, 0, 329, 1341, 1, 0, 0, 0, 331, 1344, 1, 0, 0, 0, 333, 1350, 1, 0, 0, 0, 335, 1352, 1, 0, 0, 0, 337, 1356, 1, 0, 0, 0, 339, 1359, 1, 0, 0, 0, 341, 1362, 1, 0, 0, 0, 343, 1365, 1, 0, 0, 0, 345, 1367, 1, 0, 0, 0, 347, 1369, 1, 0, 0, 0, 349, 1371, 1, 0, 0, 0, 351, 1373, 1, 0, 0, 0, 353, 1378, 1, 0, 0, 0, 355, 1383, 1, 0, 0, 0, 357, 1385, 1, 0, 0, 0, 359, 1387, 1, 0, 0, 0, 361, 1390, 1, 0, 0, 0, 363, 1394, 1, 0, 0, 0, 365, 1396, 1, 0, 0, 0, 367, 1398, 1, 0, 0, 0, 369, 1400, 1, 0, 0, 0, 371, 1402, 1, 0, 0, 0, 373, 1404, 1, 0, 0, 0, 375, 1422, 1, 0, 0, 0, 377, 1435, 1, 0, 0, 0, 379, 1450, 1, 0, 0, 0, 381, 1454, 1, 0, 0, 0, 383, 1458, 1, 0, 0, 0, 385, 1468, 1, 0, 0, 0, 387, 1472, 1, 0, 0, 0, 389, 390, 3, 229, 113, 0, 390, 391, 3, 251, 124, 0, 391, 392, 3, 251, 124, 0, 392, 4, 1, 0, 0, 0, 393, 394, 3, 229, 113, 0, 394, 395, 3, 255, 126, 0, 395, 396, 3, 235, 116, 0, 396, 6, 1, 0, 0, 0, 397, 398, 3, 229, 113, 0, 398, 399, 3, 255, 126, 0, 399, 400, 3, 267, 132, 0, 400, 401, 3, 245, 121, 0, 401, 8, 1, 0, 0, 0, 402, 403, 3, 229, 113, 0, 403, 404, 3, 255, 126, 0, 404, 405, 3, 277, 137, 0, 405, 10, 1, 0, 0, 0, 406, 407, 3, 229, 113, 0, 407, 408, 3, 263, 130, 0, 408, 409, 3, 263, 130, 0, 409, 410, 3, 229, 113, 0, 410, 411, 3, 277, 137, 0, 411, 12, 1, 0, 0, 0, 412, 413, 3, 229, 113, 0, 413, 414, 3, 265, 131, 0, 414, 14, 1, 0, 0, 0, 415, 416, 3, 229, 113, 0, 416, 417, 3, 265, 131, 0, 417, 418, 3, 233, 115, 0, 418, 430, 1, 0, 0, 0, 419, 420, 3, 229, 113, 0, 420, 421, 3, 265, 131, 0, 421, 422, 3, 233, 115, 0, 422, 423, 3, 237, 117, 0, 423, 424, 3, 255, 126, 0, 424, 425, 3, 235, 116, 0, 425, 426, 3, 245, 121, 0, 426, 427, 3, 255, 126, 0, 427, 428, 3, 241, 119, 0, 428, 430, 1, 0, 0, 0, 429, 415, 1, 0, 0, 0, 429, 419, 1, 0, 0, 0, 430, 16, 1, 0, 0, 0, 431, 432, 3, 229, 113, 0, 432, 433, 3, 265, 131, 0, 433, 434, 3, 257, 127, 0, 434, 435, 3, 239, 118, 0, 435, 18, 1, 0, 0, 0, 436, 437, 3, 231, 114, 0, 437, 438, 3, 237, 117, 0, 438, 439, 3, 267, 132, 0, 439, 440, 3, 273, 135, 0, 440, 441, 3, 237, 117, 0, 441, 442, 3, 237, 117, 0, 442, 443, 3, 255, 126, 0, 443, 20, 1, 0, 0, 0, 444, 445, 3, 231, 114, 0, 445, 446, 3, 257, 127, 0, 446, 447, 3, 267, 132, 0, 447, 448, 3, 243, 120, 0, 448, 22, 1, 0, 0, 0, 449, 450, 3, 231, 114, 0, 450, 451, 3, 277, 137, 0, 451, 24, 1, 0, 0, 0, 452, 453, 3, 233, 115, 0, 453, 454, 3, 229, 113, 0, 454, 455, 3, 265, 131, 0, 455, 456, 3, 237, 117, 0, 456, 26, 1, 0, 0, 0, 457, 458, 3, 233, 115, 0, 458, 459, 3, 229, 113, 0, 459, 460, 3, 265, 131, 0, 460, 461, 3, 267, 132, 0, 461, 28, 1, 0, 0, 0, 462, 463, 3, 233, 115, 0, 463, 464, 3, 229, 113, 0, 464, 465, 3, 267, 132, 0, 465, 466, 3, 233, 115, 0, 466, 467, 3, 243, 120, 0, 467, 30, 1, 0, 0, 0, 468, 469, 3, 233, 115, 0, 469, 470, 3, 257, 127, 0, 470, 471, 3, 243, 120, 0, 471, 472, 3, 257, 127, 0, 472, 473, 3, 263, 130, 0, 473, 474, 3, 267, 132, 0, 474, 32, 1, 0, 0, 0, 475, 476, 3, 233, 115, 0, 476, 477, 3, 257, 127, 0, 477, 478, 3, 251, 124, 0, 478, 479, 3, 251, 124, 0, 479, 480, 3, 229, 113, 0, 480, 481, 3, 267, 132, 0, 481, 482, 3, 237, 117, 0, 482, 34, 1, 0, 0, 0, 483, 484, 3, 233, 115, 0, 484, 485, 3, 263, 130, 0, 485, 486, 3, 257, 127, 0, 486, 487, 3, 265, 131, 0, 487, 488, 3, 265, 131, 0, 488, 36, 1, 0, 0, 0, 489, 490, 3, 233, 115, 0, 490, 491, 3, 269, 133, 0, 491, 492, 3, 231, 114, 0, 492, 493, 3, 237, 117, 0, 493, 38, 1, 0, 0, 0, 494, 495, 3, 233, 115, 0, 495, 496, 3, 269, 133, 0, 496, 497, 3, 263, 130, 0, 497, 498, 3, 263, 130, 0, 498, 499, 3, 237, 117, 0, 499, 500, 3, 255, 126, 0, 500, 501, 3, 267, 132, 0, 501, 40, 1, 0, 0, 0, 502, 503, 3, 235, 116, 0, 503, 504, 3, 229, 113, 0, 504, 505, 3, 267, 132, 0, 505, 506, 3, 237, 117, 0, 506, 42, 1, 0, 0, 0, 507, 508, 3, 235, 116, 0, 508, 509, 3, 229, 113, 0, 509, 510, 3, 277, 137, 0, 510, 44, 1, 0, 0, 0, 511, 512, 3, 235, 116, 0, 512, 513, 3, 237, 117, 0, 513, 514, 3, 265, 131, 0, 514, 515, 3, 233, 115, 0, 515, 46, 1, 0, 0, 0, 516, 517, 3, 235, 116, 0, 517, 518, 3, 237, 117, 0, 518, 519, 3, 265, 131, 0, 519, 520, 3, 233, 115, 0, 520, 521, 3, 237, 117, 0, 521, 522, 3, 255, 126, 0, 522, 523, 3, 235, 116, 0, 523, 524, 3, 245, 121, 0, 524, 525, 3, 255, 126, 0, 525, 526, 3, 241, 119, 0, 526, 48, 1, 0, 0, 0, 527, 528, 3, 235, 116, 0, 528, 529, 3, 245, 121, 0, 529, 530, 3, 265, 131, 0, 530, 531, 3, 267, 132, 0, 531, 532, 3, 245, 121, 0, 532, 533, 3, 255, 126, 0, 533, 534, 3, 233, 115, 0, 534, 535, 3, 267, 132, 0, 535, 50, 1, 0, 0, 0, 536, 537, 3, 237, 117, 0, 537, 538, 3, 251, 124, 0, 538, 539, 3, 265, 131, 0, 539, 540, 3, 237, 117, 0, 540, 52, 1, 0, 0, 0, 541, 542, 3, 237, 117, 0, 542, 543, 3, 255, 126, 0, 543, 544, 3, 235, 116, 0, 544, 54, 1, 0, 0, 0, 545, 546, 3, 237, 117, 0, 546, 547, 3, 275, 136, 0, 547, 548, 3, 233, 115, 0, 548, 549, 3, 237, 117, 0, 549, 550, 3, 259, 128, 0, 550, 551, 3, 267, 132, 0, 551, 56, 1, 0, 0, 0, 552, 553, 3, 237, 117, 0, 553, 554, 3, 275, 136, 0, 554, 555, 3, 267, 132, 0, 555, 556, 3, 263, 130, 0, 556, 557, 3, 229, 113, 0, 557, 558, 3, 233, 115, 0, 558, 559, 3, 267, 132, 0, 559, 58, 1, 0, 0, 0, 560, 561, 3, 239, 118, 0, 561, 562, 3, 245, 121, 0, 562, 563, 3, 255, 126, 0, 563, 564, 3, 229, 113, 0, 564, 565, 3, 251, 124, 0, 565, 60, 1, 0, 0, 0, 566, 567, 3, 239, 118, 0, 567, 568, 3, 245, 121, 0, 568, 569, 3, 255, 126, 0, 569, 570, 3, 229, 113, 0, 570, 571, 3, 251, 124, 0, 571, 572, 3, 251, 124, 0, 572, 573, 3, 277, 137, 0, 573, 62, 1, 0, 0, 0, 574, 575, 3, 239, 118, 0, 575, 576, 3, 245, 121, 0, 576, 577, 3, 263, 130, 0, 577, 578, 3, 265, 131, 0, 578, 579, 3, 267, 132, 0, 579, 64, 1, 0, 0, 0, 580, 581, 3, 239, 118, 0, 581, 582, 3, 255, 126, 0, 582, 66, 1, 0, 0, 0, 583, 584, 3, 239, 118, 0, 584, 585, 3, 257, 127, 0, 585, 586, 3, 251, 124, 0, 586, 587, 3, 251, 124, 0, 587, 588, 3, 257, 127, 0, 588, 589, 3, 273, 135, 0, 589, 590, 3, 245, 121, 0, 590, 591, 3, 255, 126, 0, 591, 592, 3, 241, 119, 0, 592, 68, 1, 0, 0, 0, 593, 594, 3, 239, 118, 0, 594, 595, 3, 257, 127, 0, 595, 596, 3, 263, 130, 0, 596, 70, 1, 0, 0, 0, 597, 598, 3, 239, 118, 0, 598, 599, 3, 263, 130, 0, 599, 600, 3, 257, 127, 0, 600, 601, 3, 253, 125, 0, 601, 72, 1, 0, 0, 0, 602, 603, 3, 239, 118, 0, 603, 604, 3, 269, 133, 0, 604, 605, 3, 251, 124, 0, 605, 606, 3, 251, 124, 0, 606, 74, 1, 0, 0, 0, 607, 608, 3, 239, 118, 0, 608, 609, 3, 269, 133, 0, 609, 610, 3, 255, 126, 0, 610, 76, 1, 0, 0, 0, 611, 612, 3, 241, 119, 0, 612, 613, 3, 263, 130, 0, 613, 614, 3, 257, 127, 0, 614, 615, 3, 269, 133, 0, 615, 616, 3, 259, 128, 0, 616, 78, 1, 0, 0, 0, 617, 618, 3, 243, 120, 0, 618, 619, 3, 229, 113, 0, 619, 620, 3, 271, 134, 0, 620, 621, 3, 245, 121, 0, 621, 622, 3, 255, 126, 0, 622, 623, 3, 241, 119, 0, 623, 80, 1, 0, 0, 0, 624, 625, 3, 243, 120, 0, 625, 626, 3, 257, 127, 0, 626, 627, 3, 269, 133, 0, 627, 628, 3, 263, 130, 0, 628, 82, 1, 0, 0, 0, 629, 630, 3, 245, 121, 0, 630, 631, 3, 235, 116, 0, 631, 84, 1, 0, 0, 0, 632, 633, 3, 245, 121, 0, 633, 634, 3, 239, 118, 0, 634, 86, 1, 0, 0, 0, 635, 636, 3, 245, 121, 0, 636, 637, 3, 251, 124, 0, 637, 638, 3, 245, 121, 0, 638, 639, 3, 249, 123, 0, 639, 640, 3, 237, 117, 0, 640, 88, 1, 0, 0, 0, 641, 642, 3, 245, 121, 0, 642, 643, 3, 255, 126, 0, 643, 90, 1, 0, 0, 0, 644, 645, 3, 245, 121, 0, 645, 646, 3, 255, 126, 0, 646, 647, 3, 239, 118, 0, 647, 658, 1, 0, 0, 0, 648, 649, 3, 245, 121, 0, 649, 650, 3, 255, 126, 0, 650, 651, 3, 239, 118, 0, 651, 652, 3, 245, 121, 0, 652, 653, 3, 255, 126, 0, 653, 654, 3, 245, 121, 0, 654, 655, 3, 267, 132, 0, 655, 656, 3, 277, 137, 0, 656, 658, 1, 0, 0, 0, 657, 644, 1, 0, 0, 0, 657, 648, 1, 0, 0, 0, 658, 92, 1, 0, 0, 0, 659, 660, 3, 245, 121, 0, 660, 661, 3, 255, 126, 0, 661, 662, 3, 255, 126, 0, 662, 663, 3, 237, 117, 0, 663, 664, 3, 263, 130, 0, 664, 94, 1, 0, 0, 0, 665, 666, 3, 245, 121, 0, 666, 667, 3, 255, 126, 0, 667, 668, 3, 267, 132, 0, 668, 669, 3, 237, 117, 0, 669, 670, 3, 263, 130, 0, 670, 671, 3, 265, 131, 0, 671, 672, 3, 237, 117, 0, 672, 673, 3, 233, 115, 0, 673, 674, 3, 267, 132, 0, 674, 96, 1, 0, 0, 0, 675, 676, 3, 245, 121, 0, 676, 677, 3, 255, 126, 0, 677, 678, 3, 267, 132, 0, 678, 679, 3, 237, 117, 0, 679, 680, 3, 263, 130, 0, 680, 681, 3, 271, 134, 0, 681, 682, 3, 229, 113, 0, 682, 683, 3, 251, 124, 0, 683, 98, 1, 0, 0, 0, 684, 685, 3, 245, 121, 0, 685, 686, 3, 265, 131, 0, 686, 100, 1, 0, 0, 0, 687, 688, 3, 247, 122, 0, 688, 689, 3, 257, 127, 0, 689, 690, 3, 245, 121, 0, 690, 691, 3, 255, 126, 0, 691, 102, 1, 0, 0, 0, 692, 693, 3, 249, 123, 0, 693, 694, 3, 237, 117, 0, 694, 695, 3, 277, 137, 0, 695, 104, 1, 0, 0, 0, 696, 697, 3, 251, 124, 0, 697, 698, 3, 229, 113, 0, 698, 699, 3, 265, 131, 0, 699, 700, 3, 267, 132, 0, 700, 106, 1, 0, 0, 0, 701, 702, 3, 251, 124, 0, 702, 703, 3, 237, 117, 0, 703, 704, 3, 229, 113, 0, 704, 705, 3, 235, 116, 0, 705, 706, 3, 245, 121, 0, 706, 707, 3, 255, 126, 0, 707, 708, 3, 241, 119, 0, 708, 108, 1, 0, 0, 0, 709, 710, 3, 251, 124, 0, 710, 711, 3, 237, 117, 0, 711, 712, 3, 239, 118, 0, 712, 713, 3, 267, 132, 0, 713, 110, 1, 0, 0, 0, 714, 715, 3, 251, 124, 0, 715, 716, 3, 237, 117, 0, 716, 717, 3, 267, 132, 0, 717, 112, 1, 0, 0, 0, 718, 719, 3, 251, 124, 0, 719, 720, 3, 245, 121, 0, 720, 721, 3, 249, 123, 0, 721, 722, 3, 237, 117, 0, 722, 114, 1, 0, 0, 0, 723, 724, 3, 251, 124, 0, 724, 725, 3, 245, 121, 0, 725, 726, 3, 253, 125, 0, 726, 727, 3, 245, 121, 0, 727, 728, 3, 267, 132, 0, 728, 116, 1, 0, 0, 0, 729, 730, 3, 253, 125, 0, 730, 731, 3, 245, 121, 0, 731, 732, 3, 255, 126, 0, 732, 733, 3, 269, 133, 0, 733, 734, 3, 267, 132, 0, 734, 735, 3, 237, 117, 0, 735, 118, 1, 0, 0, 0, 736, 737, 3, 253, 125, 0, 737, 738, 3, 257, 127, 0, 738, 739, 3, 255, 126, 0, 739, 740, 3, 267, 132, 0, 740, 741, 3, 243, 120, 0, 741, 120, 1, 0, 0, 0, 742, 743, 3, 255, 126, 0, 743, 744, 3, 229, 113, 0, 744, 745, 3, 255, 126, 0, 745, 122, 1, 0, 0, 0, 746, 747, 3, 255, 126, 0, 747, 748, 3, 257, 127, 0, 748, 749, 3, 267, 132, 0, 749, 124, 1, 0, 0, 0, 750, 751, 3, 255, 126, 0, 751, 752, 3, 269, 133, 0, 752, 753, 3, 251, 124, 0, 753, 754, 3, 251, 124, 0, 754, 126, 1, 0, 0, 0, 755, 756, 3, 255, 126, 0, 756, 757, 3, 269, 133, 0, 757, 758, 3, 251, 124, 0, 758, 759, 3, 251, 124, 0, 759, 760, 3, 265, 131, 0, 760, 128, 1, 0, 0, 0, 761, 762, 3, 257, 127, 0, 762, 763, 3, 239, 118, 0, 763, 764, 3, 239, 118, 0, 764, 765, 3, 265, 131, 0, 765, 766, 3, 237, 117, 0, 766, 767, 3, 267, 132, 0, 767, 130, 1, 0, 0, 0, 768, 769, 3, 257, 127, 0, 769, 770, 3, 255, 126, 0, 770, 132, 1, 0, 0, 0, 771, 772, 3, 257, 127, 0, 772, 773, 3, 263, 130, 0, 773, 134, 1, 0, 0, 0, 774, 775, 3, 257, 127, 0, 775, 776, 3, 263, 130, 0, 776, 777, 3, 235, 116, 0, 777, 778, 3, 237, 117, 0, 778, 779, 3, 263, 130, 0, 779, 136, 1, 0, 0, 0, 780, 781, 3, 257, 127, 0, 781, 782, 3, 269, 133, 0, 782, 783, 3, 267, 132, 0, 783, 784, 3, 237, 117, 0, 784, 785, 3, 263, 130, 0, 785, 138, 1, 0, 0, 0, 786, 787, 3, 257, 127, 0, 787, 788, 3, 271, 134, 0, 788, 789, 3, 237, 117, 0, 789, 790, 3, 263, 130, 0, 790, 140, 1, 0, 0, 0, 791, 792, 3, 259, 128, 0, 792, 793, 3, 229, 113, 0, 793, 794, 3, 263, 130, 0, 794, 795, 3, 267, 132, 0, 795, 796, 3, 245, 121, 0, 796, 797, 3, 267, 132, 0, 797, 798, 3, 245, 121, 0, 798, 799, 3, 257, 127, 0, 799, 800, 3, 255, 126, 0, 800, 142, 1, 0, 0, 0, 801, 802, 3, 259, 128, 0, 802, 803, 3, 263, 130, 0, 803, 804, 3, 237, 117, 0, 804, 805, 3, 233, 115, 0, 805, 806, 3, 237, 117, 0, 806, 807, 3, 235, 116, 0, 807, 808, 3, 245, 121, 0, 808, 809, 3, 255, 126, 0, 809, 810, 3, 241, 119, 0, 810, 144, 1, 0, 0, 0, 811, 812, 3, 259, 128, 0, 812, 813, 3, 263, 130, 0, 813, 814, 3, 237, 117, 0, 814, 815, 3, 273, 135, 0, 815, 816, 3, 243, 120, 0, 816, 817, 3, 237, 117, 0, 817, 818, 3, 263, 130, 0, 818, 819, 3, 237, 117, 0, 819, 146, 1, 0, 0, 0, 820, 821, 3, 261, 129, 0, 821, 822, 3, 269, 133, 0, 822, 823, 3, 229, 113, 0, 823, 824, 3, 263, 130, 0, 824, 825, 3, 267, 132, 0, 825, 826, 3, 237, 117, 0, 826, 827, 3, 263, 130, 0, 827, 148, 1, 0, 0, 0, 828, 829, 3, 263, 130, 0, 829, 830, 3, 229, 113, 0, 830, 831, 3, 255, 126, 0, 831, 832, 3, 241, 119, 0, 832, 833, 3, 237, 117, 0, 833, 150, 1, 0, 0, 0, 834, 835, 3, 263, 130, 0, 835, 836, 3, 237, 117, 0, 836, 837, 3, 267, 132, 0, 837, 838, 3, 269, 133, 0, 838, 839, 3, 263, 130, 0, 839, 840, 3, 255, 126, 0, 840, 152, 1, 0, 0, 0, 841, 842, 3, 263, 130, 0, 842, 843, 3, 245, 121, 0, 843, 844, 3, 241, 119, 0, 844, 845, 3, 243, 120, 0, 845, 846, 3, 267, 132, 0, 846, 154, 1, 0, 0, 0, 847, 848, 3, 263, 130, 0, 848, 849, 3, 257, 127, 0, 849, 850, 3, 251, 124, 0, 850, 851, 3, 251, 124, 0, 851, 852, 3, 269, 133, 0, 852, 853, 3, 259, 128, 0, 853, 156, 1, 0, 0, 0, 854, 855, 3, 263, 130, 0, 855, 856, 3, 257, 127, 0, 856, 857, 3, 273, 135, 0, 857, 158, 1, 0, 0, 0, 858, 859, 3, 263, 130, 0, 859, 860, 3, 257, 127, 0, 860, 861, 3, 273, 135, 0, 861, 862, 3, 265, 131, 0, 862, 160, 1, 0, 0, 0, 863, 864, 3, 265, 131, 0, 864, 865, 3, 229, 113, 0, 865, 866, 3, 253, 125, 0, 866, 867, 3, 259, 128, 0, 867, 868, 3, 251, 124, 0, 868, 869, 3, 237, 117, 0, 869, 162, 1, 0, 0, 0, 870, 871, 3, 265, 131, 0, 871, 872, 3, 237, 117, 0, 872, 873, 3, 233, 115, 0, 873, 874, 3, 257, 127, 0, 874, 875, 3, 255, 126, 0, 875, 876, 3, 235, 116, 0, 876, 164, 1, 0, 0, 0, 877, 878, 3, 265, 131, 0, 878, 879, 3, 237, 117, 0, 879, 880, 3, 251, 124, 0, 880, 881, 3, 237, 117, 0, 881, 882, 3, 233, 115, 0, 882, 883, 3, 267, 132, 0, 883, 166, 1, 0, 0, 0, 884, 885, 3, 265, 131, 0, 885, 886, 3, 237, 117, 0, 886, 887, 3, 253, 125, 0, 887, 888, 3, 245, 121, 0, 888, 168, 1, 0, 0, 0, 889, 890, 3, 265, 131, 0, 890, 891, 3, 237, 117, 0, 891, 892, 3, 267, 132, 0, 892, 893, 3, 267, 132, 0, 893, 894, 3, 245, 121, 0, 894, 895, 3, 255, 126, 0, 895, 896, 3, 241, 119, 0, 896, 897, 3, 265, 131, 0, 897, 170, 1, 0, 0, 0, 898, 899, 3, 265, 131, 0, 899, 900, 3, 269, 133, 0, 900, 901, 3, 231, 114, 0, 901, 902, 3, 265, 131, 0, 902, 903, 3, 267, 132, 0, 903, 904, 3, 263, 130, 0, 904, 905, 3, 245, 121, 0, 905, 906, 3, 255, 126, 0, 906, 907, 3, 241, 119, 0, 907, 172, 1, 0, 0, 0, 908, 909, 3, 267, 132, 0, 909, 910, 3, 243, 120, 0, 910, 911, 3, 237, 117, 0, 911, 912, 3, 255, 126, 0, 912, 174, 1, 0, 0, 0, 913, 914, 3, 267, 132, 0, 914, 915, 3, 243, 120, 0, 915, 916, 3, 263, 130, 0, 916, 917, 3, 257, 127, 0, 917, 918, 3, 273, 135, 0, 918, 176, 1, 0, 0, 0, 919, 920, 3, 267, 132, 0, 920, 921, 3, 245, 121, 0, 921, 922, 3, 237, 117, 0, 922, 923, 3, 265, 131, 0, 923, 178, 1, 0, 0, 0, 924, 925, 3, 267, 132, 0, 925, 926, 3, 245, 121, 0, 926, 927, 3, 253, 125, 0, 927, 928, 3, 237, 117, 0, 928, 929, 3, 265, 131, 0, 929, 930, 3, 267, 132, 0, 930, 931, 3, 229, 113, 0, 931, 932, 3, 253, 125, 0, 932, 933, 3, 259, 128, 0, 933, 180, 1, 0, 0, 0, 934, 935, 3, 267, 132, 0, 935, 936, 3, 257, 127, 0, 936, 182, 1, 0, 0, 0, 937, 938, 3, 267, 132, 0, 938, 939, 3, 257, 127, 0, 939, 940, 3, 259, 128, 0, 940, 184, 1, 0, 0, 0, 941, 942, 3, 267, 132, 0, 942, 943, 3, 257, 127, 0, 943, 944, 3, 267, 132, 0, 944, 945, 3, 229, 113, 0, 945, 946, 3, 251, 124, 0, 946, 947, 3, 265, 131, 0, 947, 186, 1, 0, 0, 0, 948, 949, 3, 267, 132, 0, 949, 950, 3, 263, 130, 0, 950, 951, 3, 229, 113, 0, 951, 952, 3, 245, 121, 0, 952, 953, 3, 251, 124, 0, 953, 954, 3, 245, 121, 0, 954, 955, 3, 255, 126, 0, 955, 956, 3, 241, 119, 0, 956, 188, 1, 0, 0, 0, 957, 958, 3, 267, 132, 0, 958, 959, 3, 263, 130, 0, 959, 960, 3, 245, 121, 0, 960, 961, 3, 253, 125, 0, 961, 190, 1, 0, 0, 0, 962, 963, 3, 267, 132, 0, 963, 964, 3, 263, 130, 0, 964, 965, 3, 269, 133, 0, 965, 966, 3, 255, 126, 0, 966, 967, 3, 233, 115, 0, 967, 968, 3, 229, 113, 0, 968, 969, 3, 267, 132, 0, 969, 970, 3, 237, 117, 0, 970, 192, 1, 0, 0, 0, 971, 972, 3, 267, 132, 0, 972, 973, 3, 263, 130, 0, 973, 974, 3, 277, 137, 0, 974, 194, 1, 0, 0, 0, 975, 976, 3, 269, 133, 0, 976, 977, 3, 255, 126, 0, 977, 978, 3, 231, 114, 0, 978, 979, 3, 257, 127, 0, 979, 980, 3, 269, 133, 0, 980, 981, 3, 255, 126, 0, 981, 982, 3, 235, 116, 0, 982, 983, 3, 237, 117, 0, 983, 984, 3, 235, 116, 0, 984, 196, 1, 0, 0, 0, 985, 986, 3, 269, 133, 0, 986, 987, 3, 255, 126, 0, 987, 988, 3, 245, 121, 0, 988, 989, 3, 257, 127, 0, 989, 990, 3, 255, 126, 0, 990, 198, 1, 0, 0, 0, 991, 992, 3, 269, 133, 0, 992, 993, 3, 265, 131, 0, 993, 994, 3, 245, 121, 0, 994, 995, 3, 255, 126, 0, 995, 996, 3, 241, 119, 0, 996, 200, 1, 0, 0, 0, 997, 998, 3, 273, 135, 0, 998, 999, 3, 237, 117, 0, 999, 1000, 3, 237, 117, 0, 1000, 1001, 3, 249, 123, 0, 1001, 202, 1, 0, 0, 0, 1002, 1003, 3, 273, 135, 0, 1003, 1004, 3, 243, 120, 0, 1004, 1005, 3, 237, 117, 0, 1005, 1006, 3, 255, 126, 0, 1006, 204, 1, 0, 0, 0, 1007, 1008, 3, 273, 135, 0, 1008, 1009, 3, 243, 120, 0, 1009, 1010, 3, 237, 117, 0, 1010, 1011, 3, 263, 130, 0, 1011, 1012, 3, 237, 117, 0, 1012, 206, 1, 0, 0, 0, 1013, 1014, 3, 273, 135, 0, 1014, 1015, 3, 243, 120, 0, 1015, 1016, 3, 245, 121, 0, 1016, 1017, 3, 251, 124, 0, 1017, 1018, 3, 237, 117, 0, 1018, 208, 1, 0, 0, 0, 1019, 1020, 3, 273, 135, 0, 1020, 1021, 3, 245, 121, 0, 1021, 1022, 3, 255, 126, 0, 1022, 1023, 3, 235, 116, 0, 1023, 1024, 3, 257, 127, 0, 1024, 1025, 3, 273, 135, 0, 1025, 210, 1, 0, 0, 0, 1026, 1027, 3, 273, 135, 0, 1027, 1028, 3, 245, 121, 0, 1028, 1029, 3, 267, 132, 0, 1029, 1030, 3, 243, 120, 0, 1030, 212, 1, 0, 0, 0, 1031, 1032, 3, 277, 137, 0, 1032, 1033, 3, 237, 117, 0, 1033, 1034, 3, 229, 113, 0, 1034, 1035, 3, 263, 130, 0, 1035, 1042, 1, 0, 0, 0, 1036, 1037, 3, 277, 137, 0, 1037, 1038, 3, 277, 137, 0, 1038, 1039, 3, 277, 137, 0, 1039, 1040, 3, 277, 137, 0, 1040, 1042, 1, 0, 0, 0, 1041, 1031, 1, 0, 0, 0, 1041, 1036, 1, 0, 0, 0, 1042, 214, 1, 0, 0, 0, 1043, 1044, 3, 295, 146, 0, 1044, 1045, 3, 231, 114, 0, 1045, 1071, 1, 0, 0, 0, 1046, 1047, 3, 295, 146, 0, 1047, 1048, 3, 239, 118, 0, 1048, 1071, 1, 0, 0, 0, 1049, 1050, 3, 295, 146, 0, 1050, 1051, 3, 263, 130, 0, 1051, 1071, 1, 0, 0, 0, 1052, 1053, 3, 295, 146, 0, 1053, 1054, 3, 255, 126, 0, 1054, 1071, 1, 0, 0, 0, 1055, 1056, 3, 295, 146, 0, 1056, 1057, 3, 267, 132, 0, 1057, 1071, 1, 0, 0, 0, 1058, 1059, 3, 295, 146, 0, 1059, 1060, 5, 48, 0, 0, 1060, 1071, 1, 0, 0, 0, 1061, 1062, 3, 295, 146, 0, 1062, 1063, 3, 229, 113, 0, 1063, 1071, 1, 0, 0, 0, 1064, 1065, 3, 295, 146, 0, 1065, 1066, 3, 271, 134, 0, 1066, 1071, 1, 0, 0, 0, 1067, 1068, 3, 295, 146, 0, 1068, 1069, 3, 295, 146, 0, 1069, 1071, 1, 0, 0, 0, 1070, 1043, 1, 0, 0, 0, 1070, 1046, 1, 0, 0, 0, 1070, 1049, 1, 0, 0, 0, 1070, 1052, 1, 0, 0, 0, 1070, 1055, 1, 0, 0, 0, 1070, 1058, 1, 0, 0, 0, 1070, 1061, 1, 0, 0, 0, 1070, 1064, 1, 0, 0, 0, 1070, 1067, 1, 0, 0, 0, 1071, 216, 1, 0, 0, 0, 1072, 1076, 3, 281, 139, 0, 1073, 1076, 3, 371, 184, 0, 1074, 1076, 3, 305, 151, 0, 1075, 1072, 1, 0, 0, 0, 1075, 1073, 1, 0, 0, 0, 1075, 1074, 1, 0, 0, 0, 1076, 1083, 1, 0, 0, 0, 1077, 1082, 3, 281, 139, 0, 1078, 1082, 3, 371, 184, 0, 1079, 1082, 3, 285, 141, 0, 1080, 1082, 3, 305, 151, 0, 1081, 1077, 1, 0, 0, 0, 1081, 1078, 1, 0, 0, 0, 1081, 1079, 1, 0, 0, 0, 1081, 1080, 1, 0, 0, 0, 1082, 1085, 1, 0, 0, 0, 1083, 1081, 1, 0, 0, 0, 1083, 1084, 1, 0, 0, 0, 1084, 1119, 1, 0, 0, 0, 1085, 1083, 1, 0, 0, 0, 1086, 1097, 3, 293, 145, 0, 1087, 1096, 8, 0, 0, 0, 1088, 1096, 3, 215, 106, 0, 1089, 1090, 3, 295, 146, 0, 1090, 1091, 3, 355, 176, 0, 1091, 1096, 1, 0, 0, 0, 1092, 1093, 3, 293, 145, 0, 1093, 1094, 3, 293, 145, 0, 1094, 1096, 1, 0, 0, 0, 1095, 1087, 1, 0, 0, 0, 1095, 1088, 1, 0, 0, 0, 1095, 1089, 1, 0, 0, 0, 1095, 1092, 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, 1101, 3, 293, 145, 0, 1101, 1119, 1, 0, 0, 0, 1102, 1113, 3, 349, 173, 0, 1103, 1112, 8, 1, 0, 0, 1104, 1112, 3, 215, 106, 0, 1105, 1106, 3, 295, 146, 0, 1106, 1107, 3, 349, 173, 0, 1107, 1112, 1, 0, 0, 0, 1108, 1109, 3, 349, 173, 0, 1109, 1110, 3, 349, 173, 0, 1110, 1112, 1, 0, 0, 0, 1111, 1103, 1, 0, 0, 0, 1111, 1104, 1, 0, 0, 0, 1111, 1105, 1, 0, 0, 0, 1111, 1108, 1, 0, 0, 0, 1112, 1115, 1, 0, 0, 0, 1113, 1111, 1, 0, 0, 0, 1113, 1114, 1, 0, 0, 0, 1114, 1116, 1, 0, 0, 0, 1115, 1113, 1, 0, 0, 0, 1116, 1117, 3, 349, 173, 0, 1117, 1119, 1, 0, 0, 0, 1118, 1075, 1, 0, 0, 0, 1118, 1086, 1, 0, 0, 0, 1118, 1102, 1, 0, 0, 0, 1119, 218, 1, 0, 0, 0, 1120, 1121, 3, 225, 111, 0, 1121, 1125, 3, 307, 152, 0, 1122, 1124, 3, 287, 142, 0, 1123, 1122, 1, 0, 0, 0, 1124, 1127, 1, 0, 0, 0, 1125, 1123, 1, 0, 0, 0, 1125, 1126, 1, 0, 0, 0, 1126, 1130, 1, 0, 0, 0, 1127, 1125, 1, 0, 0, 0, 1128, 1131, 3, 259, 128, 0, 1129, 1131, 3, 237, 117, 0, 1130, 1128, 1, 0, 0, 0, 1130, 1129, 1, 0, 0, 0, 1131, 1134, 1, 0, 0, 0, 1132, 1135, 3, 345, 171, 0, 1133, 1135, 3, 303, 150, 0, 1134, 1132, 1, 0, 0, 0, 1134, 1133, 1, 0, 0, 0, 1134, 1135, 1, 0, 0, 0, 1135, 1137, 1, 0, 0, 0, 1136, 1138, 3, 285, 141, 0, 1137, 1136, 1, 0, 0, 0, 1138, 1139, 1, 0, 0, 0, 1139, 1137, 1, 0, 0, 0, 1139, 1140, 1, 0, 0, 0, 1140, 1197, 1, 0, 0, 0, 1141, 1144, 3, 225, 111, 0, 1142, 1145, 3, 259, 128, 0, 1143, 1145, 3, 237, 117, 0, 1144, 1142, 1, 0, 0, 0, 1144, 1143, 1, 0, 0, 0, 1145, 1148, 1, 0, 0, 0, 1146, 1149, 3, 345, 171, 0, 1147, 1149, 3, 303, 150, 0, 1148, 1146, 1, 0, 0, 0, 1148, 1147, 1, 0, 0, 0, 1148, 1149, 1, 0, 0, 0, 1149, 1151, 1, 0, 0, 0, 1150, 1152, 3, 285, 141, 0, 1151, 1150, 1, 0, 0, 0, 1152, 1153, 1, 0, 0, 0, 1153, 1151, 1, 0, 0, 0, 1153, 1154, 1, 0, 0, 0, 1154, 1197, 1, 0, 0, 0, 1155, 1156, 3, 223, 110, 0, 1156, 1160, 3, 307, 152, 0, 1157, 1159, 3, 285, 141, 0, 1158, 1157, 1, 0, 0, 0, 1159, 1162, 1, 0, 0, 0, 1160, 1158, 1, 0, 0, 0, 1160, 1161, 1, 0, 0, 0, 1161, 1163, 1, 0, 0, 0, 1162, 1160, 1, 0, 0, 0, 1163, 1166, 3, 237, 117, 0, 1164, 1167, 3, 345, 171, 0, 1165, 1167, 3, 303, 150, 0, 1166, 1164, 1, 0, 0, 0, 1166, 1165, 1, 0, 0, 0, 1166, 1167, 1, 0, 0, 0, 1167, 1169, 1, 0, 0, 0, 1168, 1170, 3, 285, 141, 0, 1169, 1168, 1, 0, 0, 0, 1170, 1171, 1, 0, 0, 0, 1171, 1169, 1, 0, 0, 0, 1171, 1172, 1, 0, 0, 0, 1172, 1197, 1, 0, 0, 0, 1173, 1174, 3, 307, 152, 0, 1174, 1175, 3, 223, 110, 0, 1175, 1178, 3, 237, 117, 0, 1176, 1179, 3, 345, 171, 0, 1177, 1179, 3, 303, 150, 0, 1178, 1176, 1, 0, 0, 0, 1178, 1177, 1, 0, 0, 0, 1178, 1179, 1, 0, 0, 0, 1179, 1181, 1, 0, 0, 0, 1180, 1182, 3, 285, 141, 0, 1181, 1180, 1, 0, 0, 0, 1182, 1183, 1, 0, 0, 0, 1183, 1181, 1, 0, 0, 0, 1183, 1184, 1, 0, 0, 0, 1184, 1197, 1, 0, 0, 0, 1185, 1186, 3, 223, 110, 0, 1186, 1189, 3, 237, 117, 0, 1187, 1190, 3, 345, 171, 0, 1188, 1190, 3, 303, 150, 0, 1189, 1187, 1, 0, 0, 0, 1189, 1188, 1, 0, 0, 0, 1189, 1190, 1, 0, 0, 0, 1190, 1192, 1, 0, 0, 0, 1191, 1193, 3, 285, 141, 0, 1192, 1191, 1, 0, 0, 0, 1193, 1194, 1, 0, 0, 0, 1194, 1192, 1, 0, 0, 0, 1194, 1195, 1, 0, 0, 0, 1195, 1197, 1, 0, 0, 0, 1196, 1120, 1, 0, 0, 0, 1196, 1141, 1, 0, 0, 0, 1196, 1155, 1, 0, 0, 0, 1196, 1173, 1, 0, 0, 0, 1196, 1185, 1, 0, 0, 0, 1197, 220, 1, 0, 0, 0, 1198, 1200, 5, 48, 0, 0, 1199, 1201, 3, 283, 140, 0, 1200, 1199, 1, 0, 0, 0, 1201, 1202, 1, 0, 0, 0, 1202, 1200, 1, 0, 0, 0, 1202, 1203, 1, 0, 0, 0, 1203, 222, 1, 0, 0, 0, 1204, 1206, 3, 285, 141, 0, 1205, 1204, 1, 0, 0, 0, 1206, 1207, 1, 0, 0, 0, 1207, 1205, 1, 0, 0, 0, 1207, 1208, 1, 0, 0, 0, 1208, 224, 1, 0, 0, 0, 1209, 1210, 5, 48, 0, 0, 1210, 1212, 3, 275, 136, 0, 1211, 1213, 3, 287, 142, 0, 1212, 1211, 1, 0, 0, 0, 1213, 1214, 1, 0, 0, 0, 1214, 1212, 1, 0, 0, 0, 1214, 1215, 1, 0, 0, 0, 1215, 226, 1, 0, 0, 0, 1216, 1227, 3, 355, 176, 0, 1217, 1226, 8, 2, 0, 0, 1218, 1226, 3, 215, 106, 0, 1219, 1220, 3, 295, 146, 0, 1220, 1221, 3, 355, 176, 0, 1221, 1226, 1, 0, 0, 0, 1222, 1223, 3, 355, 176, 0, 1223, 1224, 3, 355, 176, 0, 1224, 1226, 1, 0, 0, 0, 1225, 1217, 1, 0, 0, 0, 1225, 1218, 1, 0, 0, 0, 1225, 1219, 1, 0, 0, 0, 1225, 1222, 1, 0, 0, 0, 1226, 1229, 1, 0, 0, 0, 1227, 1225, 1, 0, 0, 0, 1227, 1228, 1, 0, 0, 0, 1228, 1230, 1, 0, 0, 0, 1229, 1227, 1, 0, 0, 0, 1230, 1231, 3, 355, 176, 0, 1231, 228, 1, 0, 0, 0, 1232, 1233, 7, 3, 0, 0, 1233, 230, 1, 0, 0, 0, 1234, 1235, 7, 4, 0, 0, 1235, 232, 1, 0, 0, 0, 1236, 1237, 7, 5, 0, 0, 1237, 234, 1, 0, 0, 0, 1238, 1239, 7, 6, 0, 0, 1239, 236, 1, 0, 0, 0, 1240, 1241, 7, 7, 0, 0, 1241, 238, 1, 0, 0, 0, 1242, 1243, 7, 8, 0, 0, 1243, 240, 1, 0, 0, 0, 1244, 1245, 7, 9, 0, 0, 1245, 242, 1, 0, 0, 0, 1246, 1247, 7, 10, 0, 0, 1247, 244, 1, 0, 0, 0, 1248, 1249, 7, 11, 0, 0, 1249, 246, 1, 0, 0, 0, 1250, 1251, 7, 12, 0, 0, 1251, 248, 1, 0, 0, 0, 1252, 1253, 7, 13, 0, 0, 1253, 250, 1, 0, 0, 0, 1254, 1255, 7, 14, 0, 0, 1255, 252, 1, 0, 0, 0, 1256, 1257, 7, 15, 0, 0, 1257, 254, 1, 0, 0, 0, 1258, 1259, 7, 16, 0, 0, 1259, 256, 1, 0, 0, 0, 1260, 1261, 7, 17, 0, 0, 1261, 258, 1, 0, 0, 0, 1262, 1263, 7, 18, 0, 0, 1263, 260, 1, 0, 0, 0, 1264, 1265, 7, 19, 0, 0, 1265, 262, 1, 0, 0, 0, 1266, 1267, 7, 20, 0, 0, 1267, 264, 1, 0, 0, 0, 1268, 1269, 7, 21, 0, 0, 1269, 266, 1, 0, 0, 0, 1270, 1271, 7, 22, 0, 0, 1271, 268, 1, 0, 0, 0, 1272, 1273, 7, 23, 0, 0, 1273, 270, 1, 0, 0, 0, 1274, 1275, 7, 24, 0, 0, 1275, 272, 1, 0, 0, 0, 1276, 1277, 7, 25, 0, 0, 1277, 274, 1, 0, 0, 0, 1278, 1279, 7, 26, 0, 0, 1279, 276, 1, 0, 0, 0, 1280, 1281, 7, 27, 0, 0, 1281, 278, 1, 0, 0, 0, 1282, 1283, 7, 28, 0, 0, 1283, 280, 1, 0, 0, 0, 1284, 1285, 7, 29, 0, 0, 1285, 282, 1, 0, 0, 0, 1286, 1287, 7, 30, 0, 0, 1287, 284, 1, 0, 0, 0, 1288, 1289, 7, 31, 0, 0, 1289, 286, 1, 0, 0, 0, 1290, 1291, 7, 32, 0, 0, 1291, 288, 1, 0, 0, 0, 1292, 1293, 5, 45, 0, 0, 1293, 1294, 5, 62, 0, 0, 1294, 290, 1, 0, 0, 0, 1295, 1296, 5, 42, 0, 0, 1296, 292, 1, 0, 0, 0, 1297, 1298, 5, 96, 0, 0, 1298, 294, 1, 0, 0, 0, 1299, 1300, 5, 92, 0, 0, 1300, 296, 1, 0, 0, 0, 1301, 1302, 5, 58, 0, 0, 1302, 298, 1, 0, 0, 0, 1303, 1304, 5, 44, 0, 0, 1304, 300, 1, 0, 0, 0, 1305, 1306, 5, 124, 0, 0, 1306, 1307, 5, 124, 0, 0, 1307, 302, 1, 0, 0, 0, 1308, 1309, 5, 45, 0, 0, 1309, 304, 1, 0, 0, 0, 1310, 1311, 5, 36, 0, 0, 1311, 306, 1, 0, 0, 0, 1312, 1313, 5, 46, 0, 0, 1313, 308, 1, 0, 0, 0, 1314, 1315, 5, 61, 0, 0, 1315, 1316, 5, 61, 0, 0, 1316, 310, 1, 0, 0, 0, 1317, 1318, 5, 61, 0, 0, 1318, 312, 1, 0, 0, 0, 1319, 1320, 5, 62, 0, 0, 1320, 1321, 5, 61, 0, 0, 1321, 314, 1, 0, 0, 0, 1322, 1323, 5, 62, 0, 0, 1323, 316, 1, 0, 0, 0, 1324, 1325, 5, 35, 0, 0, 1325, 318, 1, 0, 0, 0, 1326, 1327, 5, 126, 0, 0, 1327, 1328, 5, 42, 0, 0, 1328, 320, 1, 0, 0, 0, 1329, 1330, 5, 61, 0, 0, 1330, 1331, 5, 126, 0, 0, 1331, 1332, 5, 42, 0, 0, 1332, 322, 1, 0, 0, 0, 1333, 1334, 5, 123, 0, 0, 1334, 1335, 1, 0, 0, 0, 1335, 1336, 6, 160, 0, 0, 1336, 324, 1, 0, 0, 0, 1337, 1338, 5, 91, 0, 0, 1338, 326, 1, 0, 0, 0, 1339, 1340, 5, 40, 0, 0, 1340, 328, 1, 0, 0, 0, 1341, 1342, 5, 60, 0, 0, 1342, 1343, 5, 61, 0, 0, 1343, 330, 1, 0, 0, 0, 1344, 1345, 5, 60, 0, 0, 1345, 332, 1, 0, 0, 0, 1346, 1347, 5, 33, 0, 0, 1347, 1351, 5, 61, 0, 0, 1348, 1349, 5, 60, 0, 0, 1349, 1351, 5, 62, 0, 0, 1350, 1346, 1, 0, 0, 0, 1350, 1348, 1, 0, 0, 0, 1351, 334, 1, 0, 0, 0, 1352, 1353, 5, 33, 0, 0, 1353, 1354, 5, 126, 0, 0, 1354, 1355, 5, 42, 0, 0, 1355, 336, 1, 0, 0, 0, 1356, 1357, 5, 33, 0, 0, 1357, 1358, 5, 126, 0, 0, 1358, 338, 1, 0, 0, 0, 1359, 1360, 5, 63, 0, 0, 1360, 1361, 5, 46, 0, 0, 1361, 340, 1, 0, 0, 0, 1362, 1363, 5, 63, 0, 0, 1363, 1364, 5, 63, 0, 0, 1364, 342, 1, 0, 0, 0, 1365, 1366, 5, 37, 0, 0, 1366, 344, 1, 0, 0, 0, 1367, 1368, 5, 43, 0, 0, 1368, 346, 1, 0, 0, 0, 1369, 1370, 5, 63, 0, 0, 1370, 348, 1, 0, 0, 0, 1371, 1372, 5, 34, 0, 0, 1372, 350, 1, 0, 0, 0, 1373, 1374, 5, 102, 0, 0, 1374, 1375, 5, 39, 0, 0, 1375, 1376, 1, 0, 0, 0, 1376, 1377, 6, 174, 1, 0, 1377, 352, 1, 0, 0, 0, 1378, 1379, 5, 70, 0, 0, 1379, 1380, 5, 39, 0, 0, 1380, 1381, 1, 0, 0, 0, 1381, 1382, 6, 175, 2, 0, 1382, 354, 1, 0, 0, 0, 1383, 1384, 5, 39, 0, 0, 1384, 356, 1, 0, 0, 0, 1385, 1386, 5, 126, 0, 0, 1386, 358, 1, 0, 0, 0, 1387, 1388, 5, 61, 0, 0, 1388, 1389, 5, 126, 0, 0, 1389, 360, 1, 0, 0, 0, 1390, 1391, 5, 125, 0, 0, 1391, 1392, 1, 0, 0, 0, 1392, 1393, 6, 179, 3, 0, 1393, 362, 1, 0, 0, 0, 1394, 1395, 5, 93, 0, 0, 1395, 364, 1, 0, 0, 0, 1396, 1397, 5, 41, 0, 0, 1397, 366, 1, 0, 0, 0, 1398, 1399, 5, 59, 0, 0, 1399, 368, 1, 0, 0, 0, 1400, 1401, 5, 47, 0, 0, 1401, 370, 1, 0, 0, 0, 1402, 1403, 5, 95, 0, 0, 1403, 372, 1, 0, 0, 0, 1404, 1405, 5, 47, 0, 0, 1405, 1406, 5, 42, 0, 0, 1406, 1410, 1, 0, 0, 0, 1407, 1409, 9, 0, 0, 0, 1408, 1407, 1, 0, 0, 0, 1409, 1412, 1, 0, 0, 0, 1410, 1411, 1, 0, 0, 0, 1410, 1408, 1, 0, 0, 0, 1411, 1413, 1, 0, 0, 0, 1412, 1410, 1, 0, 0, 0, 1413, 1414, 5, 42, 0, 0, 1414, 1415, 5, 47, 0, 0, 1415, 1416, 1, 0, 0, 0, 1416, 1417, 6, 185, 4, 0, 1417, 374, 1, 0, 0, 0, 1418, 1419, 5, 45, 0, 0, 1419, 1423, 5, 45, 0, 0, 1420, 1421, 5, 47, 0, 0, 1421, 1423, 5, 47, 0, 0, 1422, 1418, 1, 0, 0, 0, 1422, 1420, 1, 0, 0, 0, 1423, 1427, 1, 0, 0, 0, 1424, 1426, 8, 33, 0, 0, 1425, 1424, 1, 0, 0, 0, 1426, 1429, 1, 0, 0, 0, 1427, 1425, 1, 0, 0, 0, 1427, 1428, 1, 0, 0, 0, 1428, 1431, 1, 0, 0, 0, 1429, 1427, 1, 0, 0, 0, 1430, 1432, 7, 34, 0, 0, 1431, 1430, 1, 0, 0, 0, 1432, 1433, 1, 0, 0, 0, 1433, 1434, 6, 186, 4, 0, 1434, 376, 1, 0, 0, 0, 1435, 1436, 7, 35, 0, 0, 1436, 1437, 1, 0, 0, 0, 1437, 1438, 6, 187, 5, 0, 1438, 378, 1, 0, 0, 0, 1439, 1451, 8, 36, 0, 0, 1440, 1451, 3, 215, 106, 0, 1441, 1442, 3, 295, 146, 0, 1442, 1443, 3, 355, 176, 0, 1443, 1451, 1, 0, 0, 0, 1444, 1445, 3, 295, 146, 0, 1445, 1446, 3, 323, 160, 0, 1446, 1451, 1, 0, 0, 0, 1447, 1448, 3, 355, 176, 0, 1448, 1449, 3, 355, 176, 0, 1449, 1451, 1, 0, 0, 0, 1450, 1439, 1, 0, 0, 0, 1450, 1440, 1, 0, 0, 0, 1450, 1441, 1, 0, 0, 0, 1450, 1444, 1, 0, 0, 0, 1450, 1447, 1, 0, 0, 0, 1451, 1452, 1, 0, 0, 0, 1452, 1450, 1, 0, 0, 0, 1452, 1453, 1, 0, 0, 0, 1453, 380, 1, 0, 0, 0, 1454, 1455, 3, 323, 160, 0, 1455, 1456, 1, 0, 0, 0, 1456, 1457, 6, 189, 0, 0, 1457, 382, 1, 0, 0, 0, 1458, 1459, 3, 355, 176, 0, 1459, 1460, 1, 0, 0, 0, 1460, 1461, 6, 190, 6, 0, 1461, 1462, 6, 190, 3, 0, 1462, 384, 1, 0, 0, 0, 1463, 1469, 8, 37, 0, 0, 1464, 1469, 3, 215, 106, 0, 1465, 1466, 3, 295, 146, 0, 1466, 1467, 3, 323, 160, 0, 1467, 1469, 1, 0, 0, 0, 1468, 1463, 1, 0, 0, 0, 1468, 1464, 1, 0, 0, 0, 1468, 1465, 1, 0, 0, 0, 1469, 1470, 1, 0, 0, 0, 1470, 1468, 1, 0, 0, 0, 1470, 1471, 1, 0, 0, 0, 1471, 386, 1, 0, 0, 0, 1472, 1473, 3, 323, 160, 0, 1473, 1474, 1, 0, 0, 0, 1474, 1475, 6, 192, 0, 0, 1475, 388, 1, 0, 0, 0, 44, 0, 1, 2, 429, 657, 1041, 1070, 1075, 1081, 1083, 1095, 1097, 1111, 1113, 1118, 1125, 1130, 1134, 1139, 1144, 1148, 1153, 1160, 1166, 1171, 1178, 1183, 1189, 1194, 1196, 1202, 1207, 1214, 1225, 1227, 1350, 1410, 1422, 1427, 1431, 1450, 1452, 1468, 1470, 7, 5, 0, 0, 5, 1, 0, 5, 2, 0, 4, 0, 0, 6, 0, 0, 0, 1, 0, 7, 147, 0] \ No newline at end of file diff --git a/hogql_parser/HogQLLexer.tokens b/hogql_parser/HogQLLexer.tokens index 8658dc473b899..f370b819d5a0d 100644 --- a/hogql_parser/HogQLLexer.tokens +++ b/hogql_parser/HogQLLexer.tokens @@ -24,178 +24,180 @@ DESCENDING=23 DISTINCT=24 ELSE=25 END=26 -EXTRACT=27 -FINAL=28 -FINALLY=29 -FIRST=30 -FN=31 -FOLLOWING=32 -FOR=33 -FROM=34 -FULL=35 -FUN=36 -GROUP=37 -HAVING=38 -HOUR=39 -ID=40 -IF=41 -ILIKE=42 -IN=43 -INF=44 -INNER=45 -INTERVAL=46 -IS=47 -JOIN=48 -KEY=49 -LAST=50 -LEADING=51 -LEFT=52 -LET=53 -LIKE=54 -LIMIT=55 -MINUTE=56 -MONTH=57 -NAN_SQL=58 -NOT=59 -NULL_SQL=60 -NULLS=61 -OFFSET=62 -ON=63 -OR=64 -ORDER=65 -OUTER=66 -OVER=67 -PARTITION=68 -PRECEDING=69 -PREWHERE=70 -QUARTER=71 -RANGE=72 -RETURN=73 -RIGHT=74 -ROLLUP=75 -ROW=76 -ROWS=77 -SAMPLE=78 -SECOND=79 -SELECT=80 -SEMI=81 -SETTINGS=82 -SUBSTRING=83 -THEN=84 -THROW=85 -TIES=86 -TIMESTAMP=87 -TO=88 -TOP=89 -TOTALS=90 -TRAILING=91 -TRIM=92 -TRUNCATE=93 -TRY=94 -UNBOUNDED=95 -UNION=96 -USING=97 -WEEK=98 -WHEN=99 -WHERE=100 -WHILE=101 -WINDOW=102 -WITH=103 -YEAR=104 -ESCAPE_CHAR_COMMON=105 -IDENTIFIER=106 -FLOATING_LITERAL=107 -OCTAL_LITERAL=108 -DECIMAL_LITERAL=109 -HEXADECIMAL_LITERAL=110 -STRING_LITERAL=111 -ARROW=112 -ASTERISK=113 -BACKQUOTE=114 -BACKSLASH=115 -COLON=116 -COMMA=117 -CONCAT=118 -DASH=119 -DOLLAR=120 -DOT=121 -EQ_DOUBLE=122 -EQ_SINGLE=123 -GT_EQ=124 -GT=125 -HASH=126 -IREGEX_SINGLE=127 -IREGEX_DOUBLE=128 -LBRACE=129 -LBRACKET=130 -LPAREN=131 -LT_EQ=132 -LT=133 -NOT_EQ=134 -NOT_IREGEX=135 -NOT_REGEX=136 -NULL_PROPERTY=137 -NULLISH=138 -PERCENT=139 -PLUS=140 -QUERY=141 -QUOTE_DOUBLE=142 -QUOTE_SINGLE_TEMPLATE=143 -QUOTE_SINGLE_TEMPLATE_FULL=144 -QUOTE_SINGLE=145 -REGEX_SINGLE=146 -REGEX_DOUBLE=147 -RBRACE=148 -RBRACKET=149 -RPAREN=150 -SEMICOLON=151 -SLASH=152 -UNDERSCORE=153 -MULTI_LINE_COMMENT=154 -SINGLE_LINE_COMMENT=155 -WHITESPACE=156 -STRING_TEXT=157 -STRING_ESCAPE_TRIGGER=158 -FULL_STRING_TEXT=159 -FULL_STRING_ESCAPE_TRIGGER=160 -'->'=112 -'*'=113 -'`'=114 -'\\'=115 -':'=116 -','=117 -'||'=118 -'-'=119 -'$'=120 -'.'=121 -'=='=122 -'='=123 -'>='=124 -'>'=125 -'#'=126 -'~*'=127 -'=~*'=128 -'{'=129 -'['=130 -'('=131 -'<='=132 -'<'=133 -'!~*'=135 -'!~'=136 -'?.'=137 -'??'=138 -'%'=139 -'+'=140 -'?'=141 -'"'=142 -'f\''=143 -'F\''=144 -'\''=145 -'~'=146 -'=~'=147 -'}'=148 -']'=149 -')'=150 -';'=151 -'/'=152 -'_'=153 +EXCEPT=27 +EXTRACT=28 +FINAL=29 +FINALLY=30 +FIRST=31 +FN=32 +FOLLOWING=33 +FOR=34 +FROM=35 +FULL=36 +FUN=37 +GROUP=38 +HAVING=39 +HOUR=40 +ID=41 +IF=42 +ILIKE=43 +IN=44 +INF=45 +INNER=46 +INTERSECT=47 +INTERVAL=48 +IS=49 +JOIN=50 +KEY=51 +LAST=52 +LEADING=53 +LEFT=54 +LET=55 +LIKE=56 +LIMIT=57 +MINUTE=58 +MONTH=59 +NAN_SQL=60 +NOT=61 +NULL_SQL=62 +NULLS=63 +OFFSET=64 +ON=65 +OR=66 +ORDER=67 +OUTER=68 +OVER=69 +PARTITION=70 +PRECEDING=71 +PREWHERE=72 +QUARTER=73 +RANGE=74 +RETURN=75 +RIGHT=76 +ROLLUP=77 +ROW=78 +ROWS=79 +SAMPLE=80 +SECOND=81 +SELECT=82 +SEMI=83 +SETTINGS=84 +SUBSTRING=85 +THEN=86 +THROW=87 +TIES=88 +TIMESTAMP=89 +TO=90 +TOP=91 +TOTALS=92 +TRAILING=93 +TRIM=94 +TRUNCATE=95 +TRY=96 +UNBOUNDED=97 +UNION=98 +USING=99 +WEEK=100 +WHEN=101 +WHERE=102 +WHILE=103 +WINDOW=104 +WITH=105 +YEAR=106 +ESCAPE_CHAR_COMMON=107 +IDENTIFIER=108 +FLOATING_LITERAL=109 +OCTAL_LITERAL=110 +DECIMAL_LITERAL=111 +HEXADECIMAL_LITERAL=112 +STRING_LITERAL=113 +ARROW=114 +ASTERISK=115 +BACKQUOTE=116 +BACKSLASH=117 +COLON=118 +COMMA=119 +CONCAT=120 +DASH=121 +DOLLAR=122 +DOT=123 +EQ_DOUBLE=124 +EQ_SINGLE=125 +GT_EQ=126 +GT=127 +HASH=128 +IREGEX_SINGLE=129 +IREGEX_DOUBLE=130 +LBRACE=131 +LBRACKET=132 +LPAREN=133 +LT_EQ=134 +LT=135 +NOT_EQ=136 +NOT_IREGEX=137 +NOT_REGEX=138 +NULL_PROPERTY=139 +NULLISH=140 +PERCENT=141 +PLUS=142 +QUERY=143 +QUOTE_DOUBLE=144 +QUOTE_SINGLE_TEMPLATE=145 +QUOTE_SINGLE_TEMPLATE_FULL=146 +QUOTE_SINGLE=147 +REGEX_SINGLE=148 +REGEX_DOUBLE=149 +RBRACE=150 +RBRACKET=151 +RPAREN=152 +SEMICOLON=153 +SLASH=154 +UNDERSCORE=155 +MULTI_LINE_COMMENT=156 +SINGLE_LINE_COMMENT=157 +WHITESPACE=158 +STRING_TEXT=159 +STRING_ESCAPE_TRIGGER=160 +FULL_STRING_TEXT=161 +FULL_STRING_ESCAPE_TRIGGER=162 +'->'=114 +'*'=115 +'`'=116 +'\\'=117 +':'=118 +','=119 +'||'=120 +'-'=121 +'$'=122 +'.'=123 +'=='=124 +'='=125 +'>='=126 +'>'=127 +'#'=128 +'~*'=129 +'=~*'=130 +'{'=131 +'['=132 +'('=133 +'<='=134 +'<'=135 +'!~*'=137 +'!~'=138 +'?.'=139 +'??'=140 +'%'=141 +'+'=142 +'?'=143 +'"'=144 +'f\''=145 +'F\''=146 +'\''=147 +'~'=148 +'=~'=149 +'}'=150 +']'=151 +')'=152 +';'=153 +'/'=154 +'_'=155 diff --git a/hogql_parser/HogQLParser.cpp b/hogql_parser/HogQLParser.cpp index 4b0766a579cd5..d964e54b51e2c 100644 --- a/hogql_parser/HogQLParser.cpp +++ b/hogql_parser/HogQLParser.cpp @@ -56,16 +56,17 @@ void hogqlparserParserInitialize() { "statement", "returnStmt", "throwStmt", "catchBlock", "tryCatchStmt", "ifStmt", "whileStmt", "forStmt", "forInStmt", "funcStmt", "varAssignment", "exprStmt", "emptyStmt", "block", "kvPair", "kvPairList", "select", - "selectUnionStmt", "selectStmtWithParens", "selectStmt", "withClause", - "topClause", "fromClause", "arrayJoinClause", "windowClause", "prewhereClause", - "whereClause", "groupByClause", "havingClause", "orderByClause", "projectionOrderByClause", - "limitAndOffsetClause", "offsetOnlyClause", "settingsClause", "joinExpr", - "joinOp", "joinOpCross", "joinConstraintClause", "sampleClause", "orderExprList", - "orderExpr", "ratioExpr", "settingExprList", "settingExpr", "windowExpr", - "winPartitionByClause", "winOrderByClause", "winFrameClause", "winFrameExtend", - "winFrameBound", "expr", "columnTypeExpr", "columnExprList", "columnExpr", - "columnLambdaExpr", "hogqlxTagElement", "hogqlxTagAttribute", "withExprList", - "withExpr", "columnIdentifier", "nestedIdentifier", "tableExpr", "tableFunctionExpr", + "selectStmtWithParens", "subsequentSelectSetClause", "selectSetStmt", + "selectStmt", "withClause", "topClause", "fromClause", "arrayJoinClause", + "windowClause", "prewhereClause", "whereClause", "groupByClause", + "havingClause", "orderByClause", "projectionOrderByClause", "limitAndOffsetClause", + "offsetOnlyClause", "settingsClause", "joinExpr", "joinOp", "joinOpCross", + "joinConstraintClause", "sampleClause", "orderExprList", "orderExpr", + "ratioExpr", "settingExprList", "settingExpr", "windowExpr", "winPartitionByClause", + "winOrderByClause", "winFrameClause", "winFrameExtend", "winFrameBound", + "expr", "columnTypeExpr", "columnExprList", "columnExpr", "columnLambdaExpr", + "hogqlxTagElement", "hogqlxTagAttribute", "withExprList", "withExpr", + "columnIdentifier", "nestedIdentifier", "tableExpr", "tableFunctionExpr", "tableIdentifier", "tableArgList", "databaseIdentifier", "floatingLiteral", "numberLiteral", "literal", "interval", "keyword", "keywordForAlias", "alias", "identifier", "enumValue", "placeholder", "string", "templateString", @@ -78,30 +79,30 @@ void hogqlparserParserInitialize() { "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", - "", "", "", "", "", "", "", "", "", "", "'->'", "'*'", "'`'", "'\\'", - "':'", "','", "'||'", "'-'", "'$'", "'.'", "'=='", "'='", "'>='", - "'>'", "'#'", "'~*'", "'=~*'", "'{'", "'['", "'('", "'<='", "'<'", - "", "'!~*'", "'!~'", "'\\u003F.'", "'\\u003F\\u003F'", "'%'", "'+'", - "'\\u003F'", "'\"'", "'f''", "'F''", "'''", "'~'", "'=~'", "'}'", - "']'", "')'", "';'", "'/'", "'_'" + "", "", "", "", "", "", "", "", "", "", "", "", "'->'", "'*'", "'`'", + "'\\'", "':'", "','", "'||'", "'-'", "'$'", "'.'", "'=='", "'='", + "'>='", "'>'", "'#'", "'~*'", "'=~*'", "'{'", "'['", "'('", "'<='", + "'<'", "", "'!~*'", "'!~'", "'\\u003F.'", "'\\u003F\\u003F'", "'%'", + "'+'", "'\\u003F'", "'\"'", "'f''", "'F''", "'''", "'~'", "'=~'", + "'}'", "']'", "')'", "';'", "'/'", "'_'" }, std::vector{ "", "ALL", "AND", "ANTI", "ANY", "ARRAY", "AS", "ASCENDING", "ASOF", "BETWEEN", "BOTH", "BY", "CASE", "CAST", "CATCH", "COHORT", "COLLATE", "CROSS", "CUBE", "CURRENT", "DATE", "DAY", "DESC", "DESCENDING", "DISTINCT", - "ELSE", "END", "EXTRACT", "FINAL", "FINALLY", "FIRST", "FN", "FOLLOWING", - "FOR", "FROM", "FULL", "FUN", "GROUP", "HAVING", "HOUR", "ID", "IF", - "ILIKE", "IN", "INF", "INNER", "INTERVAL", "IS", "JOIN", "KEY", "LAST", - "LEADING", "LEFT", "LET", "LIKE", "LIMIT", "MINUTE", "MONTH", "NAN_SQL", - "NOT", "NULL_SQL", "NULLS", "OFFSET", "ON", "OR", "ORDER", "OUTER", - "OVER", "PARTITION", "PRECEDING", "PREWHERE", "QUARTER", "RANGE", - "RETURN", "RIGHT", "ROLLUP", "ROW", "ROWS", "SAMPLE", "SECOND", "SELECT", - "SEMI", "SETTINGS", "SUBSTRING", "THEN", "THROW", "TIES", "TIMESTAMP", - "TO", "TOP", "TOTALS", "TRAILING", "TRIM", "TRUNCATE", "TRY", "UNBOUNDED", - "UNION", "USING", "WEEK", "WHEN", "WHERE", "WHILE", "WINDOW", "WITH", - "YEAR", "ESCAPE_CHAR_COMMON", "IDENTIFIER", "FLOATING_LITERAL", "OCTAL_LITERAL", - "DECIMAL_LITERAL", "HEXADECIMAL_LITERAL", "STRING_LITERAL", "ARROW", - "ASTERISK", "BACKQUOTE", "BACKSLASH", "COLON", "COMMA", "CONCAT", + "ELSE", "END", "EXCEPT", "EXTRACT", "FINAL", "FINALLY", "FIRST", "FN", + "FOLLOWING", "FOR", "FROM", "FULL", "FUN", "GROUP", "HAVING", "HOUR", + "ID", "IF", "ILIKE", "IN", "INF", "INNER", "INTERSECT", "INTERVAL", + "IS", "JOIN", "KEY", "LAST", "LEADING", "LEFT", "LET", "LIKE", "LIMIT", + "MINUTE", "MONTH", "NAN_SQL", "NOT", "NULL_SQL", "NULLS", "OFFSET", + "ON", "OR", "ORDER", "OUTER", "OVER", "PARTITION", "PRECEDING", "PREWHERE", + "QUARTER", "RANGE", "RETURN", "RIGHT", "ROLLUP", "ROW", "ROWS", "SAMPLE", + "SECOND", "SELECT", "SEMI", "SETTINGS", "SUBSTRING", "THEN", "THROW", + "TIES", "TIMESTAMP", "TO", "TOP", "TOTALS", "TRAILING", "TRIM", "TRUNCATE", + "TRY", "UNBOUNDED", "UNION", "USING", "WEEK", "WHEN", "WHERE", "WHILE", + "WINDOW", "WITH", "YEAR", "ESCAPE_CHAR_COMMON", "IDENTIFIER", "FLOATING_LITERAL", + "OCTAL_LITERAL", "DECIMAL_LITERAL", "HEXADECIMAL_LITERAL", "STRING_LITERAL", + "ARROW", "ASTERISK", "BACKQUOTE", "BACKSLASH", "COLON", "COMMA", "CONCAT", "DASH", "DOLLAR", "DOT", "EQ_DOUBLE", "EQ_SINGLE", "GT_EQ", "GT", "HASH", "IREGEX_SINGLE", "IREGEX_DOUBLE", "LBRACE", "LBRACKET", "LPAREN", "LT_EQ", "LT", "NOT_EQ", "NOT_IREGEX", "NOT_REGEX", "NULL_PROPERTY", @@ -113,7 +114,7 @@ void hogqlparserParserInitialize() { } ); static const int32_t serializedATNSegment[] = { - 4,1,160,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, + 4,1,162,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, @@ -125,481 +126,486 @@ 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,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,17,2,0,31,31,36,36,2,0, - 18,18,75,75,2,0,45,45,52,52,3,0,1,1,4,4,8,8,4,0,1,1,3,4,8,8,81,81,2,0, - 52,52,74,74,2,0,1,1,4,4,2,0,7,7,22,23,2,0,30,30,50,50,2,0,72,72,77,77, - 3,0,10,10,51,51,91,91,2,0,42,42,54,54,1,0,108,109,2,0,119,119,140,140, - 7,0,21,21,39,39,56,57,71,71,79,79,98,98,104,104,17,0,1,13,15,20,22,28, - 30,30,32,35,37,38,40,43,45,52,54,55,59,59,61,70,72,78,80,84,86,93,95, - 97,99,100,102,103,4,0,20,20,30,30,40,40,49,49,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,53,0,0,187,191,3,156,78, - 0,188,189,5,116,0,0,189,190,5,123,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,117,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,117,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,73,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,151,0,0,223,222,1,0,0, - 0,223,224,1,0,0,0,224,13,1,0,0,0,225,227,5,85,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,151,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,131, - 0,0,234,237,3,156,78,0,235,236,5,116,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,150,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,94,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,41,0,0,258,259,5,131,0,0,259, - 260,3,4,2,0,260,261,5,150,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,101, - 0,0,267,268,5,131,0,0,268,269,3,4,2,0,269,270,5,150,0,0,270,272,3,10, - 5,0,271,273,5,151,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,131,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,151,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,151,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,150,0,0,292,294, - 3,10,5,0,293,295,5,151,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,131,0,0,298,299,5,53,0,0,299,302,3,156, - 78,0,300,301,5,117,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,43,0,0,305,306,3,4,2,0,306,307,5,150,0, - 0,307,309,3,10,5,0,308,310,5,151,0,0,309,308,1,0,0,0,309,310,1,0,0,0, - 310,27,1,0,0,0,311,312,7,0,0,0,312,313,3,156,78,0,313,315,5,131,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, - 150,0,0,318,319,3,36,18,0,319,29,1,0,0,0,320,321,3,4,2,0,321,322,5,116, - 0,0,322,323,5,123,0,0,323,324,3,4,2,0,324,31,1,0,0,0,325,327,3,4,2,0, - 326,328,5,151,0,0,327,326,1,0,0,0,327,328,1,0,0,0,328,33,1,0,0,0,329, - 330,5,151,0,0,330,35,1,0,0,0,331,335,5,129,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,148,0,0,339,37,1,0,0,0,340,341,3,4,2,0,341, - 342,5,116,0,0,342,343,3,4,2,0,343,39,1,0,0,0,344,349,3,38,19,0,345,346, - 5,117,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,117,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,96,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,131,0,0,373,374,3,44,22,0, - 374,375,5,150,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,80,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,103,0,0,406, - 408,7,1,0,0,407,405,1,0,0,0,407,408,1,0,0,0,408,411,1,0,0,0,409,410,5, - 103,0,0,410,412,5,90,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,103,0,0,430,431,3,124,62,0,431,51,1,0,0,0, - 432,433,5,89,0,0,433,436,5,109,0,0,434,435,5,103,0,0,435,437,5,86,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,2,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,48,0,0,446,447,3,114,57, - 0,447,57,1,0,0,0,448,449,5,102,0,0,449,450,3,156,78,0,450,451,5,6,0,0, - 451,452,5,131,0,0,452,453,3,98,49,0,453,463,5,150,0,0,454,455,5,117,0, - 0,455,456,3,156,78,0,456,457,5,6,0,0,457,458,5,131,0,0,458,459,3,98,49, - 0,459,460,5,150,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, - 70,0,0,467,468,3,116,58,0,468,61,1,0,0,0,469,470,5,100,0,0,470,471,3, - 116,58,0,471,63,1,0,0,0,472,473,5,37,0,0,473,480,5,11,0,0,474,475,7,1, - 0,0,475,476,5,131,0,0,476,477,3,114,57,0,477,478,5,150,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,38,0,0,483,484,3,116,58,0,484,67,1,0,0,0,485,486,5,65,0,0, - 486,487,5,11,0,0,487,488,3,88,44,0,488,69,1,0,0,0,489,490,5,65,0,0,490, - 491,5,11,0,0,491,492,3,114,57,0,492,71,1,0,0,0,493,494,5,55,0,0,494,497, - 3,116,58,0,495,496,5,117,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,103,0,0,500,504,5,86,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,55,0,0,506,509,3,116,58,0,507,508,5,103, - 0,0,508,510,5,86,0,0,509,507,1,0,0,0,509,510,1,0,0,0,510,511,1,0,0,0, - 511,512,5,62,0,0,512,513,3,116,58,0,513,523,1,0,0,0,514,515,5,55,0,0, - 515,516,3,116,58,0,516,517,5,62,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,62,0,0,525,526,3,116,58,0,526,75,1,0,0,0,527,528,5,82,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,131,0,0,539, - 540,3,78,39,0,540,541,5,150,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,48,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,3,0,0,562,561,1,0,0,0,562,563,1,0,0,0,563,564,1,0,0,0, - 564,571,5,45,0,0,565,567,5,45,0,0,566,568,7,3,0,0,567,566,1,0,0,0,567, - 568,1,0,0,0,568,571,1,0,0,0,569,571,7,3,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,4,0,0,573,572,1,0,0,0, - 573,574,1,0,0,0,574,575,1,0,0,0,575,577,7,5,0,0,576,578,5,66,0,0,577, - 576,1,0,0,0,577,578,1,0,0,0,578,587,1,0,0,0,579,581,7,5,0,0,580,582,5, - 66,0,0,581,580,1,0,0,0,581,582,1,0,0,0,582,584,1,0,0,0,583,585,7,4,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,6,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,66,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,66,0,0,597, - 596,1,0,0,0,597,598,1,0,0,0,598,600,1,0,0,0,599,601,7,6,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,48,0,0,608,610,5,117,0,0,609,606,1, - 0,0,0,609,608,1,0,0,0,610,83,1,0,0,0,611,612,5,63,0,0,612,621,3,114,57, - 0,613,614,5,97,0,0,614,615,5,131,0,0,615,616,3,114,57,0,616,617,5,150, - 0,0,617,621,1,0,0,0,618,619,5,97,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,78,0,0,623, - 626,3,92,46,0,624,625,5,62,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,117,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,7,0,0, - 638,637,1,0,0,0,638,639,1,0,0,0,639,642,1,0,0,0,640,641,5,61,0,0,641, - 643,7,8,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,111,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,152,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,117,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,123, - 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,68,0,0,678,679,5,11,0,0,679, - 680,3,114,57,0,680,101,1,0,0,0,681,682,5,65,0,0,682,683,5,11,0,0,683, - 684,3,88,44,0,684,103,1,0,0,0,685,686,7,9,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,76,0,0,698,699,5,95, - 0,0,699,709,5,69,0,0,700,701,5,95,0,0,701,709,5,32,0,0,702,703,3,144, - 72,0,703,704,5,69,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,131,0,0,716,717,3,156,78,0,717,724,3,112,56,0,718,719,5,117,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,117,0,0,728,727,1,0,0,0,728,729,1,0,0,0,729,730,1,0,0, - 0,730,731,5,150,0,0,731,770,1,0,0,0,732,733,3,156,78,0,733,734,5,131, - 0,0,734,739,3,158,79,0,735,736,5,117,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,117,0,0,743,742,1,0,0,0,743,744,1,0,0,0,744, - 745,1,0,0,0,745,746,5,150,0,0,746,770,1,0,0,0,747,748,3,156,78,0,748, - 749,5,131,0,0,749,754,3,112,56,0,750,751,5,117,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,117,0,0,758,757,1,0,0,0,758,759,1,0, - 0,0,759,760,1,0,0,0,760,761,5,150,0,0,761,770,1,0,0,0,762,763,3,156,78, - 0,763,765,5,131,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,150,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,117,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,117,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,99,0,0,788,789, - 3,116,58,0,789,790,5,84,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,131,0,0,804,805,3,116,58,0,805,806,5,6,0,0,806,807,3,112,56,0,807, - 808,5,150,0,0,808,933,1,0,0,0,809,810,5,20,0,0,810,933,5,111,0,0,811, - 812,5,46,0,0,812,813,3,116,58,0,813,814,3,148,74,0,814,933,1,0,0,0,815, - 816,5,83,0,0,816,817,5,131,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,150,0,0,825,933,1,0,0,0,826,827, - 5,87,0,0,827,933,5,111,0,0,828,829,5,92,0,0,829,830,5,131,0,0,830,831, - 7,10,0,0,831,832,3,162,81,0,832,833,5,34,0,0,833,834,3,116,58,0,834,835, - 5,150,0,0,835,933,1,0,0,0,836,837,3,156,78,0,837,839,5,131,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, - 150,0,0,842,851,1,0,0,0,843,845,5,131,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,150,0,0,851,843,1,0,0,0, - 851,852,1,0,0,0,852,853,1,0,0,0,853,854,5,67,0,0,854,855,5,131,0,0,855, - 856,3,98,49,0,856,857,5,150,0,0,857,933,1,0,0,0,858,859,3,156,78,0,859, - 861,5,131,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,150,0,0,864,873,1,0,0,0,865,867,5,131,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,150,0, - 0,873,865,1,0,0,0,873,874,1,0,0,0,874,875,1,0,0,0,875,876,5,67,0,0,876, - 877,3,156,78,0,877,933,1,0,0,0,878,884,3,156,78,0,879,881,5,131,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,150,0,0,884,879,1,0,0,0,884,885,1,0,0,0,885,886,1,0,0,0,886,888,5,131, - 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,150,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,119,0,0,899,933,3,116,58,20,900,901,5,59,0,0, - 901,933,3,116,58,14,902,903,3,136,68,0,903,904,5,121,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,113,0,0, - 908,909,5,131,0,0,909,910,3,44,22,0,910,911,5,150,0,0,911,933,1,0,0,0, - 912,913,5,131,0,0,913,914,3,116,58,0,914,915,5,150,0,0,915,933,1,0,0, - 0,916,917,5,131,0,0,917,918,3,114,57,0,918,919,5,150,0,0,919,933,1,0, - 0,0,920,922,5,130,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,149,0,0,925,927,5,129,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,148,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,113,0,0,936,939,5,152,0,0,937,939,5,139, - 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,140,0,0,943,946,5,119,0, - 0,944,946,5,118,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,122,0,0, - 950,974,5,123,0,0,951,974,5,134,0,0,952,974,5,132,0,0,953,974,5,133,0, - 0,954,974,5,124,0,0,955,974,5,125,0,0,956,958,5,59,0,0,957,956,1,0,0, - 0,957,958,1,0,0,0,958,959,1,0,0,0,959,961,5,43,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,59,0,0,964,963, - 1,0,0,0,964,965,1,0,0,0,965,966,1,0,0,0,966,974,7,11,0,0,967,974,5,146, - 0,0,968,974,5,147,0,0,969,974,5,136,0,0,970,974,5,127,0,0,971,974,5,128, - 0,0,972,974,5,135,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,138,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,64,0,0,984,1043,3,116,58,13,985,987,10,11,0,0,986,988, - 5,59,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,141,0,0,996,997,3,116,58,0,997,998, - 5,116,0,0,998,999,3,116,58,10,999,1043,1,0,0,0,1000,1001,10,30,0,0,1001, - 1003,5,131,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,150,0,0,1006,1007,10,26,0,0,1007,1008, - 5,130,0,0,1008,1009,3,116,58,0,1009,1010,5,149,0,0,1010,1043,1,0,0,0, - 1011,1012,10,25,0,0,1012,1013,5,121,0,0,1013,1043,5,109,0,0,1014,1015, - 10,24,0,0,1015,1016,5,121,0,0,1016,1043,3,156,78,0,1017,1018,10,23,0, - 0,1018,1019,5,137,0,0,1019,1020,5,130,0,0,1020,1021,3,116,58,0,1021,1022, - 5,149,0,0,1022,1043,1,0,0,0,1023,1024,10,22,0,0,1024,1025,5,137,0,0,1025, - 1043,5,109,0,0,1026,1027,10,21,0,0,1027,1028,5,137,0,0,1028,1043,3,156, - 78,0,1029,1030,10,16,0,0,1030,1032,5,47,0,0,1031,1033,5,59,0,0,1032,1031, - 1,0,0,0,1032,1033,1,0,0,0,1033,1034,1,0,0,0,1034,1043,5,60,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,111,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,131,0,0,1048,1053,3,156,78,0,1049, - 1050,5,117,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,117,0,0,1057,1056,1,0,0,0,1057,1058,1,0,0,0,1058,1059, - 1,0,0,0,1059,1060,5,150,0,0,1060,1075,1,0,0,0,1061,1066,3,156,78,0,1062, - 1063,5,117,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,117,0,0,1070,1069,1,0,0,0,1070,1071,1,0,0,0,1071,1075, - 1,0,0,0,1072,1073,5,131,0,0,1073,1075,5,150,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,112,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,133,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,152, - 0,0,1090,1091,5,125,0,0,1091,1114,1,0,0,0,1092,1093,5,133,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,125,0,0,1101,1107,3,120,60,0,1102,1103,5,129,0,0,1103,1104,3,116, - 58,0,1104,1105,5,148,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,133,0,0,1109, - 1110,5,152,0,0,1110,1111,3,156,78,0,1111,1112,5,125,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,123,0,0,1117,1118,3,162,81,0,1118,1127,1,0,0,0,1119, - 1120,3,156,78,0,1120,1121,5,123,0,0,1121,1122,5,129,0,0,1122,1123,3,116, - 58,0,1123,1124,5,148,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,117,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,117,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,131,0,0,1142,1143,3,44,22,0,1143,1144,5,150,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,121,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,121,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,131,0,0,1172,1173,3,44,22,0,1173,1174,5,150, - 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,131,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,150,0,0,1196,135,1,0, - 0,0,1197,1198,3,140,70,0,1198,1199,5,121,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,117,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,117,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,107,0,0,1218,1219,5,121,0,0,1219,1226,7, - 12,0,0,1220,1221,5,109,0,0,1221,1223,5,121,0,0,1222,1224,7,12,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,13,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,108,0,0,1232,1237,5,109,0,0,1233,1237,5,110,0,0,1234,1237, - 5,44,0,0,1235,1237,5,58,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,111,0,0,1240,1242,5,60,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,14,0,0,1244,149,1,0,0,0,1245,1246,7,15,0,0,1246,151,1, - 0,0,0,1247,1248,7,16,0,0,1248,153,1,0,0,0,1249,1252,5,106,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,106,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,123,0,0,1260,1261,3,144,72,0,1261,159,1,0,0,0, - 1262,1263,5,129,0,0,1263,1264,3,116,58,0,1264,1265,5,148,0,0,1265,161, - 1,0,0,0,1266,1269,5,111,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,143,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,145,0,0,1278,165, - 1,0,0,0,1279,1280,5,158,0,0,1280,1281,3,116,58,0,1281,1282,5,148,0,0, - 1282,1285,1,0,0,0,1283,1285,5,157,0,0,1284,1279,1,0,0,0,1284,1283,1,0, - 0,0,1285,167,1,0,0,0,1286,1290,5,144,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,160,0,0,1296,1297,3,116,58,0,1297,1298,5,148,0,0,1298,1301,1,0,0,0, - 1299,1301,5,159,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 + 7,84,2,85,7,85,2,86,7,86,1,0,5,0,176,8,0,10,0,12,0,179,9,0,1,0,1,0,1, + 1,1,1,3,1,185,8,1,1,2,1,2,1,3,1,3,1,3,1,3,1,3,3,3,194,8,3,1,4,1,4,1,4, + 5,4,199,8,4,10,4,12,4,202,9,4,1,4,3,4,205,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,219,8,5,1,6,1,6,3,6,223,8,6,1,6,3,6,226,8, + 6,1,7,1,7,3,7,230,8,7,1,7,3,7,233,8,7,1,8,1,8,1,8,1,8,1,8,3,8,240,8,8, + 1,8,1,8,3,8,244,8,8,1,8,1,8,1,9,1,9,1,9,5,9,251,8,9,10,9,12,9,254,9,9, + 1,9,1,9,3,9,258,8,9,1,10,1,10,1,10,1,10,1,10,1,10,1,10,3,10,267,8,10, + 1,11,1,11,1,11,1,11,1,11,1,11,3,11,275,8,11,1,12,1,12,1,12,1,12,1,12, + 3,12,282,8,12,1,12,1,12,3,12,286,8,12,1,12,1,12,1,12,1,12,3,12,292,8, + 12,1,12,1,12,1,12,3,12,297,8,12,1,13,1,13,1,13,1,13,1,13,1,13,3,13,305, + 8,13,1,13,1,13,1,13,1,13,1,13,3,13,312,8,13,1,14,1,14,1,14,1,14,3,14, + 318,8,14,1,14,1,14,1,14,1,15,1,15,1,15,1,15,1,15,1,16,1,16,3,16,330,8, + 16,1,17,1,17,1,18,1,18,5,18,336,8,18,10,18,12,18,339,9,18,1,18,1,18,1, + 19,1,19,1,19,1,19,1,20,1,20,1,20,5,20,350,8,20,10,20,12,20,353,9,20,1, + 20,3,20,356,8,20,1,21,1,21,1,21,3,21,361,8,21,1,21,1,21,1,22,1,22,1,22, + 1,22,1,22,1,22,3,22,371,8,22,1,23,1,23,1,23,1,23,3,23,377,8,23,1,23,1, + 23,1,24,1,24,5,24,383,8,24,10,24,12,24,386,9,24,1,25,3,25,389,8,25,1, + 25,1,25,3,25,393,8,25,1,25,3,25,396,8,25,1,25,1,25,3,25,400,8,25,1,25, + 3,25,403,8,25,1,25,3,25,406,8,25,1,25,3,25,409,8,25,1,25,3,25,412,8,25, + 1,25,1,25,3,25,416,8,25,1,25,1,25,3,25,420,8,25,1,25,3,25,423,8,25,1, + 25,3,25,426,8,25,1,25,3,25,429,8,25,1,25,1,25,3,25,433,8,25,1,25,3,25, + 436,8,25,1,26,1,26,1,26,1,27,1,27,1,27,1,27,3,27,445,8,27,1,28,1,28,1, + 28,1,29,3,29,451,8,29,1,29,1,29,1,29,1,29,1,30,1,30,1,30,1,30,1,30,1, + 30,1,30,1,30,1,30,1,30,1,30,1,30,1,30,5,30,470,8,30,10,30,12,30,473,9, + 30,1,31,1,31,1,31,1,32,1,32,1,32,1,33,1,33,1,33,1,33,1,33,1,33,1,33,1, + 33,3,33,489,8,33,1,34,1,34,1,34,1,35,1,35,1,35,1,35,1,36,1,36,1,36,1, + 36,1,37,1,37,1,37,1,37,3,37,506,8,37,1,37,1,37,1,37,1,37,3,37,512,8,37, + 1,37,1,37,1,37,1,37,3,37,518,8,37,1,37,1,37,1,37,1,37,1,37,1,37,1,37, + 1,37,1,37,3,37,529,8,37,3,37,531,8,37,1,38,1,38,1,38,1,39,1,39,1,39,1, + 40,1,40,1,40,3,40,542,8,40,1,40,3,40,545,8,40,1,40,1,40,1,40,1,40,3,40, + 551,8,40,1,40,1,40,1,40,1,40,1,40,1,40,3,40,559,8,40,1,40,1,40,1,40,1, + 40,5,40,565,8,40,10,40,12,40,568,9,40,1,41,3,41,571,8,41,1,41,1,41,1, + 41,3,41,576,8,41,1,41,3,41,579,8,41,1,41,3,41,582,8,41,1,41,1,41,3,41, + 586,8,41,1,41,1,41,3,41,590,8,41,1,41,3,41,593,8,41,3,41,595,8,41,1,41, + 3,41,598,8,41,1,41,1,41,3,41,602,8,41,1,41,1,41,3,41,606,8,41,1,41,3, + 41,609,8,41,3,41,611,8,41,3,41,613,8,41,1,42,1,42,1,42,3,42,618,8,42, + 1,43,1,43,1,43,1,43,1,43,1,43,1,43,1,43,1,43,3,43,629,8,43,1,44,1,44, + 1,44,1,44,3,44,635,8,44,1,45,1,45,1,45,5,45,640,8,45,10,45,12,45,643, + 9,45,1,46,1,46,3,46,647,8,46,1,46,1,46,3,46,651,8,46,1,46,1,46,3,46,655, + 8,46,1,47,1,47,1,47,1,47,3,47,661,8,47,3,47,663,8,47,1,48,1,48,1,48,5, + 48,668,8,48,10,48,12,48,671,9,48,1,49,1,49,1,49,1,49,1,50,3,50,678,8, + 50,1,50,3,50,681,8,50,1,50,3,50,684,8,50,1,51,1,51,1,51,1,51,1,52,1,52, + 1,52,1,52,1,53,1,53,1,53,1,54,1,54,1,54,1,54,1,54,1,54,3,54,703,8,54, + 1,55,1,55,1,55,1,55,1,55,1,55,1,55,1,55,1,55,1,55,1,55,1,55,3,55,717, + 8,55,1,56,1,56,1,56,1,57,1,57,1,57,1,57,1,57,1,57,1,57,1,57,1,57,5,57, + 731,8,57,10,57,12,57,734,9,57,1,57,3,57,737,8,57,1,57,1,57,1,57,1,57, + 1,57,1,57,1,57,5,57,746,8,57,10,57,12,57,749,9,57,1,57,3,57,752,8,57, + 1,57,1,57,1,57,1,57,1,57,1,57,1,57,5,57,761,8,57,10,57,12,57,764,9,57, + 1,57,3,57,767,8,57,1,57,1,57,1,57,1,57,1,57,3,57,774,8,57,1,57,1,57,3, + 57,778,8,57,1,58,1,58,1,58,5,58,783,8,58,10,58,12,58,786,9,58,1,58,3, + 58,789,8,58,1,59,1,59,1,59,3,59,794,8,59,1,59,1,59,1,59,1,59,1,59,4,59, + 801,8,59,11,59,12,59,802,1,59,1,59,3,59,807,8,59,1,59,1,59,1,59,1,59, + 1,59,1,59,1,59,1,59,1,59,1,59,1,59,1,59,1,59,1,59,1,59,1,59,1,59,1,59, + 1,59,1,59,1,59,1,59,3,59,831,8,59,1,59,1,59,1,59,1,59,1,59,1,59,1,59, + 1,59,1,59,1,59,1,59,1,59,1,59,1,59,1,59,3,59,848,8,59,1,59,1,59,1,59, + 1,59,3,59,854,8,59,1,59,3,59,857,8,59,1,59,3,59,860,8,59,1,59,1,59,1, + 59,1,59,1,59,1,59,1,59,1,59,3,59,870,8,59,1,59,1,59,1,59,1,59,3,59,876, + 8,59,1,59,3,59,879,8,59,1,59,3,59,882,8,59,1,59,1,59,1,59,1,59,1,59,1, + 59,3,59,890,8,59,1,59,3,59,893,8,59,1,59,1,59,3,59,897,8,59,1,59,3,59, + 900,8,59,1,59,1,59,1,59,1,59,1,59,1,59,1,59,1,59,1,59,1,59,1,59,1,59, + 3,59,914,8,59,1,59,1,59,1,59,1,59,1,59,1,59,1,59,1,59,1,59,1,59,1,59, + 1,59,1,59,1,59,1,59,3,59,931,8,59,1,59,1,59,1,59,3,59,936,8,59,1,59,1, + 59,1,59,3,59,941,8,59,1,59,1,59,1,59,1,59,3,59,947,8,59,1,59,1,59,1,59, + 1,59,1,59,3,59,954,8,59,1,59,1,59,1,59,1,59,1,59,1,59,1,59,1,59,1,59, + 1,59,3,59,966,8,59,1,59,1,59,3,59,970,8,59,1,59,3,59,973,8,59,1,59,1, + 59,1,59,1,59,1,59,1,59,1,59,3,59,982,8,59,1,59,1,59,1,59,1,59,1,59,1, + 59,1,59,1,59,1,59,1,59,1,59,1,59,3,59,996,8,59,1,59,1,59,1,59,1,59,1, + 59,1,59,1,59,1,59,1,59,1,59,1,59,1,59,1,59,1,59,3,59,1012,8,59,1,59,1, + 59,1,59,1,59,1,59,1,59,1,59,1,59,1,59,1,59,1,59,1,59,1,59,1,59,1,59,1, + 59,1,59,1,59,1,59,1,59,1,59,1,59,1,59,1,59,1,59,1,59,1,59,3,59,1041,8, + 59,1,59,1,59,1,59,1,59,1,59,1,59,3,59,1049,8,59,5,59,1051,8,59,10,59, + 12,59,1054,9,59,1,60,1,60,1,60,1,60,5,60,1060,8,60,10,60,12,60,1063,9, + 60,1,60,3,60,1066,8,60,1,60,1,60,1,60,1,60,1,60,5,60,1073,8,60,10,60, + 12,60,1076,9,60,1,60,3,60,1079,8,60,1,60,1,60,3,60,1083,8,60,1,60,1,60, + 1,60,3,60,1088,8,60,1,61,1,61,1,61,5,61,1093,8,61,10,61,12,61,1096,9, + 61,1,61,1,61,1,61,1,61,1,61,1,61,5,61,1104,8,61,10,61,12,61,1107,9,61, + 1,61,1,61,1,61,1,61,1,61,1,61,3,61,1115,8,61,1,61,1,61,1,61,1,61,1,61, + 3,61,1122,8,61,1,62,1,62,1,62,1,62,1,62,1,62,1,62,1,62,1,62,1,62,1,62, + 3,62,1135,8,62,1,63,1,63,1,63,5,63,1140,8,63,10,63,12,63,1143,9,63,1, + 63,3,63,1146,8,63,1,64,1,64,1,64,1,64,1,64,1,64,1,64,1,64,1,64,1,64,3, + 64,1158,8,64,1,65,1,65,1,65,1,65,3,65,1164,8,65,1,65,3,65,1167,8,65,1, + 66,1,66,1,66,5,66,1172,8,66,10,66,12,66,1175,9,66,1,67,1,67,1,67,1,67, + 1,67,1,67,1,67,1,67,1,67,3,67,1186,8,67,1,67,1,67,1,67,1,67,3,67,1192, + 8,67,5,67,1194,8,67,10,67,12,67,1197,9,67,1,68,1,68,1,68,3,68,1202,8, + 68,1,68,1,68,1,69,1,69,1,69,3,69,1209,8,69,1,69,1,69,1,70,1,70,1,70,5, + 70,1216,8,70,10,70,12,70,1219,9,70,1,70,3,70,1222,8,70,1,71,1,71,1,72, + 1,72,1,72,1,72,1,72,1,72,3,72,1232,8,72,3,72,1234,8,72,1,73,3,73,1237, + 8,73,1,73,1,73,1,73,1,73,1,73,1,73,3,73,1245,8,73,1,74,1,74,1,74,3,74, + 1250,8,74,1,75,1,75,1,76,1,76,1,77,1,77,1,78,1,78,3,78,1260,8,78,1,79, + 1,79,1,79,3,79,1265,8,79,1,80,1,80,1,80,1,80,1,81,1,81,1,81,1,81,1,82, + 1,82,3,82,1277,8,82,1,83,1,83,5,83,1281,8,83,10,83,12,83,1284,9,83,1, + 83,1,83,1,84,1,84,1,84,1,84,1,84,3,84,1293,8,84,1,85,1,85,5,85,1297,8, + 85,10,85,12,85,1300,9,85,1,85,1,85,1,86,1,86,1,86,1,86,1,86,3,86,1309, + 8,86,1,86,0,3,80,118,134,87,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,0,17,2,0,32,32,37,37,2,0,18,18, + 77,77,2,0,46,46,54,54,3,0,1,1,4,4,8,8,4,0,1,1,3,4,8,8,83,83,2,0,54,54, + 76,76,2,0,1,1,4,4,2,0,7,7,22,23,2,0,31,31,52,52,2,0,74,74,79,79,3,0,10, + 10,53,53,93,93,2,0,43,43,56,56,1,0,110,111,2,0,121,121,142,142,7,0,21, + 21,40,40,58,59,73,73,81,81,100,100,106,106,19,0,1,13,15,20,22,26,28,29, + 31,31,33,36,38,39,41,44,46,46,48,54,56,57,61,61,63,72,74,80,82,86,88, + 95,97,99,101,102,104,105,4,0,20,20,31,31,41,41,51,51,1484,0,177,1,0,0, + 0,2,184,1,0,0,0,4,186,1,0,0,0,6,188,1,0,0,0,8,195,1,0,0,0,10,218,1,0, + 0,0,12,220,1,0,0,0,14,227,1,0,0,0,16,234,1,0,0,0,18,247,1,0,0,0,20,259, + 1,0,0,0,22,268,1,0,0,0,24,276,1,0,0,0,26,298,1,0,0,0,28,313,1,0,0,0,30, + 322,1,0,0,0,32,327,1,0,0,0,34,331,1,0,0,0,36,333,1,0,0,0,38,342,1,0,0, + 0,40,346,1,0,0,0,42,360,1,0,0,0,44,370,1,0,0,0,46,376,1,0,0,0,48,380, + 1,0,0,0,50,388,1,0,0,0,52,437,1,0,0,0,54,440,1,0,0,0,56,446,1,0,0,0,58, + 450,1,0,0,0,60,456,1,0,0,0,62,474,1,0,0,0,64,477,1,0,0,0,66,480,1,0,0, + 0,68,490,1,0,0,0,70,493,1,0,0,0,72,497,1,0,0,0,74,530,1,0,0,0,76,532, + 1,0,0,0,78,535,1,0,0,0,80,550,1,0,0,0,82,612,1,0,0,0,84,617,1,0,0,0,86, + 628,1,0,0,0,88,630,1,0,0,0,90,636,1,0,0,0,92,644,1,0,0,0,94,662,1,0,0, + 0,96,664,1,0,0,0,98,672,1,0,0,0,100,677,1,0,0,0,102,685,1,0,0,0,104,689, + 1,0,0,0,106,693,1,0,0,0,108,702,1,0,0,0,110,716,1,0,0,0,112,718,1,0,0, + 0,114,777,1,0,0,0,116,779,1,0,0,0,118,940,1,0,0,0,120,1082,1,0,0,0,122, + 1121,1,0,0,0,124,1134,1,0,0,0,126,1136,1,0,0,0,128,1157,1,0,0,0,130,1166, + 1,0,0,0,132,1168,1,0,0,0,134,1185,1,0,0,0,136,1198,1,0,0,0,138,1208,1, + 0,0,0,140,1212,1,0,0,0,142,1223,1,0,0,0,144,1233,1,0,0,0,146,1236,1,0, + 0,0,148,1249,1,0,0,0,150,1251,1,0,0,0,152,1253,1,0,0,0,154,1255,1,0,0, + 0,156,1259,1,0,0,0,158,1264,1,0,0,0,160,1266,1,0,0,0,162,1270,1,0,0,0, + 164,1276,1,0,0,0,166,1278,1,0,0,0,168,1292,1,0,0,0,170,1294,1,0,0,0,172, + 1308,1,0,0,0,174,176,3,2,1,0,175,174,1,0,0,0,176,179,1,0,0,0,177,175, + 1,0,0,0,177,178,1,0,0,0,178,180,1,0,0,0,179,177,1,0,0,0,180,181,5,0,0, + 1,181,1,1,0,0,0,182,185,3,6,3,0,183,185,3,10,5,0,184,182,1,0,0,0,184, + 183,1,0,0,0,185,3,1,0,0,0,186,187,3,118,59,0,187,5,1,0,0,0,188,189,5, + 55,0,0,189,193,3,158,79,0,190,191,5,118,0,0,191,192,5,125,0,0,192,194, + 3,4,2,0,193,190,1,0,0,0,193,194,1,0,0,0,194,7,1,0,0,0,195,200,3,158,79, + 0,196,197,5,119,0,0,197,199,3,158,79,0,198,196,1,0,0,0,199,202,1,0,0, + 0,200,198,1,0,0,0,200,201,1,0,0,0,201,204,1,0,0,0,202,200,1,0,0,0,203, + 205,5,119,0,0,204,203,1,0,0,0,204,205,1,0,0,0,205,9,1,0,0,0,206,219,3, + 12,6,0,207,219,3,14,7,0,208,219,3,18,9,0,209,219,3,20,10,0,210,219,3, + 22,11,0,211,219,3,26,13,0,212,219,3,24,12,0,213,219,3,28,14,0,214,219, + 3,30,15,0,215,219,3,36,18,0,216,219,3,32,16,0,217,219,3,34,17,0,218,206, + 1,0,0,0,218,207,1,0,0,0,218,208,1,0,0,0,218,209,1,0,0,0,218,210,1,0,0, + 0,218,211,1,0,0,0,218,212,1,0,0,0,218,213,1,0,0,0,218,214,1,0,0,0,218, + 215,1,0,0,0,218,216,1,0,0,0,218,217,1,0,0,0,219,11,1,0,0,0,220,222,5, + 75,0,0,221,223,3,4,2,0,222,221,1,0,0,0,222,223,1,0,0,0,223,225,1,0,0, + 0,224,226,5,153,0,0,225,224,1,0,0,0,225,226,1,0,0,0,226,13,1,0,0,0,227, + 229,5,87,0,0,228,230,3,4,2,0,229,228,1,0,0,0,229,230,1,0,0,0,230,232, + 1,0,0,0,231,233,5,153,0,0,232,231,1,0,0,0,232,233,1,0,0,0,233,15,1,0, + 0,0,234,243,5,14,0,0,235,236,5,133,0,0,236,239,3,158,79,0,237,238,5,118, + 0,0,238,240,3,158,79,0,239,237,1,0,0,0,239,240,1,0,0,0,240,241,1,0,0, + 0,241,242,5,152,0,0,242,244,1,0,0,0,243,235,1,0,0,0,243,244,1,0,0,0,244, + 245,1,0,0,0,245,246,3,36,18,0,246,17,1,0,0,0,247,248,5,96,0,0,248,252, + 3,36,18,0,249,251,3,16,8,0,250,249,1,0,0,0,251,254,1,0,0,0,252,250,1, + 0,0,0,252,253,1,0,0,0,253,257,1,0,0,0,254,252,1,0,0,0,255,256,5,30,0, + 0,256,258,3,36,18,0,257,255,1,0,0,0,257,258,1,0,0,0,258,19,1,0,0,0,259, + 260,5,42,0,0,260,261,5,133,0,0,261,262,3,4,2,0,262,263,5,152,0,0,263, + 266,3,10,5,0,264,265,5,25,0,0,265,267,3,10,5,0,266,264,1,0,0,0,266,267, + 1,0,0,0,267,21,1,0,0,0,268,269,5,103,0,0,269,270,5,133,0,0,270,271,3, + 4,2,0,271,272,5,152,0,0,272,274,3,10,5,0,273,275,5,153,0,0,274,273,1, + 0,0,0,274,275,1,0,0,0,275,23,1,0,0,0,276,277,5,34,0,0,277,281,5,133,0, + 0,278,282,3,6,3,0,279,282,3,30,15,0,280,282,3,4,2,0,281,278,1,0,0,0,281, + 279,1,0,0,0,281,280,1,0,0,0,281,282,1,0,0,0,282,283,1,0,0,0,283,285,5, + 153,0,0,284,286,3,4,2,0,285,284,1,0,0,0,285,286,1,0,0,0,286,287,1,0,0, + 0,287,291,5,153,0,0,288,292,3,6,3,0,289,292,3,30,15,0,290,292,3,4,2,0, + 291,288,1,0,0,0,291,289,1,0,0,0,291,290,1,0,0,0,291,292,1,0,0,0,292,293, + 1,0,0,0,293,294,5,152,0,0,294,296,3,10,5,0,295,297,5,153,0,0,296,295, + 1,0,0,0,296,297,1,0,0,0,297,25,1,0,0,0,298,299,5,34,0,0,299,300,5,133, + 0,0,300,301,5,55,0,0,301,304,3,158,79,0,302,303,5,119,0,0,303,305,3,158, + 79,0,304,302,1,0,0,0,304,305,1,0,0,0,305,306,1,0,0,0,306,307,5,44,0,0, + 307,308,3,4,2,0,308,309,5,152,0,0,309,311,3,10,5,0,310,312,5,153,0,0, + 311,310,1,0,0,0,311,312,1,0,0,0,312,27,1,0,0,0,313,314,7,0,0,0,314,315, + 3,158,79,0,315,317,5,133,0,0,316,318,3,8,4,0,317,316,1,0,0,0,317,318, + 1,0,0,0,318,319,1,0,0,0,319,320,5,152,0,0,320,321,3,36,18,0,321,29,1, + 0,0,0,322,323,3,4,2,0,323,324,5,118,0,0,324,325,5,125,0,0,325,326,3,4, + 2,0,326,31,1,0,0,0,327,329,3,4,2,0,328,330,5,153,0,0,329,328,1,0,0,0, + 329,330,1,0,0,0,330,33,1,0,0,0,331,332,5,153,0,0,332,35,1,0,0,0,333,337, + 5,131,0,0,334,336,3,2,1,0,335,334,1,0,0,0,336,339,1,0,0,0,337,335,1,0, + 0,0,337,338,1,0,0,0,338,340,1,0,0,0,339,337,1,0,0,0,340,341,5,150,0,0, + 341,37,1,0,0,0,342,343,3,4,2,0,343,344,5,118,0,0,344,345,3,4,2,0,345, + 39,1,0,0,0,346,351,3,38,19,0,347,348,5,119,0,0,348,350,3,38,19,0,349, + 347,1,0,0,0,350,353,1,0,0,0,351,349,1,0,0,0,351,352,1,0,0,0,352,355,1, + 0,0,0,353,351,1,0,0,0,354,356,5,119,0,0,355,354,1,0,0,0,355,356,1,0,0, + 0,356,41,1,0,0,0,357,361,3,48,24,0,358,361,3,50,25,0,359,361,3,122,61, + 0,360,357,1,0,0,0,360,358,1,0,0,0,360,359,1,0,0,0,361,362,1,0,0,0,362, + 363,5,0,0,1,363,43,1,0,0,0,364,371,3,50,25,0,365,366,5,133,0,0,366,367, + 3,48,24,0,367,368,5,152,0,0,368,371,1,0,0,0,369,371,3,162,81,0,370,364, + 1,0,0,0,370,365,1,0,0,0,370,369,1,0,0,0,371,45,1,0,0,0,372,377,5,27,0, + 0,373,374,5,98,0,0,374,377,5,1,0,0,375,377,5,47,0,0,376,372,1,0,0,0,376, + 373,1,0,0,0,376,375,1,0,0,0,377,378,1,0,0,0,378,379,3,44,22,0,379,47, + 1,0,0,0,380,384,3,44,22,0,381,383,3,46,23,0,382,381,1,0,0,0,383,386,1, + 0,0,0,384,382,1,0,0,0,384,385,1,0,0,0,385,49,1,0,0,0,386,384,1,0,0,0, + 387,389,3,52,26,0,388,387,1,0,0,0,388,389,1,0,0,0,389,390,1,0,0,0,390, + 392,5,82,0,0,391,393,5,24,0,0,392,391,1,0,0,0,392,393,1,0,0,0,393,395, + 1,0,0,0,394,396,3,54,27,0,395,394,1,0,0,0,395,396,1,0,0,0,396,397,1,0, + 0,0,397,399,3,116,58,0,398,400,3,56,28,0,399,398,1,0,0,0,399,400,1,0, + 0,0,400,402,1,0,0,0,401,403,3,58,29,0,402,401,1,0,0,0,402,403,1,0,0,0, + 403,405,1,0,0,0,404,406,3,62,31,0,405,404,1,0,0,0,405,406,1,0,0,0,406, + 408,1,0,0,0,407,409,3,64,32,0,408,407,1,0,0,0,408,409,1,0,0,0,409,411, + 1,0,0,0,410,412,3,66,33,0,411,410,1,0,0,0,411,412,1,0,0,0,412,415,1,0, + 0,0,413,414,5,105,0,0,414,416,7,1,0,0,415,413,1,0,0,0,415,416,1,0,0,0, + 416,419,1,0,0,0,417,418,5,105,0,0,418,420,5,92,0,0,419,417,1,0,0,0,419, + 420,1,0,0,0,420,422,1,0,0,0,421,423,3,68,34,0,422,421,1,0,0,0,422,423, + 1,0,0,0,423,425,1,0,0,0,424,426,3,60,30,0,425,424,1,0,0,0,425,426,1,0, + 0,0,426,428,1,0,0,0,427,429,3,70,35,0,428,427,1,0,0,0,428,429,1,0,0,0, + 429,432,1,0,0,0,430,433,3,74,37,0,431,433,3,76,38,0,432,430,1,0,0,0,432, + 431,1,0,0,0,432,433,1,0,0,0,433,435,1,0,0,0,434,436,3,78,39,0,435,434, + 1,0,0,0,435,436,1,0,0,0,436,51,1,0,0,0,437,438,5,105,0,0,438,439,3,126, + 63,0,439,53,1,0,0,0,440,441,5,91,0,0,441,444,5,111,0,0,442,443,5,105, + 0,0,443,445,5,88,0,0,444,442,1,0,0,0,444,445,1,0,0,0,445,55,1,0,0,0,446, + 447,5,35,0,0,447,448,3,80,40,0,448,57,1,0,0,0,449,451,7,2,0,0,450,449, + 1,0,0,0,450,451,1,0,0,0,451,452,1,0,0,0,452,453,5,5,0,0,453,454,5,50, + 0,0,454,455,3,116,58,0,455,59,1,0,0,0,456,457,5,104,0,0,457,458,3,158, + 79,0,458,459,5,6,0,0,459,460,5,133,0,0,460,461,3,100,50,0,461,471,5,152, + 0,0,462,463,5,119,0,0,463,464,3,158,79,0,464,465,5,6,0,0,465,466,5,133, + 0,0,466,467,3,100,50,0,467,468,5,152,0,0,468,470,1,0,0,0,469,462,1,0, + 0,0,470,473,1,0,0,0,471,469,1,0,0,0,471,472,1,0,0,0,472,61,1,0,0,0,473, + 471,1,0,0,0,474,475,5,72,0,0,475,476,3,118,59,0,476,63,1,0,0,0,477,478, + 5,102,0,0,478,479,3,118,59,0,479,65,1,0,0,0,480,481,5,38,0,0,481,488, + 5,11,0,0,482,483,7,1,0,0,483,484,5,133,0,0,484,485,3,116,58,0,485,486, + 5,152,0,0,486,489,1,0,0,0,487,489,3,116,58,0,488,482,1,0,0,0,488,487, + 1,0,0,0,489,67,1,0,0,0,490,491,5,39,0,0,491,492,3,118,59,0,492,69,1,0, + 0,0,493,494,5,67,0,0,494,495,5,11,0,0,495,496,3,90,45,0,496,71,1,0,0, + 0,497,498,5,67,0,0,498,499,5,11,0,0,499,500,3,116,58,0,500,73,1,0,0,0, + 501,502,5,57,0,0,502,505,3,118,59,0,503,504,5,119,0,0,504,506,3,118,59, + 0,505,503,1,0,0,0,505,506,1,0,0,0,506,511,1,0,0,0,507,508,5,105,0,0,508, + 512,5,88,0,0,509,510,5,11,0,0,510,512,3,116,58,0,511,507,1,0,0,0,511, + 509,1,0,0,0,511,512,1,0,0,0,512,531,1,0,0,0,513,514,5,57,0,0,514,517, + 3,118,59,0,515,516,5,105,0,0,516,518,5,88,0,0,517,515,1,0,0,0,517,518, + 1,0,0,0,518,519,1,0,0,0,519,520,5,64,0,0,520,521,3,118,59,0,521,531,1, + 0,0,0,522,523,5,57,0,0,523,524,3,118,59,0,524,525,5,64,0,0,525,528,3, + 118,59,0,526,527,5,11,0,0,527,529,3,116,58,0,528,526,1,0,0,0,528,529, + 1,0,0,0,529,531,1,0,0,0,530,501,1,0,0,0,530,513,1,0,0,0,530,522,1,0,0, + 0,531,75,1,0,0,0,532,533,5,64,0,0,533,534,3,118,59,0,534,77,1,0,0,0,535, + 536,5,84,0,0,536,537,3,96,48,0,537,79,1,0,0,0,538,539,6,40,-1,0,539,541, + 3,134,67,0,540,542,5,29,0,0,541,540,1,0,0,0,541,542,1,0,0,0,542,544,1, + 0,0,0,543,545,3,88,44,0,544,543,1,0,0,0,544,545,1,0,0,0,545,551,1,0,0, + 0,546,547,5,133,0,0,547,548,3,80,40,0,548,549,5,152,0,0,549,551,1,0,0, + 0,550,538,1,0,0,0,550,546,1,0,0,0,551,566,1,0,0,0,552,553,10,3,0,0,553, + 554,3,84,42,0,554,555,3,80,40,4,555,565,1,0,0,0,556,558,10,4,0,0,557, + 559,3,82,41,0,558,557,1,0,0,0,558,559,1,0,0,0,559,560,1,0,0,0,560,561, + 5,50,0,0,561,562,3,80,40,0,562,563,3,86,43,0,563,565,1,0,0,0,564,552, + 1,0,0,0,564,556,1,0,0,0,565,568,1,0,0,0,566,564,1,0,0,0,566,567,1,0,0, + 0,567,81,1,0,0,0,568,566,1,0,0,0,569,571,7,3,0,0,570,569,1,0,0,0,570, + 571,1,0,0,0,571,572,1,0,0,0,572,579,5,46,0,0,573,575,5,46,0,0,574,576, + 7,3,0,0,575,574,1,0,0,0,575,576,1,0,0,0,576,579,1,0,0,0,577,579,7,3,0, + 0,578,570,1,0,0,0,578,573,1,0,0,0,578,577,1,0,0,0,579,613,1,0,0,0,580, + 582,7,4,0,0,581,580,1,0,0,0,581,582,1,0,0,0,582,583,1,0,0,0,583,585,7, + 5,0,0,584,586,5,68,0,0,585,584,1,0,0,0,585,586,1,0,0,0,586,595,1,0,0, + 0,587,589,7,5,0,0,588,590,5,68,0,0,589,588,1,0,0,0,589,590,1,0,0,0,590, + 592,1,0,0,0,591,593,7,4,0,0,592,591,1,0,0,0,592,593,1,0,0,0,593,595,1, + 0,0,0,594,581,1,0,0,0,594,587,1,0,0,0,595,613,1,0,0,0,596,598,7,6,0,0, + 597,596,1,0,0,0,597,598,1,0,0,0,598,599,1,0,0,0,599,601,5,36,0,0,600, + 602,5,68,0,0,601,600,1,0,0,0,601,602,1,0,0,0,602,611,1,0,0,0,603,605, + 5,36,0,0,604,606,5,68,0,0,605,604,1,0,0,0,605,606,1,0,0,0,606,608,1,0, + 0,0,607,609,7,6,0,0,608,607,1,0,0,0,608,609,1,0,0,0,609,611,1,0,0,0,610, + 597,1,0,0,0,610,603,1,0,0,0,611,613,1,0,0,0,612,578,1,0,0,0,612,594,1, + 0,0,0,612,610,1,0,0,0,613,83,1,0,0,0,614,615,5,17,0,0,615,618,5,50,0, + 0,616,618,5,119,0,0,617,614,1,0,0,0,617,616,1,0,0,0,618,85,1,0,0,0,619, + 620,5,65,0,0,620,629,3,116,58,0,621,622,5,99,0,0,622,623,5,133,0,0,623, + 624,3,116,58,0,624,625,5,152,0,0,625,629,1,0,0,0,626,627,5,99,0,0,627, + 629,3,116,58,0,628,619,1,0,0,0,628,621,1,0,0,0,628,626,1,0,0,0,629,87, + 1,0,0,0,630,631,5,80,0,0,631,634,3,94,47,0,632,633,5,64,0,0,633,635,3, + 94,47,0,634,632,1,0,0,0,634,635,1,0,0,0,635,89,1,0,0,0,636,641,3,92,46, + 0,637,638,5,119,0,0,638,640,3,92,46,0,639,637,1,0,0,0,640,643,1,0,0,0, + 641,639,1,0,0,0,641,642,1,0,0,0,642,91,1,0,0,0,643,641,1,0,0,0,644,646, + 3,118,59,0,645,647,7,7,0,0,646,645,1,0,0,0,646,647,1,0,0,0,647,650,1, + 0,0,0,648,649,5,63,0,0,649,651,7,8,0,0,650,648,1,0,0,0,650,651,1,0,0, + 0,651,654,1,0,0,0,652,653,5,16,0,0,653,655,5,113,0,0,654,652,1,0,0,0, + 654,655,1,0,0,0,655,93,1,0,0,0,656,663,3,162,81,0,657,660,3,146,73,0, + 658,659,5,154,0,0,659,661,3,146,73,0,660,658,1,0,0,0,660,661,1,0,0,0, + 661,663,1,0,0,0,662,656,1,0,0,0,662,657,1,0,0,0,663,95,1,0,0,0,664,669, + 3,98,49,0,665,666,5,119,0,0,666,668,3,98,49,0,667,665,1,0,0,0,668,671, + 1,0,0,0,669,667,1,0,0,0,669,670,1,0,0,0,670,97,1,0,0,0,671,669,1,0,0, + 0,672,673,3,158,79,0,673,674,5,125,0,0,674,675,3,148,74,0,675,99,1,0, + 0,0,676,678,3,102,51,0,677,676,1,0,0,0,677,678,1,0,0,0,678,680,1,0,0, + 0,679,681,3,104,52,0,680,679,1,0,0,0,680,681,1,0,0,0,681,683,1,0,0,0, + 682,684,3,106,53,0,683,682,1,0,0,0,683,684,1,0,0,0,684,101,1,0,0,0,685, + 686,5,70,0,0,686,687,5,11,0,0,687,688,3,116,58,0,688,103,1,0,0,0,689, + 690,5,67,0,0,690,691,5,11,0,0,691,692,3,90,45,0,692,105,1,0,0,0,693,694, + 7,9,0,0,694,695,3,108,54,0,695,107,1,0,0,0,696,703,3,110,55,0,697,698, + 5,9,0,0,698,699,3,110,55,0,699,700,5,2,0,0,700,701,3,110,55,0,701,703, + 1,0,0,0,702,696,1,0,0,0,702,697,1,0,0,0,703,109,1,0,0,0,704,705,5,19, + 0,0,705,717,5,78,0,0,706,707,5,97,0,0,707,717,5,71,0,0,708,709,5,97,0, + 0,709,717,5,33,0,0,710,711,3,146,73,0,711,712,5,71,0,0,712,717,1,0,0, + 0,713,714,3,146,73,0,714,715,5,33,0,0,715,717,1,0,0,0,716,704,1,0,0,0, + 716,706,1,0,0,0,716,708,1,0,0,0,716,710,1,0,0,0,716,713,1,0,0,0,717,111, + 1,0,0,0,718,719,3,118,59,0,719,720,5,0,0,1,720,113,1,0,0,0,721,778,3, + 158,79,0,722,723,3,158,79,0,723,724,5,133,0,0,724,725,3,158,79,0,725, + 732,3,114,57,0,726,727,5,119,0,0,727,728,3,158,79,0,728,729,3,114,57, + 0,729,731,1,0,0,0,730,726,1,0,0,0,731,734,1,0,0,0,732,730,1,0,0,0,732, + 733,1,0,0,0,733,736,1,0,0,0,734,732,1,0,0,0,735,737,5,119,0,0,736,735, + 1,0,0,0,736,737,1,0,0,0,737,738,1,0,0,0,738,739,5,152,0,0,739,778,1,0, + 0,0,740,741,3,158,79,0,741,742,5,133,0,0,742,747,3,160,80,0,743,744,5, + 119,0,0,744,746,3,160,80,0,745,743,1,0,0,0,746,749,1,0,0,0,747,745,1, + 0,0,0,747,748,1,0,0,0,748,751,1,0,0,0,749,747,1,0,0,0,750,752,5,119,0, + 0,751,750,1,0,0,0,751,752,1,0,0,0,752,753,1,0,0,0,753,754,5,152,0,0,754, + 778,1,0,0,0,755,756,3,158,79,0,756,757,5,133,0,0,757,762,3,114,57,0,758, + 759,5,119,0,0,759,761,3,114,57,0,760,758,1,0,0,0,761,764,1,0,0,0,762, + 760,1,0,0,0,762,763,1,0,0,0,763,766,1,0,0,0,764,762,1,0,0,0,765,767,5, + 119,0,0,766,765,1,0,0,0,766,767,1,0,0,0,767,768,1,0,0,0,768,769,5,152, + 0,0,769,778,1,0,0,0,770,771,3,158,79,0,771,773,5,133,0,0,772,774,3,116, + 58,0,773,772,1,0,0,0,773,774,1,0,0,0,774,775,1,0,0,0,775,776,5,152,0, + 0,776,778,1,0,0,0,777,721,1,0,0,0,777,722,1,0,0,0,777,740,1,0,0,0,777, + 755,1,0,0,0,777,770,1,0,0,0,778,115,1,0,0,0,779,784,3,118,59,0,780,781, + 5,119,0,0,781,783,3,118,59,0,782,780,1,0,0,0,783,786,1,0,0,0,784,782, + 1,0,0,0,784,785,1,0,0,0,785,788,1,0,0,0,786,784,1,0,0,0,787,789,5,119, + 0,0,788,787,1,0,0,0,788,789,1,0,0,0,789,117,1,0,0,0,790,791,6,59,-1,0, + 791,793,5,12,0,0,792,794,3,118,59,0,793,792,1,0,0,0,793,794,1,0,0,0,794, + 800,1,0,0,0,795,796,5,101,0,0,796,797,3,118,59,0,797,798,5,86,0,0,798, + 799,3,118,59,0,799,801,1,0,0,0,800,795,1,0,0,0,801,802,1,0,0,0,802,800, + 1,0,0,0,802,803,1,0,0,0,803,806,1,0,0,0,804,805,5,25,0,0,805,807,3,118, + 59,0,806,804,1,0,0,0,806,807,1,0,0,0,807,808,1,0,0,0,808,809,5,26,0,0, + 809,941,1,0,0,0,810,811,5,13,0,0,811,812,5,133,0,0,812,813,3,118,59,0, + 813,814,5,6,0,0,814,815,3,114,57,0,815,816,5,152,0,0,816,941,1,0,0,0, + 817,818,5,20,0,0,818,941,5,113,0,0,819,820,5,48,0,0,820,821,3,118,59, + 0,821,822,3,150,75,0,822,941,1,0,0,0,823,824,5,85,0,0,824,825,5,133,0, + 0,825,826,3,118,59,0,826,827,5,35,0,0,827,830,3,118,59,0,828,829,5,34, + 0,0,829,831,3,118,59,0,830,828,1,0,0,0,830,831,1,0,0,0,831,832,1,0,0, + 0,832,833,5,152,0,0,833,941,1,0,0,0,834,835,5,89,0,0,835,941,5,113,0, + 0,836,837,5,94,0,0,837,838,5,133,0,0,838,839,7,10,0,0,839,840,3,164,82, + 0,840,841,5,35,0,0,841,842,3,118,59,0,842,843,5,152,0,0,843,941,1,0,0, + 0,844,845,3,158,79,0,845,847,5,133,0,0,846,848,3,116,58,0,847,846,1,0, + 0,0,847,848,1,0,0,0,848,849,1,0,0,0,849,850,5,152,0,0,850,859,1,0,0,0, + 851,853,5,133,0,0,852,854,5,24,0,0,853,852,1,0,0,0,853,854,1,0,0,0,854, + 856,1,0,0,0,855,857,3,116,58,0,856,855,1,0,0,0,856,857,1,0,0,0,857,858, + 1,0,0,0,858,860,5,152,0,0,859,851,1,0,0,0,859,860,1,0,0,0,860,861,1,0, + 0,0,861,862,5,69,0,0,862,863,5,133,0,0,863,864,3,100,50,0,864,865,5,152, + 0,0,865,941,1,0,0,0,866,867,3,158,79,0,867,869,5,133,0,0,868,870,3,116, + 58,0,869,868,1,0,0,0,869,870,1,0,0,0,870,871,1,0,0,0,871,872,5,152,0, + 0,872,881,1,0,0,0,873,875,5,133,0,0,874,876,5,24,0,0,875,874,1,0,0,0, + 875,876,1,0,0,0,876,878,1,0,0,0,877,879,3,116,58,0,878,877,1,0,0,0,878, + 879,1,0,0,0,879,880,1,0,0,0,880,882,5,152,0,0,881,873,1,0,0,0,881,882, + 1,0,0,0,882,883,1,0,0,0,883,884,5,69,0,0,884,885,3,158,79,0,885,941,1, + 0,0,0,886,892,3,158,79,0,887,889,5,133,0,0,888,890,3,116,58,0,889,888, + 1,0,0,0,889,890,1,0,0,0,890,891,1,0,0,0,891,893,5,152,0,0,892,887,1,0, + 0,0,892,893,1,0,0,0,893,894,1,0,0,0,894,896,5,133,0,0,895,897,5,24,0, + 0,896,895,1,0,0,0,896,897,1,0,0,0,897,899,1,0,0,0,898,900,3,116,58,0, + 899,898,1,0,0,0,899,900,1,0,0,0,900,901,1,0,0,0,901,902,5,152,0,0,902, + 941,1,0,0,0,903,941,3,122,61,0,904,941,3,166,83,0,905,941,3,148,74,0, + 906,907,5,121,0,0,907,941,3,118,59,20,908,909,5,61,0,0,909,941,3,118, + 59,14,910,911,3,138,69,0,911,912,5,123,0,0,912,914,1,0,0,0,913,910,1, + 0,0,0,913,914,1,0,0,0,914,915,1,0,0,0,915,941,5,115,0,0,916,917,5,133, + 0,0,917,918,3,48,24,0,918,919,5,152,0,0,919,941,1,0,0,0,920,921,5,133, + 0,0,921,922,3,118,59,0,922,923,5,152,0,0,923,941,1,0,0,0,924,925,5,133, + 0,0,925,926,3,116,58,0,926,927,5,152,0,0,927,941,1,0,0,0,928,930,5,132, + 0,0,929,931,3,116,58,0,930,929,1,0,0,0,930,931,1,0,0,0,931,932,1,0,0, + 0,932,941,5,151,0,0,933,935,5,131,0,0,934,936,3,40,20,0,935,934,1,0,0, + 0,935,936,1,0,0,0,936,937,1,0,0,0,937,941,5,150,0,0,938,941,3,120,60, + 0,939,941,3,130,65,0,940,790,1,0,0,0,940,810,1,0,0,0,940,817,1,0,0,0, + 940,819,1,0,0,0,940,823,1,0,0,0,940,834,1,0,0,0,940,836,1,0,0,0,940,844, + 1,0,0,0,940,866,1,0,0,0,940,886,1,0,0,0,940,903,1,0,0,0,940,904,1,0,0, + 0,940,905,1,0,0,0,940,906,1,0,0,0,940,908,1,0,0,0,940,913,1,0,0,0,940, + 916,1,0,0,0,940,920,1,0,0,0,940,924,1,0,0,0,940,928,1,0,0,0,940,933,1, + 0,0,0,940,938,1,0,0,0,940,939,1,0,0,0,941,1052,1,0,0,0,942,946,10,19, + 0,0,943,947,5,115,0,0,944,947,5,154,0,0,945,947,5,141,0,0,946,943,1,0, + 0,0,946,944,1,0,0,0,946,945,1,0,0,0,947,948,1,0,0,0,948,1051,3,118,59, + 20,949,953,10,18,0,0,950,954,5,142,0,0,951,954,5,121,0,0,952,954,5,120, + 0,0,953,950,1,0,0,0,953,951,1,0,0,0,953,952,1,0,0,0,954,955,1,0,0,0,955, + 1051,3,118,59,19,956,981,10,17,0,0,957,982,5,124,0,0,958,982,5,125,0, + 0,959,982,5,136,0,0,960,982,5,134,0,0,961,982,5,135,0,0,962,982,5,126, + 0,0,963,982,5,127,0,0,964,966,5,61,0,0,965,964,1,0,0,0,965,966,1,0,0, + 0,966,967,1,0,0,0,967,969,5,44,0,0,968,970,5,15,0,0,969,968,1,0,0,0,969, + 970,1,0,0,0,970,982,1,0,0,0,971,973,5,61,0,0,972,971,1,0,0,0,972,973, + 1,0,0,0,973,974,1,0,0,0,974,982,7,11,0,0,975,982,5,148,0,0,976,982,5, + 149,0,0,977,982,5,138,0,0,978,982,5,129,0,0,979,982,5,130,0,0,980,982, + 5,137,0,0,981,957,1,0,0,0,981,958,1,0,0,0,981,959,1,0,0,0,981,960,1,0, + 0,0,981,961,1,0,0,0,981,962,1,0,0,0,981,963,1,0,0,0,981,965,1,0,0,0,981, + 972,1,0,0,0,981,975,1,0,0,0,981,976,1,0,0,0,981,977,1,0,0,0,981,978,1, + 0,0,0,981,979,1,0,0,0,981,980,1,0,0,0,982,983,1,0,0,0,983,1051,3,118, + 59,18,984,985,10,15,0,0,985,986,5,140,0,0,986,1051,3,118,59,16,987,988, + 10,13,0,0,988,989,5,2,0,0,989,1051,3,118,59,14,990,991,10,12,0,0,991, + 992,5,66,0,0,992,1051,3,118,59,13,993,995,10,11,0,0,994,996,5,61,0,0, + 995,994,1,0,0,0,995,996,1,0,0,0,996,997,1,0,0,0,997,998,5,9,0,0,998,999, + 3,118,59,0,999,1000,5,2,0,0,1000,1001,3,118,59,12,1001,1051,1,0,0,0,1002, + 1003,10,10,0,0,1003,1004,5,143,0,0,1004,1005,3,118,59,0,1005,1006,5,118, + 0,0,1006,1007,3,118,59,10,1007,1051,1,0,0,0,1008,1009,10,30,0,0,1009, + 1011,5,133,0,0,1010,1012,3,116,58,0,1011,1010,1,0,0,0,1011,1012,1,0,0, + 0,1012,1013,1,0,0,0,1013,1051,5,152,0,0,1014,1015,10,26,0,0,1015,1016, + 5,132,0,0,1016,1017,3,118,59,0,1017,1018,5,151,0,0,1018,1051,1,0,0,0, + 1019,1020,10,25,0,0,1020,1021,5,123,0,0,1021,1051,5,111,0,0,1022,1023, + 10,24,0,0,1023,1024,5,123,0,0,1024,1051,3,158,79,0,1025,1026,10,23,0, + 0,1026,1027,5,139,0,0,1027,1028,5,132,0,0,1028,1029,3,118,59,0,1029,1030, + 5,151,0,0,1030,1051,1,0,0,0,1031,1032,10,22,0,0,1032,1033,5,139,0,0,1033, + 1051,5,111,0,0,1034,1035,10,21,0,0,1035,1036,5,139,0,0,1036,1051,3,158, + 79,0,1037,1038,10,16,0,0,1038,1040,5,49,0,0,1039,1041,5,61,0,0,1040,1039, + 1,0,0,0,1040,1041,1,0,0,0,1041,1042,1,0,0,0,1042,1051,5,62,0,0,1043,1048, + 10,9,0,0,1044,1045,5,6,0,0,1045,1049,3,158,79,0,1046,1047,5,6,0,0,1047, + 1049,5,113,0,0,1048,1044,1,0,0,0,1048,1046,1,0,0,0,1049,1051,1,0,0,0, + 1050,942,1,0,0,0,1050,949,1,0,0,0,1050,956,1,0,0,0,1050,984,1,0,0,0,1050, + 987,1,0,0,0,1050,990,1,0,0,0,1050,993,1,0,0,0,1050,1002,1,0,0,0,1050, + 1008,1,0,0,0,1050,1014,1,0,0,0,1050,1019,1,0,0,0,1050,1022,1,0,0,0,1050, + 1025,1,0,0,0,1050,1031,1,0,0,0,1050,1034,1,0,0,0,1050,1037,1,0,0,0,1050, + 1043,1,0,0,0,1051,1054,1,0,0,0,1052,1050,1,0,0,0,1052,1053,1,0,0,0,1053, + 119,1,0,0,0,1054,1052,1,0,0,0,1055,1056,5,133,0,0,1056,1061,3,158,79, + 0,1057,1058,5,119,0,0,1058,1060,3,158,79,0,1059,1057,1,0,0,0,1060,1063, + 1,0,0,0,1061,1059,1,0,0,0,1061,1062,1,0,0,0,1062,1065,1,0,0,0,1063,1061, + 1,0,0,0,1064,1066,5,119,0,0,1065,1064,1,0,0,0,1065,1066,1,0,0,0,1066, + 1067,1,0,0,0,1067,1068,5,152,0,0,1068,1083,1,0,0,0,1069,1074,3,158,79, + 0,1070,1071,5,119,0,0,1071,1073,3,158,79,0,1072,1070,1,0,0,0,1073,1076, + 1,0,0,0,1074,1072,1,0,0,0,1074,1075,1,0,0,0,1075,1078,1,0,0,0,1076,1074, + 1,0,0,0,1077,1079,5,119,0,0,1078,1077,1,0,0,0,1078,1079,1,0,0,0,1079, + 1083,1,0,0,0,1080,1081,5,133,0,0,1081,1083,5,152,0,0,1082,1055,1,0,0, + 0,1082,1069,1,0,0,0,1082,1080,1,0,0,0,1083,1084,1,0,0,0,1084,1087,5,114, + 0,0,1085,1088,3,118,59,0,1086,1088,3,36,18,0,1087,1085,1,0,0,0,1087,1086, + 1,0,0,0,1088,121,1,0,0,0,1089,1090,5,135,0,0,1090,1094,3,158,79,0,1091, + 1093,3,124,62,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,154, + 0,0,1098,1099,5,127,0,0,1099,1122,1,0,0,0,1100,1101,5,135,0,0,1101,1105, + 3,158,79,0,1102,1104,3,124,62,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,127,0,0,1109,1115,3,122,61,0,1110,1111,5,131,0,0,1111,1112,3,118, + 59,0,1112,1113,5,150,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,135,0,0,1117, + 1118,5,154,0,0,1118,1119,3,158,79,0,1119,1120,5,127,0,0,1120,1122,1,0, + 0,0,1121,1089,1,0,0,0,1121,1100,1,0,0,0,1122,123,1,0,0,0,1123,1124,3, + 158,79,0,1124,1125,5,125,0,0,1125,1126,3,164,82,0,1126,1135,1,0,0,0,1127, + 1128,3,158,79,0,1128,1129,5,125,0,0,1129,1130,5,131,0,0,1130,1131,3,118, + 59,0,1131,1132,5,150,0,0,1132,1135,1,0,0,0,1133,1135,3,158,79,0,1134, + 1123,1,0,0,0,1134,1127,1,0,0,0,1134,1133,1,0,0,0,1135,125,1,0,0,0,1136, + 1141,3,128,64,0,1137,1138,5,119,0,0,1138,1140,3,128,64,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,119,0,0,1145,1144,1,0,0,0,1145, + 1146,1,0,0,0,1146,127,1,0,0,0,1147,1148,3,158,79,0,1148,1149,5,6,0,0, + 1149,1150,5,133,0,0,1150,1151,3,48,24,0,1151,1152,5,152,0,0,1152,1158, + 1,0,0,0,1153,1154,3,118,59,0,1154,1155,5,6,0,0,1155,1156,3,158,79,0,1156, + 1158,1,0,0,0,1157,1147,1,0,0,0,1157,1153,1,0,0,0,1158,129,1,0,0,0,1159, + 1167,3,162,81,0,1160,1161,3,138,69,0,1161,1162,5,123,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,132,66,0,1166,1159,1,0,0,0,1166,1163,1,0,0,0,1167,131,1,0,0,0,1168, + 1173,3,158,79,0,1169,1170,5,123,0,0,1170,1172,3,158,79,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,133, + 1,0,0,0,1175,1173,1,0,0,0,1176,1177,6,67,-1,0,1177,1186,3,138,69,0,1178, + 1186,3,136,68,0,1179,1180,5,133,0,0,1180,1181,3,48,24,0,1181,1182,5,152, + 0,0,1182,1186,1,0,0,0,1183,1186,3,122,61,0,1184,1186,3,162,81,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,156,78, + 0,1189,1190,5,6,0,0,1190,1192,3,158,79,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,135,1,0,0,0,1197,1195,1,0,0,0,1198,1199, + 3,158,79,0,1199,1201,5,133,0,0,1200,1202,3,140,70,0,1201,1200,1,0,0,0, + 1201,1202,1,0,0,0,1202,1203,1,0,0,0,1203,1204,5,152,0,0,1204,137,1,0, + 0,0,1205,1206,3,142,71,0,1206,1207,5,123,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,158,79,0,1211, + 139,1,0,0,0,1212,1217,3,118,59,0,1213,1214,5,119,0,0,1214,1216,3,118, + 59,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,119,0,0,1221, + 1220,1,0,0,0,1221,1222,1,0,0,0,1222,141,1,0,0,0,1223,1224,3,158,79,0, + 1224,143,1,0,0,0,1225,1234,5,109,0,0,1226,1227,5,123,0,0,1227,1234,7, + 12,0,0,1228,1229,5,111,0,0,1229,1231,5,123,0,0,1230,1232,7,12,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,145,1,0,0,0,1235,1237,7,13,0,0,1236, + 1235,1,0,0,0,1236,1237,1,0,0,0,1237,1244,1,0,0,0,1238,1245,3,144,72,0, + 1239,1245,5,110,0,0,1240,1245,5,111,0,0,1241,1245,5,112,0,0,1242,1245, + 5,45,0,0,1243,1245,5,60,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, + 147,1,0,0,0,1246,1250,3,146,73,0,1247,1250,5,113,0,0,1248,1250,5,62,0, + 0,1249,1246,1,0,0,0,1249,1247,1,0,0,0,1249,1248,1,0,0,0,1250,149,1,0, + 0,0,1251,1252,7,14,0,0,1252,151,1,0,0,0,1253,1254,7,15,0,0,1254,153,1, + 0,0,0,1255,1256,7,16,0,0,1256,155,1,0,0,0,1257,1260,5,108,0,0,1258,1260, + 3,154,77,0,1259,1257,1,0,0,0,1259,1258,1,0,0,0,1260,157,1,0,0,0,1261, + 1265,5,108,0,0,1262,1265,3,150,75,0,1263,1265,3,152,76,0,1264,1261,1, + 0,0,0,1264,1262,1,0,0,0,1264,1263,1,0,0,0,1265,159,1,0,0,0,1266,1267, + 3,164,82,0,1267,1268,5,125,0,0,1268,1269,3,146,73,0,1269,161,1,0,0,0, + 1270,1271,5,131,0,0,1271,1272,3,118,59,0,1272,1273,5,150,0,0,1273,163, + 1,0,0,0,1274,1277,5,113,0,0,1275,1277,3,166,83,0,1276,1274,1,0,0,0,1276, + 1275,1,0,0,0,1277,165,1,0,0,0,1278,1282,5,145,0,0,1279,1281,3,168,84, + 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,147,0,0,1286,167, + 1,0,0,0,1287,1288,5,160,0,0,1288,1289,3,118,59,0,1289,1290,5,150,0,0, + 1290,1293,1,0,0,0,1291,1293,5,159,0,0,1292,1287,1,0,0,0,1292,1291,1,0, + 0,0,1293,169,1,0,0,0,1294,1298,5,146,0,0,1295,1297,3,172,86,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,171,1,0,0,0,1303,1304, + 5,162,0,0,1304,1305,3,118,59,0,1305,1306,5,150,0,0,1306,1309,1,0,0,0, + 1307,1309,5,161,0,0,1308,1303,1,0,0,0,1308,1307,1,0,0,0,1309,173,1,0, + 0,0,168,177,184,193,200,204,218,222,225,229,232,239,243,252,257,266,274, + 281,285,291,296,304,311,317,329,337,351,355,360,370,376,384,388,392,395, + 399,402,405,408,411,415,419,422,425,428,432,435,444,450,471,488,505,511, + 517,528,530,541,544,550,558,564,566,570,575,578,581,585,589,592,594,597, + 601,605,608,610,612,617,628,634,641,646,650,654,660,662,669,677,680,683, + 702,716,732,736,747,751,762,766,773,777,784,788,793,802,806,830,847,853, + 856,859,869,875,878,881,889,892,896,899,913,930,935,940,946,953,965,969, + 972,981,995,1011,1040,1048,1050,1052,1061,1065,1074,1078,1082,1087,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 }; staticData->serializedATN = antlr4::atn::SerializedATNView(serializedATNSegment, sizeof(serializedATNSegment) / sizeof(serializedATNSegment[0])); @@ -693,20 +699,20 @@ HogQLParser::ProgramContext* HogQLParser::program() { }); try { enterOuterAlt(_localctx, 1); - setState(175); + setState(177); _errHandler->sync(this); _la = _input->LA(1); while ((((_la & ~ 0x3fULL) == 0) && - ((1ULL << _la) & -536887298) != 0) || ((((_la - 64) & ~ 0x3fULL) == 0) && - ((1ULL << (_la - 64)) & 180986211001696255) != 0) || ((((_la - 129) & ~ 0x3fULL) == 0) && - ((1ULL << (_la - 129)) & 4212759) != 0)) { - setState(172); + ((1ULL << _la) & -140738696331266) != 0) || ((((_la - 64) & ~ 0x3fULL) == 0) && + ((1ULL << (_la - 64)) & 723944844006785023) != 0) || ((((_la - 131) & ~ 0x3fULL) == 0) && + ((1ULL << (_la - 131)) & 4212759) != 0)) { + setState(174); declaration(); - setState(177); + setState(179); _errHandler->sync(this); _la = _input->LA(1); } - setState(178); + setState(180); match(HogQLParser::EOF); } @@ -758,12 +764,12 @@ HogQLParser::DeclarationContext* HogQLParser::declaration() { exitRule(); }); try { - setState(182); + setState(184); _errHandler->sync(this); switch (_input->LA(1)) { case HogQLParser::LET: { enterOuterAlt(_localctx, 1); - setState(180); + setState(182); varDecl(); break; } @@ -886,7 +892,7 @@ HogQLParser::DeclarationContext* HogQLParser::declaration() { case HogQLParser::QUOTE_SINGLE_TEMPLATE: case HogQLParser::SEMICOLON: { enterOuterAlt(_localctx, 2); - setState(181); + setState(183); statement(); break; } @@ -941,7 +947,7 @@ HogQLParser::ExpressionContext* HogQLParser::expression() { }); try { enterOuterAlt(_localctx, 1); - setState(184); + setState(186); columnExpr(0); } @@ -1007,20 +1013,20 @@ HogQLParser::VarDeclContext* HogQLParser::varDecl() { }); try { enterOuterAlt(_localctx, 1); - setState(186); + setState(188); match(HogQLParser::LET); - setState(187); + setState(189); identifier(); - setState(191); + setState(193); _errHandler->sync(this); _la = _input->LA(1); if (_la == HogQLParser::COLON) { - setState(188); + setState(190); match(HogQLParser::COLON); - setState(189); + setState(191); match(HogQLParser::EQ_SINGLE); - setState(190); + setState(192); expression(); } @@ -1084,28 +1090,28 @@ HogQLParser::IdentifierListContext* HogQLParser::identifierList() { try { size_t alt; enterOuterAlt(_localctx, 1); - setState(193); + setState(195); identifier(); - setState(198); + setState(200); _errHandler->sync(this); alt = getInterpreter()->adaptivePredict(_input, 3, _ctx); while (alt != 2 && alt != atn::ATN::INVALID_ALT_NUMBER) { if (alt == 1) { - setState(194); + setState(196); match(HogQLParser::COMMA); - setState(195); + setState(197); identifier(); } - setState(200); + setState(202); _errHandler->sync(this); alt = getInterpreter()->adaptivePredict(_input, 3, _ctx); } - setState(202); + setState(204); _errHandler->sync(this); _la = _input->LA(1); if (_la == HogQLParser::COMMA) { - setState(201); + setState(203); match(HogQLParser::COMMA); } @@ -1198,89 +1204,89 @@ HogQLParser::StatementContext* HogQLParser::statement() { exitRule(); }); try { - setState(216); + setState(218); _errHandler->sync(this); switch (getInterpreter()->adaptivePredict(_input, 5, _ctx)) { case 1: { enterOuterAlt(_localctx, 1); - setState(204); + setState(206); returnStmt(); break; } case 2: { enterOuterAlt(_localctx, 2); - setState(205); + setState(207); throwStmt(); break; } case 3: { enterOuterAlt(_localctx, 3); - setState(206); + setState(208); tryCatchStmt(); break; } case 4: { enterOuterAlt(_localctx, 4); - setState(207); + setState(209); ifStmt(); break; } case 5: { enterOuterAlt(_localctx, 5); - setState(208); + setState(210); whileStmt(); break; } case 6: { enterOuterAlt(_localctx, 6); - setState(209); + setState(211); forInStmt(); break; } case 7: { enterOuterAlt(_localctx, 7); - setState(210); + setState(212); forStmt(); break; } case 8: { enterOuterAlt(_localctx, 8); - setState(211); + setState(213); funcStmt(); break; } case 9: { enterOuterAlt(_localctx, 9); - setState(212); + setState(214); varAssignment(); break; } case 10: { enterOuterAlt(_localctx, 10); - setState(213); + setState(215); block(); break; } case 11: { enterOuterAlt(_localctx, 11); - setState(214); + setState(216); exprStmt(); break; } case 12: { enterOuterAlt(_localctx, 12); - setState(215); + setState(217); emptyStmt(); break; } @@ -1343,14 +1349,14 @@ HogQLParser::ReturnStmtContext* HogQLParser::returnStmt() { }); try { enterOuterAlt(_localctx, 1); - setState(218); - match(HogQLParser::RETURN); setState(220); + match(HogQLParser::RETURN); + setState(222); _errHandler->sync(this); switch (getInterpreter()->adaptivePredict(_input, 6, _ctx)) { case 1: { - setState(219); + setState(221); expression(); break; } @@ -1358,12 +1364,12 @@ HogQLParser::ReturnStmtContext* HogQLParser::returnStmt() { default: break; } - setState(223); + setState(225); _errHandler->sync(this); switch (getInterpreter()->adaptivePredict(_input, 7, _ctx)) { case 1: { - setState(222); + setState(224); match(HogQLParser::SEMICOLON); break; } @@ -1426,14 +1432,14 @@ HogQLParser::ThrowStmtContext* HogQLParser::throwStmt() { }); try { enterOuterAlt(_localctx, 1); - setState(225); - match(HogQLParser::THROW); setState(227); + match(HogQLParser::THROW); + setState(229); _errHandler->sync(this); switch (getInterpreter()->adaptivePredict(_input, 8, _ctx)) { case 1: { - setState(226); + setState(228); expression(); break; } @@ -1441,12 +1447,12 @@ HogQLParser::ThrowStmtContext* HogQLParser::throwStmt() { default: break; } - setState(230); + setState(232); _errHandler->sync(this); switch (getInterpreter()->adaptivePredict(_input, 9, _ctx)) { case 1: { - setState(229); + setState(231); match(HogQLParser::SEMICOLON); break; } @@ -1526,31 +1532,31 @@ HogQLParser::CatchBlockContext* HogQLParser::catchBlock() { }); try { enterOuterAlt(_localctx, 1); - setState(232); + setState(234); match(HogQLParser::CATCH); - setState(241); + setState(243); _errHandler->sync(this); _la = _input->LA(1); if (_la == HogQLParser::LPAREN) { - setState(233); + setState(235); match(HogQLParser::LPAREN); - setState(234); + setState(236); antlrcpp::downCast(_localctx)->catchVar = identifier(); - setState(237); + setState(239); _errHandler->sync(this); _la = _input->LA(1); if (_la == HogQLParser::COLON) { - setState(235); + setState(237); match(HogQLParser::COLON); - setState(236); + setState(238); antlrcpp::downCast(_localctx)->catchType = identifier(); } - setState(239); + setState(241); match(HogQLParser::RPAREN); } - setState(243); + setState(245); antlrcpp::downCast(_localctx)->catchStmt = block(); } @@ -1620,28 +1626,28 @@ HogQLParser::TryCatchStmtContext* HogQLParser::tryCatchStmt() { }); try { enterOuterAlt(_localctx, 1); - setState(245); + setState(247); match(HogQLParser::TRY); - setState(246); + setState(248); antlrcpp::downCast(_localctx)->tryStmt = block(); - setState(250); + setState(252); _errHandler->sync(this); _la = _input->LA(1); while (_la == HogQLParser::CATCH) { - setState(247); + setState(249); catchBlock(); - setState(252); + setState(254); _errHandler->sync(this); _la = _input->LA(1); } - setState(255); + setState(257); _errHandler->sync(this); _la = _input->LA(1); if (_la == HogQLParser::FINALLY) { - setState(253); + setState(255); match(HogQLParser::FINALLY); - setState(254); + setState(256); antlrcpp::downCast(_localctx)->finallyStmt = block(); } @@ -1715,24 +1721,24 @@ HogQLParser::IfStmtContext* HogQLParser::ifStmt() { }); try { enterOuterAlt(_localctx, 1); - setState(257); + setState(259); match(HogQLParser::IF); - setState(258); + setState(260); match(HogQLParser::LPAREN); - setState(259); + setState(261); expression(); - setState(260); + setState(262); match(HogQLParser::RPAREN); - setState(261); + setState(263); statement(); - setState(264); + setState(266); _errHandler->sync(this); switch (getInterpreter()->adaptivePredict(_input, 14, _ctx)) { case 1: { - setState(262); + setState(264); match(HogQLParser::ELSE); - setState(263); + setState(265); statement(); break; } @@ -1807,22 +1813,22 @@ HogQLParser::WhileStmtContext* HogQLParser::whileStmt() { }); try { enterOuterAlt(_localctx, 1); - setState(266); + setState(268); match(HogQLParser::WHILE); - setState(267); + setState(269); match(HogQLParser::LPAREN); - setState(268); + setState(270); expression(); - setState(269); + setState(271); match(HogQLParser::RPAREN); - setState(270); - statement(); setState(272); + statement(); + setState(274); _errHandler->sync(this); switch (getInterpreter()->adaptivePredict(_input, 15, _ctx)) { case 1: { - setState(271); + setState(273); match(HogQLParser::SEMICOLON); break; } @@ -1922,28 +1928,28 @@ HogQLParser::ForStmtContext* HogQLParser::forStmt() { }); try { enterOuterAlt(_localctx, 1); - setState(274); + setState(276); match(HogQLParser::FOR); - setState(275); + setState(277); match(HogQLParser::LPAREN); - setState(279); + setState(281); _errHandler->sync(this); switch (getInterpreter()->adaptivePredict(_input, 16, _ctx)) { case 1: { - setState(276); + setState(278); antlrcpp::downCast(_localctx)->initializerVarDeclr = varDecl(); break; } case 2: { - setState(277); + setState(279); antlrcpp::downCast(_localctx)->initializerVarAssignment = varAssignment(); break; } case 3: { - setState(278); + setState(280); antlrcpp::downCast(_localctx)->initializerExpression = expression(); break; } @@ -1951,39 +1957,39 @@ HogQLParser::ForStmtContext* HogQLParser::forStmt() { default: break; } - setState(281); - match(HogQLParser::SEMICOLON); setState(283); + match(HogQLParser::SEMICOLON); + setState(285); _errHandler->sync(this); _la = _input->LA(1); if ((((_la & ~ 0x3fULL) == 0) && - ((1ULL << _la) & -9007270658588674) != 0) || ((((_la - 64) & ~ 0x3fULL) == 0) && - ((1ULL << (_la - 64)) & 180986072486903807) != 0) || ((((_la - 129) & ~ 0x3fULL) == 0) && - ((1ULL << (_la - 129)) & 18455) != 0)) { - setState(282); + ((1ULL << _la) & -36169677449216002) != 0) || ((((_la - 64) & ~ 0x3fULL) == 0) && + ((1ULL << (_la - 64)) & 723944289947615231) != 0) || ((((_la - 131) & ~ 0x3fULL) == 0) && + ((1ULL << (_la - 131)) & 18455) != 0)) { + setState(284); antlrcpp::downCast(_localctx)->condition = expression(); } - setState(285); + setState(287); match(HogQLParser::SEMICOLON); - setState(289); + setState(291); _errHandler->sync(this); switch (getInterpreter()->adaptivePredict(_input, 18, _ctx)) { case 1: { - setState(286); + setState(288); antlrcpp::downCast(_localctx)->incrementVarDeclr = varDecl(); break; } case 2: { - setState(287); + setState(289); antlrcpp::downCast(_localctx)->incrementVarAssignment = varAssignment(); break; } case 3: { - setState(288); + setState(290); antlrcpp::downCast(_localctx)->incrementExpression = expression(); break; } @@ -1991,16 +1997,16 @@ HogQLParser::ForStmtContext* HogQLParser::forStmt() { default: break; } - setState(291); + setState(293); match(HogQLParser::RPAREN); - setState(292); - statement(); setState(294); + statement(); + setState(296); _errHandler->sync(this); switch (getInterpreter()->adaptivePredict(_input, 19, _ctx)) { case 1: { - setState(293); + setState(295); match(HogQLParser::SEMICOLON); break; } @@ -2096,38 +2102,38 @@ HogQLParser::ForInStmtContext* HogQLParser::forInStmt() { }); try { enterOuterAlt(_localctx, 1); - setState(296); + setState(298); match(HogQLParser::FOR); - setState(297); + setState(299); match(HogQLParser::LPAREN); - setState(298); + setState(300); match(HogQLParser::LET); - setState(299); + setState(301); identifier(); - setState(302); + setState(304); _errHandler->sync(this); _la = _input->LA(1); if (_la == HogQLParser::COMMA) { - setState(300); + setState(302); match(HogQLParser::COMMA); - setState(301); + setState(303); identifier(); } - setState(304); + setState(306); match(HogQLParser::IN); - setState(305); + setState(307); expression(); - setState(306); + setState(308); match(HogQLParser::RPAREN); - setState(307); - statement(); setState(309); + statement(); + setState(311); _errHandler->sync(this); switch (getInterpreter()->adaptivePredict(_input, 21, _ctx)) { case 1: { - setState(308); + setState(310); match(HogQLParser::SEMICOLON); break; } @@ -2207,7 +2213,7 @@ HogQLParser::FuncStmtContext* HogQLParser::funcStmt() { }); try { enterOuterAlt(_localctx, 1); - setState(311); + setState(313); _la = _input->LA(1); if (!(_la == HogQLParser::FN @@ -2218,23 +2224,23 @@ HogQLParser::FuncStmtContext* HogQLParser::funcStmt() { _errHandler->reportMatch(this); consume(); } - setState(312); + setState(314); identifier(); - setState(313); - match(HogQLParser::LPAREN); setState(315); + match(HogQLParser::LPAREN); + setState(317); _errHandler->sync(this); _la = _input->LA(1); if ((((_la & ~ 0x3fULL) == 0) && - ((1ULL << _la) & -1450176743603191810) != 0) || ((((_la - 64) & ~ 0x3fULL) == 0) && - ((1ULL << (_la - 64)) & 6458554974207) != 0)) { - setState(314); + ((1ULL << _la) & -5800812384855539714) != 0) || ((((_la - 64) & ~ 0x3fULL) == 0) && + ((1ULL << (_la - 64)) & 25834219896831) != 0)) { + setState(316); identifierList(); } - setState(317); + setState(319); match(HogQLParser::RPAREN); - setState(318); + setState(320); block(); } @@ -2295,13 +2301,13 @@ HogQLParser::VarAssignmentContext* HogQLParser::varAssignment() { }); try { enterOuterAlt(_localctx, 1); - setState(320); + setState(322); expression(); - setState(321); + setState(323); match(HogQLParser::COLON); - setState(322); + setState(324); match(HogQLParser::EQ_SINGLE); - setState(323); + setState(325); expression(); } @@ -2354,14 +2360,14 @@ HogQLParser::ExprStmtContext* HogQLParser::exprStmt() { }); try { enterOuterAlt(_localctx, 1); - setState(325); - expression(); setState(327); + expression(); + setState(329); _errHandler->sync(this); switch (getInterpreter()->adaptivePredict(_input, 23, _ctx)) { case 1: { - setState(326); + setState(328); match(HogQLParser::SEMICOLON); break; } @@ -2416,7 +2422,7 @@ HogQLParser::EmptyStmtContext* HogQLParser::emptyStmt() { }); try { enterOuterAlt(_localctx, 1); - setState(329); + setState(331); match(HogQLParser::SEMICOLON); } @@ -2478,22 +2484,22 @@ HogQLParser::BlockContext* HogQLParser::block() { }); try { enterOuterAlt(_localctx, 1); - setState(331); + setState(333); match(HogQLParser::LBRACE); - setState(335); + setState(337); _errHandler->sync(this); _la = _input->LA(1); while ((((_la & ~ 0x3fULL) == 0) && - ((1ULL << _la) & -536887298) != 0) || ((((_la - 64) & ~ 0x3fULL) == 0) && - ((1ULL << (_la - 64)) & 180986211001696255) != 0) || ((((_la - 129) & ~ 0x3fULL) == 0) && - ((1ULL << (_la - 129)) & 4212759) != 0)) { - setState(332); + ((1ULL << _la) & -140738696331266) != 0) || ((((_la - 64) & ~ 0x3fULL) == 0) && + ((1ULL << (_la - 64)) & 723944844006785023) != 0) || ((((_la - 131) & ~ 0x3fULL) == 0) && + ((1ULL << (_la - 131)) & 4212759) != 0)) { + setState(334); declaration(); - setState(337); + setState(339); _errHandler->sync(this); _la = _input->LA(1); } - setState(338); + setState(340); match(HogQLParser::RBRACE); } @@ -2550,11 +2556,11 @@ HogQLParser::KvPairContext* HogQLParser::kvPair() { }); try { enterOuterAlt(_localctx, 1); - setState(340); + setState(342); expression(); - setState(341); + setState(343); match(HogQLParser::COLON); - setState(342); + setState(344); expression(); } @@ -2617,28 +2623,28 @@ HogQLParser::KvPairListContext* HogQLParser::kvPairList() { try { size_t alt; enterOuterAlt(_localctx, 1); - setState(344); + setState(346); kvPair(); - setState(349); + setState(351); _errHandler->sync(this); alt = getInterpreter()->adaptivePredict(_input, 25, _ctx); while (alt != 2 && alt != atn::ATN::INVALID_ALT_NUMBER) { if (alt == 1) { - setState(345); + setState(347); match(HogQLParser::COMMA); - setState(346); + setState(348); kvPair(); } - setState(351); + setState(353); _errHandler->sync(this); alt = getInterpreter()->adaptivePredict(_input, 25, _ctx); } - setState(353); + setState(355); _errHandler->sync(this); _la = _input->LA(1); if (_la == HogQLParser::COMMA) { - setState(352); + setState(354); match(HogQLParser::COMMA); } @@ -2662,8 +2668,8 @@ tree::TerminalNode* HogQLParser::SelectContext::EOF() { return getToken(HogQLParser::EOF, 0); } -HogQLParser::SelectUnionStmtContext* HogQLParser::SelectContext::selectUnionStmt() { - return getRuleContext(0); +HogQLParser::SelectSetStmtContext* HogQLParser::SelectContext::selectSetStmt() { + return getRuleContext(0); } HogQLParser::SelectStmtContext* HogQLParser::SelectContext::selectStmt() { @@ -2700,23 +2706,23 @@ HogQLParser::SelectContext* HogQLParser::select() { }); try { enterOuterAlt(_localctx, 1); - setState(358); + setState(360); _errHandler->sync(this); switch (getInterpreter()->adaptivePredict(_input, 27, _ctx)) { case 1: { - setState(355); - selectUnionStmt(); + setState(357); + selectSetStmt(); break; } case 2: { - setState(356); + setState(358); selectStmt(); break; } case 3: { - setState(357); + setState(359); hogqlxTagElement(); break; } @@ -2724,7 +2730,7 @@ HogQLParser::SelectContext* HogQLParser::select() { default: break; } - setState(360); + setState(362); match(HogQLParser::EOF); } @@ -2737,53 +2743,48 @@ HogQLParser::SelectContext* HogQLParser::select() { return _localctx; } -//----------------- SelectUnionStmtContext ------------------------------------------------------------------ +//----------------- SelectStmtWithParensContext ------------------------------------------------------------------ -HogQLParser::SelectUnionStmtContext::SelectUnionStmtContext(ParserRuleContext *parent, size_t invokingState) +HogQLParser::SelectStmtWithParensContext::SelectStmtWithParensContext(ParserRuleContext *parent, size_t invokingState) : ParserRuleContext(parent, invokingState) { } -std::vector HogQLParser::SelectUnionStmtContext::selectStmtWithParens() { - return getRuleContexts(); -} - -HogQLParser::SelectStmtWithParensContext* HogQLParser::SelectUnionStmtContext::selectStmtWithParens(size_t i) { - return getRuleContext(i); +HogQLParser::SelectStmtContext* HogQLParser::SelectStmtWithParensContext::selectStmt() { + return getRuleContext(0); } -std::vector HogQLParser::SelectUnionStmtContext::UNION() { - return getTokens(HogQLParser::UNION); +tree::TerminalNode* HogQLParser::SelectStmtWithParensContext::LPAREN() { + return getToken(HogQLParser::LPAREN, 0); } -tree::TerminalNode* HogQLParser::SelectUnionStmtContext::UNION(size_t i) { - return getToken(HogQLParser::UNION, i); +HogQLParser::SelectSetStmtContext* HogQLParser::SelectStmtWithParensContext::selectSetStmt() { + return getRuleContext(0); } -std::vector HogQLParser::SelectUnionStmtContext::ALL() { - return getTokens(HogQLParser::ALL); +tree::TerminalNode* HogQLParser::SelectStmtWithParensContext::RPAREN() { + return getToken(HogQLParser::RPAREN, 0); } -tree::TerminalNode* HogQLParser::SelectUnionStmtContext::ALL(size_t i) { - return getToken(HogQLParser::ALL, i); +HogQLParser::PlaceholderContext* HogQLParser::SelectStmtWithParensContext::placeholder() { + return getRuleContext(0); } -size_t HogQLParser::SelectUnionStmtContext::getRuleIndex() const { - return HogQLParser::RuleSelectUnionStmt; +size_t HogQLParser::SelectStmtWithParensContext::getRuleIndex() const { + return HogQLParser::RuleSelectStmtWithParens; } -std::any HogQLParser::SelectUnionStmtContext::accept(tree::ParseTreeVisitor *visitor) { +std::any HogQLParser::SelectStmtWithParensContext::accept(tree::ParseTreeVisitor *visitor) { if (auto parserVisitor = dynamic_cast(visitor)) - return parserVisitor->visitSelectUnionStmt(this); + return parserVisitor->visitSelectStmtWithParens(this); else return visitor->visitChildren(this); } -HogQLParser::SelectUnionStmtContext* HogQLParser::selectUnionStmt() { - SelectUnionStmtContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 44, HogQLParser::RuleSelectUnionStmt); - size_t _la = 0; +HogQLParser::SelectStmtWithParensContext* HogQLParser::selectStmtWithParens() { + SelectStmtWithParensContext *_localctx = _tracker.createInstance(_ctx, getState()); + enterRule(_localctx, 44, HogQLParser::RuleSelectStmtWithParens); #if __cplusplus > 201703L auto onExit = finally([=, this] { @@ -2793,22 +2794,37 @@ HogQLParser::SelectUnionStmtContext* HogQLParser::selectUnionStmt() { exitRule(); }); try { - enterOuterAlt(_localctx, 1); - setState(362); - selectStmtWithParens(); - setState(368); + setState(370); _errHandler->sync(this); - _la = _input->LA(1); - while (_la == HogQLParser::UNION) { - setState(363); - match(HogQLParser::UNION); - setState(364); - match(HogQLParser::ALL); - setState(365); - selectStmtWithParens(); - setState(370); - _errHandler->sync(this); - _la = _input->LA(1); + switch (_input->LA(1)) { + case HogQLParser::SELECT: + case HogQLParser::WITH: { + enterOuterAlt(_localctx, 1); + setState(364); + selectStmt(); + break; + } + + case HogQLParser::LPAREN: { + enterOuterAlt(_localctx, 2); + setState(365); + match(HogQLParser::LPAREN); + setState(366); + selectSetStmt(); + setState(367); + match(HogQLParser::RPAREN); + break; + } + + case HogQLParser::LBRACE: { + enterOuterAlt(_localctx, 3); + setState(369); + placeholder(); + break; + } + + default: + throw NoViableAltException(this); } } @@ -2821,48 +2837,48 @@ HogQLParser::SelectUnionStmtContext* HogQLParser::selectUnionStmt() { return _localctx; } -//----------------- SelectStmtWithParensContext ------------------------------------------------------------------ +//----------------- SubsequentSelectSetClauseContext ------------------------------------------------------------------ -HogQLParser::SelectStmtWithParensContext::SelectStmtWithParensContext(ParserRuleContext *parent, size_t invokingState) +HogQLParser::SubsequentSelectSetClauseContext::SubsequentSelectSetClauseContext(ParserRuleContext *parent, size_t invokingState) : ParserRuleContext(parent, invokingState) { } -HogQLParser::SelectStmtContext* HogQLParser::SelectStmtWithParensContext::selectStmt() { - return getRuleContext(0); +HogQLParser::SelectStmtWithParensContext* HogQLParser::SubsequentSelectSetClauseContext::selectStmtWithParens() { + return getRuleContext(0); } -tree::TerminalNode* HogQLParser::SelectStmtWithParensContext::LPAREN() { - return getToken(HogQLParser::LPAREN, 0); +tree::TerminalNode* HogQLParser::SubsequentSelectSetClauseContext::EXCEPT() { + return getToken(HogQLParser::EXCEPT, 0); } -HogQLParser::SelectUnionStmtContext* HogQLParser::SelectStmtWithParensContext::selectUnionStmt() { - return getRuleContext(0); +tree::TerminalNode* HogQLParser::SubsequentSelectSetClauseContext::UNION() { + return getToken(HogQLParser::UNION, 0); } -tree::TerminalNode* HogQLParser::SelectStmtWithParensContext::RPAREN() { - return getToken(HogQLParser::RPAREN, 0); +tree::TerminalNode* HogQLParser::SubsequentSelectSetClauseContext::ALL() { + return getToken(HogQLParser::ALL, 0); } -HogQLParser::PlaceholderContext* HogQLParser::SelectStmtWithParensContext::placeholder() { - return getRuleContext(0); +tree::TerminalNode* HogQLParser::SubsequentSelectSetClauseContext::INTERSECT() { + return getToken(HogQLParser::INTERSECT, 0); } -size_t HogQLParser::SelectStmtWithParensContext::getRuleIndex() const { - return HogQLParser::RuleSelectStmtWithParens; +size_t HogQLParser::SubsequentSelectSetClauseContext::getRuleIndex() const { + return HogQLParser::RuleSubsequentSelectSetClause; } -std::any HogQLParser::SelectStmtWithParensContext::accept(tree::ParseTreeVisitor *visitor) { +std::any HogQLParser::SubsequentSelectSetClauseContext::accept(tree::ParseTreeVisitor *visitor) { if (auto parserVisitor = dynamic_cast(visitor)) - return parserVisitor->visitSelectStmtWithParens(this); + return parserVisitor->visitSubsequentSelectSetClause(this); else return visitor->visitChildren(this); } -HogQLParser::SelectStmtWithParensContext* HogQLParser::selectStmtWithParens() { - SelectStmtWithParensContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 46, HogQLParser::RuleSelectStmtWithParens); +HogQLParser::SubsequentSelectSetClauseContext* HogQLParser::subsequentSelectSetClause() { + SubsequentSelectSetClauseContext *_localctx = _tracker.createInstance(_ctx, getState()); + enterRule(_localctx, 46, HogQLParser::RuleSubsequentSelectSetClause); #if __cplusplus > 201703L auto onExit = finally([=, this] { @@ -2872,38 +2888,105 @@ HogQLParser::SelectStmtWithParensContext* HogQLParser::selectStmtWithParens() { exitRule(); }); try { - setState(377); + enterOuterAlt(_localctx, 1); + setState(376); _errHandler->sync(this); switch (_input->LA(1)) { - case HogQLParser::SELECT: - case HogQLParser::WITH: { - enterOuterAlt(_localctx, 1); - setState(371); - selectStmt(); + case HogQLParser::EXCEPT: { + setState(372); + match(HogQLParser::EXCEPT); break; } - case HogQLParser::LPAREN: { - enterOuterAlt(_localctx, 2); - setState(372); - match(HogQLParser::LPAREN); + case HogQLParser::UNION: { setState(373); - selectUnionStmt(); + match(HogQLParser::UNION); setState(374); - match(HogQLParser::RPAREN); + match(HogQLParser::ALL); break; } - case HogQLParser::LBRACE: { - enterOuterAlt(_localctx, 3); - setState(376); - placeholder(); + case HogQLParser::INTERSECT: { + setState(375); + match(HogQLParser::INTERSECT); break; } default: throw NoViableAltException(this); } + setState(378); + selectStmtWithParens(); + + } + catch (RecognitionException &e) { + _errHandler->reportError(this, e); + _localctx->exception = std::current_exception(); + _errHandler->recover(this, _localctx->exception); + } + + return _localctx; +} + +//----------------- SelectSetStmtContext ------------------------------------------------------------------ + +HogQLParser::SelectSetStmtContext::SelectSetStmtContext(ParserRuleContext *parent, size_t invokingState) + : ParserRuleContext(parent, invokingState) { +} + +HogQLParser::SelectStmtWithParensContext* HogQLParser::SelectSetStmtContext::selectStmtWithParens() { + return getRuleContext(0); +} + +std::vector HogQLParser::SelectSetStmtContext::subsequentSelectSetClause() { + return getRuleContexts(); +} + +HogQLParser::SubsequentSelectSetClauseContext* HogQLParser::SelectSetStmtContext::subsequentSelectSetClause(size_t i) { + return getRuleContext(i); +} + + +size_t HogQLParser::SelectSetStmtContext::getRuleIndex() const { + return HogQLParser::RuleSelectSetStmt; +} + + +std::any HogQLParser::SelectSetStmtContext::accept(tree::ParseTreeVisitor *visitor) { + if (auto parserVisitor = dynamic_cast(visitor)) + return parserVisitor->visitSelectSetStmt(this); + else + return visitor->visitChildren(this); +} + +HogQLParser::SelectSetStmtContext* HogQLParser::selectSetStmt() { + SelectSetStmtContext *_localctx = _tracker.createInstance(_ctx, getState()); + enterRule(_localctx, 48, HogQLParser::RuleSelectSetStmt); + size_t _la = 0; + +#if __cplusplus > 201703L + auto onExit = finally([=, this] { +#else + auto onExit = finally([=] { +#endif + exitRule(); + }); + try { + enterOuterAlt(_localctx, 1); + setState(380); + selectStmtWithParens(); + setState(384); + _errHandler->sync(this); + _la = _input->LA(1); + while (_la == HogQLParser::EXCEPT + + || _la == HogQLParser::INTERSECT || _la == HogQLParser::UNION) { + setState(381); + subsequentSelectSetClause(); + setState(386); + _errHandler->sync(this); + _la = _input->LA(1); + } } catch (RecognitionException &e) { @@ -3020,7 +3103,7 @@ std::any HogQLParser::SelectStmtContext::accept(tree::ParseTreeVisitor *visitor) HogQLParser::SelectStmtContext* HogQLParser::selectStmt() { SelectStmtContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 48, HogQLParser::RuleSelectStmt); + enterRule(_localctx, 50, HogQLParser::RuleSelectStmt); size_t _la = 0; #if __cplusplus > 201703L @@ -3032,22 +3115,22 @@ HogQLParser::SelectStmtContext* HogQLParser::selectStmt() { }); try { enterOuterAlt(_localctx, 1); - setState(380); + setState(388); _errHandler->sync(this); _la = _input->LA(1); if (_la == HogQLParser::WITH) { - setState(379); + setState(387); antlrcpp::downCast(_localctx)->with = withClause(); } - setState(382); + setState(390); match(HogQLParser::SELECT); - setState(384); + setState(392); _errHandler->sync(this); - switch (getInterpreter()->adaptivePredict(_input, 31, _ctx)) { + switch (getInterpreter()->adaptivePredict(_input, 32, _ctx)) { case 1: { - setState(383); + setState(391); match(HogQLParser::DISTINCT); break; } @@ -3055,12 +3138,12 @@ HogQLParser::SelectStmtContext* HogQLParser::selectStmt() { default: break; } - setState(387); + setState(395); _errHandler->sync(this); - switch (getInterpreter()->adaptivePredict(_input, 32, _ctx)) { + switch (getInterpreter()->adaptivePredict(_input, 33, _ctx)) { case 1: { - setState(386); + setState(394); topClause(); break; } @@ -3068,57 +3151,57 @@ HogQLParser::SelectStmtContext* HogQLParser::selectStmt() { default: break; } - setState(389); + setState(397); antlrcpp::downCast(_localctx)->columns = columnExprList(); - setState(391); + setState(399); _errHandler->sync(this); _la = _input->LA(1); if (_la == HogQLParser::FROM) { - setState(390); + setState(398); antlrcpp::downCast(_localctx)->from = fromClause(); } - setState(394); + setState(402); _errHandler->sync(this); _la = _input->LA(1); if ((((_la & ~ 0x3fULL) == 0) && - ((1ULL << _la) & 4538783999459360) != 0)) { - setState(393); + ((1ULL << _la) & 18084767253659680) != 0)) { + setState(401); arrayJoinClause(); } - setState(397); + setState(405); _errHandler->sync(this); _la = _input->LA(1); if (_la == HogQLParser::PREWHERE) { - setState(396); + setState(404); prewhereClause(); } - setState(400); + setState(408); _errHandler->sync(this); _la = _input->LA(1); if (_la == HogQLParser::WHERE) { - setState(399); + setState(407); antlrcpp::downCast(_localctx)->where = whereClause(); } - setState(403); + setState(411); _errHandler->sync(this); _la = _input->LA(1); if (_la == HogQLParser::GROUP) { - setState(402); + setState(410); groupByClause(); } - setState(407); + setState(415); _errHandler->sync(this); - switch (getInterpreter()->adaptivePredict(_input, 38, _ctx)) { + switch (getInterpreter()->adaptivePredict(_input, 39, _ctx)) { case 1: { - setState(405); + setState(413); match(HogQLParser::WITH); - setState(406); + setState(414); _la = _input->LA(1); if (!(_la == HogQLParser::CUBE @@ -3135,56 +3218,58 @@ HogQLParser::SelectStmtContext* HogQLParser::selectStmt() { default: break; } - setState(411); + setState(419); _errHandler->sync(this); _la = _input->LA(1); if (_la == HogQLParser::WITH) { - setState(409); + setState(417); match(HogQLParser::WITH); - setState(410); + setState(418); match(HogQLParser::TOTALS); } - setState(414); + setState(422); _errHandler->sync(this); _la = _input->LA(1); if (_la == HogQLParser::HAVING) { - setState(413); + setState(421); havingClause(); } - setState(417); + setState(425); _errHandler->sync(this); _la = _input->LA(1); if (_la == HogQLParser::WINDOW) { - setState(416); + setState(424); windowClause(); } - setState(420); + setState(428); _errHandler->sync(this); _la = _input->LA(1); if (_la == HogQLParser::ORDER) { - setState(419); + setState(427); orderByClause(); } - setState(424); + setState(432); _errHandler->sync(this); switch (_input->LA(1)) { case HogQLParser::LIMIT: { - setState(422); + setState(430); limitAndOffsetClause(); break; } case HogQLParser::OFFSET: { - setState(423); + setState(431); offsetOnlyClause(); break; } case HogQLParser::EOF: + case HogQLParser::EXCEPT: + case HogQLParser::INTERSECT: case HogQLParser::SETTINGS: case HogQLParser::UNION: case HogQLParser::RPAREN: { @@ -3194,12 +3279,12 @@ HogQLParser::SelectStmtContext* HogQLParser::selectStmt() { default: break; } - setState(427); + setState(435); _errHandler->sync(this); _la = _input->LA(1); if (_la == HogQLParser::SETTINGS) { - setState(426); + setState(434); settingsClause(); } @@ -3242,7 +3327,7 @@ std::any HogQLParser::WithClauseContext::accept(tree::ParseTreeVisitor *visitor) HogQLParser::WithClauseContext* HogQLParser::withClause() { WithClauseContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 50, HogQLParser::RuleWithClause); + enterRule(_localctx, 52, HogQLParser::RuleWithClause); #if __cplusplus > 201703L auto onExit = finally([=, this] { @@ -3253,9 +3338,9 @@ HogQLParser::WithClauseContext* HogQLParser::withClause() { }); try { enterOuterAlt(_localctx, 1); - setState(429); + setState(437); match(HogQLParser::WITH); - setState(430); + setState(438); withExprList(); } @@ -3305,7 +3390,7 @@ std::any HogQLParser::TopClauseContext::accept(tree::ParseTreeVisitor *visitor) HogQLParser::TopClauseContext* HogQLParser::topClause() { TopClauseContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 52, HogQLParser::RuleTopClause); + enterRule(_localctx, 54, HogQLParser::RuleTopClause); #if __cplusplus > 201703L auto onExit = finally([=, this] { @@ -3316,18 +3401,18 @@ HogQLParser::TopClauseContext* HogQLParser::topClause() { }); try { enterOuterAlt(_localctx, 1); - setState(432); + setState(440); match(HogQLParser::TOP); - setState(433); + setState(441); match(HogQLParser::DECIMAL_LITERAL); - setState(436); + setState(444); _errHandler->sync(this); - switch (getInterpreter()->adaptivePredict(_input, 45, _ctx)) { + switch (getInterpreter()->adaptivePredict(_input, 46, _ctx)) { case 1: { - setState(434); + setState(442); match(HogQLParser::WITH); - setState(435); + setState(443); match(HogQLParser::TIES); break; } @@ -3375,7 +3460,7 @@ std::any HogQLParser::FromClauseContext::accept(tree::ParseTreeVisitor *visitor) HogQLParser::FromClauseContext* HogQLParser::fromClause() { FromClauseContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 54, HogQLParser::RuleFromClause); + enterRule(_localctx, 56, HogQLParser::RuleFromClause); #if __cplusplus > 201703L auto onExit = finally([=, this] { @@ -3386,9 +3471,9 @@ HogQLParser::FromClauseContext* HogQLParser::fromClause() { }); try { enterOuterAlt(_localctx, 1); - setState(438); + setState(446); match(HogQLParser::FROM); - setState(439); + setState(447); joinExpr(0); } @@ -3442,7 +3527,7 @@ std::any HogQLParser::ArrayJoinClauseContext::accept(tree::ParseTreeVisitor *vis HogQLParser::ArrayJoinClauseContext* HogQLParser::arrayJoinClause() { ArrayJoinClauseContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 56, HogQLParser::RuleArrayJoinClause); + enterRule(_localctx, 58, HogQLParser::RuleArrayJoinClause); size_t _la = 0; #if __cplusplus > 201703L @@ -3454,14 +3539,14 @@ HogQLParser::ArrayJoinClauseContext* HogQLParser::arrayJoinClause() { }); try { enterOuterAlt(_localctx, 1); - setState(442); + setState(450); _errHandler->sync(this); _la = _input->LA(1); if (_la == HogQLParser::INNER || _la == HogQLParser::LEFT) { - setState(441); + setState(449); _la = _input->LA(1); if (!(_la == HogQLParser::INNER @@ -3473,11 +3558,11 @@ HogQLParser::ArrayJoinClauseContext* HogQLParser::arrayJoinClause() { consume(); } } - setState(444); + setState(452); match(HogQLParser::ARRAY); - setState(445); + setState(453); match(HogQLParser::JOIN); - setState(446); + setState(454); columnExprList(); } @@ -3563,7 +3648,7 @@ std::any HogQLParser::WindowClauseContext::accept(tree::ParseTreeVisitor *visito HogQLParser::WindowClauseContext* HogQLParser::windowClause() { WindowClauseContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 58, HogQLParser::RuleWindowClause); + enterRule(_localctx, 60, HogQLParser::RuleWindowClause); size_t _la = 0; #if __cplusplus > 201703L @@ -3575,35 +3660,35 @@ HogQLParser::WindowClauseContext* HogQLParser::windowClause() { }); try { enterOuterAlt(_localctx, 1); - setState(448); + setState(456); match(HogQLParser::WINDOW); - setState(449); + setState(457); identifier(); - setState(450); + setState(458); match(HogQLParser::AS); - setState(451); + setState(459); match(HogQLParser::LPAREN); - setState(452); + setState(460); windowExpr(); - setState(453); + setState(461); match(HogQLParser::RPAREN); - setState(463); + setState(471); _errHandler->sync(this); _la = _input->LA(1); while (_la == HogQLParser::COMMA) { - setState(454); + setState(462); match(HogQLParser::COMMA); - setState(455); + setState(463); identifier(); - setState(456); + setState(464); match(HogQLParser::AS); - setState(457); + setState(465); match(HogQLParser::LPAREN); - setState(458); + setState(466); windowExpr(); - setState(459); + setState(467); match(HogQLParser::RPAREN); - setState(465); + setState(473); _errHandler->sync(this); _la = _input->LA(1); } @@ -3647,7 +3732,7 @@ std::any HogQLParser::PrewhereClauseContext::accept(tree::ParseTreeVisitor *visi HogQLParser::PrewhereClauseContext* HogQLParser::prewhereClause() { PrewhereClauseContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 60, HogQLParser::RulePrewhereClause); + enterRule(_localctx, 62, HogQLParser::RulePrewhereClause); #if __cplusplus > 201703L auto onExit = finally([=, this] { @@ -3658,9 +3743,9 @@ HogQLParser::PrewhereClauseContext* HogQLParser::prewhereClause() { }); try { enterOuterAlt(_localctx, 1); - setState(466); + setState(474); match(HogQLParser::PREWHERE); - setState(467); + setState(475); columnExpr(0); } @@ -3702,7 +3787,7 @@ std::any HogQLParser::WhereClauseContext::accept(tree::ParseTreeVisitor *visitor HogQLParser::WhereClauseContext* HogQLParser::whereClause() { WhereClauseContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 62, HogQLParser::RuleWhereClause); + enterRule(_localctx, 64, HogQLParser::RuleWhereClause); #if __cplusplus > 201703L auto onExit = finally([=, this] { @@ -3713,9 +3798,9 @@ HogQLParser::WhereClauseContext* HogQLParser::whereClause() { }); try { enterOuterAlt(_localctx, 1); - setState(469); + setState(477); match(HogQLParser::WHERE); - setState(470); + setState(478); columnExpr(0); } @@ -3777,7 +3862,7 @@ std::any HogQLParser::GroupByClauseContext::accept(tree::ParseTreeVisitor *visit HogQLParser::GroupByClauseContext* HogQLParser::groupByClause() { GroupByClauseContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 64, HogQLParser::RuleGroupByClause); + enterRule(_localctx, 66, HogQLParser::RuleGroupByClause); size_t _la = 0; #if __cplusplus > 201703L @@ -3789,15 +3874,15 @@ HogQLParser::GroupByClauseContext* HogQLParser::groupByClause() { }); try { enterOuterAlt(_localctx, 1); - setState(472); + setState(480); match(HogQLParser::GROUP); - setState(473); + setState(481); match(HogQLParser::BY); - setState(480); + setState(488); _errHandler->sync(this); - switch (getInterpreter()->adaptivePredict(_input, 48, _ctx)) { + switch (getInterpreter()->adaptivePredict(_input, 49, _ctx)) { case 1: { - setState(474); + setState(482); _la = _input->LA(1); if (!(_la == HogQLParser::CUBE @@ -3808,17 +3893,17 @@ HogQLParser::GroupByClauseContext* HogQLParser::groupByClause() { _errHandler->reportMatch(this); consume(); } - setState(475); + setState(483); match(HogQLParser::LPAREN); - setState(476); + setState(484); columnExprList(); - setState(477); + setState(485); match(HogQLParser::RPAREN); break; } case 2: { - setState(479); + setState(487); columnExprList(); break; } @@ -3866,7 +3951,7 @@ std::any HogQLParser::HavingClauseContext::accept(tree::ParseTreeVisitor *visito HogQLParser::HavingClauseContext* HogQLParser::havingClause() { HavingClauseContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 66, HogQLParser::RuleHavingClause); + enterRule(_localctx, 68, HogQLParser::RuleHavingClause); #if __cplusplus > 201703L auto onExit = finally([=, this] { @@ -3877,9 +3962,9 @@ HogQLParser::HavingClauseContext* HogQLParser::havingClause() { }); try { enterOuterAlt(_localctx, 1); - setState(482); + setState(490); match(HogQLParser::HAVING); - setState(483); + setState(491); columnExpr(0); } @@ -3925,7 +4010,7 @@ std::any HogQLParser::OrderByClauseContext::accept(tree::ParseTreeVisitor *visit HogQLParser::OrderByClauseContext* HogQLParser::orderByClause() { OrderByClauseContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 68, HogQLParser::RuleOrderByClause); + enterRule(_localctx, 70, HogQLParser::RuleOrderByClause); #if __cplusplus > 201703L auto onExit = finally([=, this] { @@ -3936,11 +4021,11 @@ HogQLParser::OrderByClauseContext* HogQLParser::orderByClause() { }); try { enterOuterAlt(_localctx, 1); - setState(485); + setState(493); match(HogQLParser::ORDER); - setState(486); + setState(494); match(HogQLParser::BY); - setState(487); + setState(495); orderExprList(); } @@ -3986,7 +4071,7 @@ std::any HogQLParser::ProjectionOrderByClauseContext::accept(tree::ParseTreeVisi HogQLParser::ProjectionOrderByClauseContext* HogQLParser::projectionOrderByClause() { ProjectionOrderByClauseContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 70, HogQLParser::RuleProjectionOrderByClause); + enterRule(_localctx, 72, HogQLParser::RuleProjectionOrderByClause); #if __cplusplus > 201703L auto onExit = finally([=, this] { @@ -3997,11 +4082,11 @@ HogQLParser::ProjectionOrderByClauseContext* HogQLParser::projectionOrderByClaus }); try { enterOuterAlt(_localctx, 1); - setState(489); + setState(497); match(HogQLParser::ORDER); - setState(490); + setState(498); match(HogQLParser::BY); - setState(491); + setState(499); columnExprList(); } @@ -4071,7 +4156,7 @@ std::any HogQLParser::LimitAndOffsetClauseContext::accept(tree::ParseTreeVisitor HogQLParser::LimitAndOffsetClauseContext* HogQLParser::limitAndOffsetClause() { LimitAndOffsetClauseContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 72, HogQLParser::RuleLimitAndOffsetClause); + enterRule(_localctx, 74, HogQLParser::RuleLimitAndOffsetClause); size_t _la = 0; #if __cplusplus > 201703L @@ -4082,45 +4167,47 @@ HogQLParser::LimitAndOffsetClauseContext* HogQLParser::limitAndOffsetClause() { exitRule(); }); try { - setState(522); + setState(530); _errHandler->sync(this); - switch (getInterpreter()->adaptivePredict(_input, 53, _ctx)) { + switch (getInterpreter()->adaptivePredict(_input, 54, _ctx)) { case 1: { enterOuterAlt(_localctx, 1); - setState(493); + setState(501); match(HogQLParser::LIMIT); - setState(494); + setState(502); columnExpr(0); - setState(497); + setState(505); _errHandler->sync(this); _la = _input->LA(1); if (_la == HogQLParser::COMMA) { - setState(495); + setState(503); match(HogQLParser::COMMA); - setState(496); + setState(504); columnExpr(0); } - setState(503); + setState(511); _errHandler->sync(this); switch (_input->LA(1)) { case HogQLParser::WITH: { - setState(499); + setState(507); match(HogQLParser::WITH); - setState(500); + setState(508); match(HogQLParser::TIES); break; } case HogQLParser::BY: { - setState(501); + setState(509); match(HogQLParser::BY); - setState(502); + setState(510); columnExprList(); break; } case HogQLParser::EOF: + case HogQLParser::EXCEPT: + case HogQLParser::INTERSECT: case HogQLParser::SETTINGS: case HogQLParser::UNION: case HogQLParser::RPAREN: { @@ -4135,45 +4222,45 @@ HogQLParser::LimitAndOffsetClauseContext* HogQLParser::limitAndOffsetClause() { case 2: { enterOuterAlt(_localctx, 2); - setState(505); + setState(513); match(HogQLParser::LIMIT); - setState(506); + setState(514); columnExpr(0); - setState(509); + setState(517); _errHandler->sync(this); _la = _input->LA(1); if (_la == HogQLParser::WITH) { - setState(507); + setState(515); match(HogQLParser::WITH); - setState(508); + setState(516); match(HogQLParser::TIES); } - setState(511); + setState(519); match(HogQLParser::OFFSET); - setState(512); + setState(520); columnExpr(0); break; } case 3: { enterOuterAlt(_localctx, 3); - setState(514); + setState(522); match(HogQLParser::LIMIT); - setState(515); + setState(523); columnExpr(0); - setState(516); + setState(524); match(HogQLParser::OFFSET); - setState(517); + setState(525); columnExpr(0); - setState(520); + setState(528); _errHandler->sync(this); _la = _input->LA(1); if (_la == HogQLParser::BY) { - setState(518); + setState(526); match(HogQLParser::BY); - setState(519); + setState(527); columnExprList(); } break; @@ -4222,7 +4309,7 @@ std::any HogQLParser::OffsetOnlyClauseContext::accept(tree::ParseTreeVisitor *vi HogQLParser::OffsetOnlyClauseContext* HogQLParser::offsetOnlyClause() { OffsetOnlyClauseContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 74, HogQLParser::RuleOffsetOnlyClause); + enterRule(_localctx, 76, HogQLParser::RuleOffsetOnlyClause); #if __cplusplus > 201703L auto onExit = finally([=, this] { @@ -4233,9 +4320,9 @@ HogQLParser::OffsetOnlyClauseContext* HogQLParser::offsetOnlyClause() { }); try { enterOuterAlt(_localctx, 1); - setState(524); + setState(532); match(HogQLParser::OFFSET); - setState(525); + setState(533); columnExpr(0); } @@ -4277,7 +4364,7 @@ std::any HogQLParser::SettingsClauseContext::accept(tree::ParseTreeVisitor *visi HogQLParser::SettingsClauseContext* HogQLParser::settingsClause() { SettingsClauseContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 76, HogQLParser::RuleSettingsClause); + enterRule(_localctx, 78, HogQLParser::RuleSettingsClause); #if __cplusplus > 201703L auto onExit = finally([=, this] { @@ -4288,9 +4375,9 @@ HogQLParser::SettingsClauseContext* HogQLParser::settingsClause() { }); try { enterOuterAlt(_localctx, 1); - setState(527); + setState(535); match(HogQLParser::SETTINGS); - setState(528); + setState(536); settingExprList(); } @@ -4429,8 +4516,8 @@ HogQLParser::JoinExprContext* HogQLParser::joinExpr(int precedence) { HogQLParser::JoinExprContext *_localctx = _tracker.createInstance(_ctx, parentState); HogQLParser::JoinExprContext *previousContext = _localctx; (void)previousContext; // Silence compiler, in case the context is not used by generated code. - size_t startState = 78; - enterRecursionRule(_localctx, 78, HogQLParser::RuleJoinExpr, precedence); + size_t startState = 80; + enterRecursionRule(_localctx, 80, HogQLParser::RuleJoinExpr, precedence); size_t _la = 0; @@ -4444,22 +4531,22 @@ HogQLParser::JoinExprContext* HogQLParser::joinExpr(int precedence) { try { size_t alt; enterOuterAlt(_localctx, 1); - setState(542); + setState(550); _errHandler->sync(this); - switch (getInterpreter()->adaptivePredict(_input, 56, _ctx)) { + switch (getInterpreter()->adaptivePredict(_input, 57, _ctx)) { case 1: { _localctx = _tracker.createInstance(_localctx); _ctx = _localctx; previousContext = _localctx; - setState(531); + setState(539); tableExpr(0); - setState(533); + setState(541); _errHandler->sync(this); - switch (getInterpreter()->adaptivePredict(_input, 54, _ctx)) { + switch (getInterpreter()->adaptivePredict(_input, 55, _ctx)) { case 1: { - setState(532); + setState(540); match(HogQLParser::FINAL); break; } @@ -4467,12 +4554,12 @@ HogQLParser::JoinExprContext* HogQLParser::joinExpr(int precedence) { default: break; } - setState(536); + setState(544); _errHandler->sync(this); - switch (getInterpreter()->adaptivePredict(_input, 55, _ctx)) { + switch (getInterpreter()->adaptivePredict(_input, 56, _ctx)) { case 1: { - setState(535); + setState(543); sampleClause(); break; } @@ -4487,11 +4574,11 @@ HogQLParser::JoinExprContext* HogQLParser::joinExpr(int precedence) { _localctx = _tracker.createInstance(_localctx); _ctx = _localctx; previousContext = _localctx; - setState(538); + setState(546); match(HogQLParser::LPAREN); - setState(539); + setState(547); joinExpr(0); - setState(540); + setState(548); match(HogQLParser::RPAREN); break; } @@ -4500,27 +4587,27 @@ HogQLParser::JoinExprContext* HogQLParser::joinExpr(int precedence) { break; } _ctx->stop = _input->LT(-1); - setState(558); + setState(566); _errHandler->sync(this); - alt = getInterpreter()->adaptivePredict(_input, 59, _ctx); + alt = getInterpreter()->adaptivePredict(_input, 60, _ctx); while (alt != 2 && alt != atn::ATN::INVALID_ALT_NUMBER) { if (alt == 1) { if (!_parseListeners.empty()) triggerExitRuleEvent(); previousContext = _localctx; - setState(556); + setState(564); _errHandler->sync(this); - switch (getInterpreter()->adaptivePredict(_input, 58, _ctx)) { + switch (getInterpreter()->adaptivePredict(_input, 59, _ctx)) { case 1: { auto newContext = _tracker.createInstance(_tracker.createInstance(parentContext, parentState)); _localctx = newContext; pushNewRecursionContext(newContext, startState, RuleJoinExpr); - setState(544); + setState(552); if (!(precpred(_ctx, 3))) throw FailedPredicateException(this, "precpred(_ctx, 3)"); - setState(545); + setState(553); joinOpCross(); - setState(546); + setState(554); joinExpr(4); break; } @@ -4529,25 +4616,25 @@ HogQLParser::JoinExprContext* HogQLParser::joinExpr(int precedence) { auto newContext = _tracker.createInstance(_tracker.createInstance(parentContext, parentState)); _localctx = newContext; pushNewRecursionContext(newContext, startState, RuleJoinExpr); - setState(548); + setState(556); if (!(precpred(_ctx, 4))) throw FailedPredicateException(this, "precpred(_ctx, 4)"); - setState(550); + setState(558); _errHandler->sync(this); _la = _input->LA(1); if ((((_la & ~ 0x3fULL) == 0) && - ((1ULL << _la) & 4538818359197978) != 0) || _la == HogQLParser::RIGHT + ((1ULL << _la) & 18084835973136666) != 0) || _la == HogQLParser::RIGHT || _la == HogQLParser::SEMI) { - setState(549); + setState(557); joinOp(); } - setState(552); + setState(560); match(HogQLParser::JOIN); - setState(553); + setState(561); joinExpr(0); - setState(554); + setState(562); joinConstraintClause(); break; } @@ -4556,9 +4643,9 @@ HogQLParser::JoinExprContext* HogQLParser::joinExpr(int precedence) { break; } } - setState(560); + setState(568); _errHandler->sync(this); - alt = getInterpreter()->adaptivePredict(_input, 59, _ctx); + alt = getInterpreter()->adaptivePredict(_input, 60, _ctx); } } catch (RecognitionException &e) { @@ -4683,7 +4770,7 @@ std::any HogQLParser::JoinOpLeftRightContext::accept(tree::ParseTreeVisitor *vis } HogQLParser::JoinOpContext* HogQLParser::joinOp() { JoinOpContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 80, HogQLParser::RuleJoinOp); + enterRule(_localctx, 82, HogQLParser::RuleJoinOp); size_t _la = 0; #if __cplusplus > 201703L @@ -4694,23 +4781,23 @@ HogQLParser::JoinOpContext* HogQLParser::joinOp() { exitRule(); }); try { - setState(604); + setState(612); _errHandler->sync(this); - switch (getInterpreter()->adaptivePredict(_input, 73, _ctx)) { + switch (getInterpreter()->adaptivePredict(_input, 74, _ctx)) { case 1: { _localctx = _tracker.createInstance(_localctx); enterOuterAlt(_localctx, 1); - setState(570); + setState(578); _errHandler->sync(this); - switch (getInterpreter()->adaptivePredict(_input, 62, _ctx)) { + switch (getInterpreter()->adaptivePredict(_input, 63, _ctx)) { case 1: { - setState(562); + setState(570); _errHandler->sync(this); _la = _input->LA(1); if ((((_la & ~ 0x3fULL) == 0) && ((1ULL << _la) & 274) != 0)) { - setState(561); + setState(569); _la = _input->LA(1); if (!((((_la & ~ 0x3fULL) == 0) && ((1ULL << _la) & 274) != 0))) { @@ -4721,21 +4808,21 @@ HogQLParser::JoinOpContext* HogQLParser::joinOp() { consume(); } } - setState(564); + setState(572); match(HogQLParser::INNER); break; } case 2: { - setState(565); + setState(573); match(HogQLParser::INNER); - setState(567); + setState(575); _errHandler->sync(this); _la = _input->LA(1); if ((((_la & ~ 0x3fULL) == 0) && ((1ULL << _la) & 274) != 0)) { - setState(566); + setState(574); _la = _input->LA(1); if (!((((_la & ~ 0x3fULL) == 0) && ((1ULL << _la) & 274) != 0))) { @@ -4750,7 +4837,7 @@ HogQLParser::JoinOpContext* HogQLParser::joinOp() { } case 3: { - setState(569); + setState(577); _la = _input->LA(1); if (!((((_la & ~ 0x3fULL) == 0) && ((1ULL << _la) & 274) != 0))) { @@ -4772,17 +4859,17 @@ HogQLParser::JoinOpContext* HogQLParser::joinOp() { case 2: { _localctx = _tracker.createInstance(_localctx); enterOuterAlt(_localctx, 2); - setState(586); + setState(594); _errHandler->sync(this); - switch (getInterpreter()->adaptivePredict(_input, 67, _ctx)) { + switch (getInterpreter()->adaptivePredict(_input, 68, _ctx)) { case 1: { - setState(573); + setState(581); _errHandler->sync(this); _la = _input->LA(1); if ((((_la & ~ 0x3fULL) == 0) && ((1ULL << _la) & 282) != 0) || _la == HogQLParser::SEMI) { - setState(572); + setState(580); _la = _input->LA(1); if (!((((_la & ~ 0x3fULL) == 0) && ((1ULL << _la) & 282) != 0) || _la == HogQLParser::SEMI)) { @@ -4793,7 +4880,7 @@ HogQLParser::JoinOpContext* HogQLParser::joinOp() { consume(); } } - setState(575); + setState(583); _la = _input->LA(1); if (!(_la == HogQLParser::LEFT @@ -4804,19 +4891,19 @@ HogQLParser::JoinOpContext* HogQLParser::joinOp() { _errHandler->reportMatch(this); consume(); } - setState(577); + setState(585); _errHandler->sync(this); _la = _input->LA(1); if (_la == HogQLParser::OUTER) { - setState(576); + setState(584); match(HogQLParser::OUTER); } break; } case 2: { - setState(579); + setState(587); _la = _input->LA(1); if (!(_la == HogQLParser::LEFT @@ -4827,21 +4914,21 @@ HogQLParser::JoinOpContext* HogQLParser::joinOp() { _errHandler->reportMatch(this); consume(); } - setState(581); + setState(589); _errHandler->sync(this); _la = _input->LA(1); if (_la == HogQLParser::OUTER) { - setState(580); + setState(588); match(HogQLParser::OUTER); } - setState(584); + setState(592); _errHandler->sync(this); _la = _input->LA(1); if ((((_la & ~ 0x3fULL) == 0) && ((1ULL << _la) & 282) != 0) || _la == HogQLParser::SEMI) { - setState(583); + setState(591); _la = _input->LA(1); if (!((((_la & ~ 0x3fULL) == 0) && ((1ULL << _la) & 282) != 0) || _la == HogQLParser::SEMI)) { @@ -4864,18 +4951,18 @@ HogQLParser::JoinOpContext* HogQLParser::joinOp() { case 3: { _localctx = _tracker.createInstance(_localctx); enterOuterAlt(_localctx, 3); - setState(602); + setState(610); _errHandler->sync(this); - switch (getInterpreter()->adaptivePredict(_input, 72, _ctx)) { + switch (getInterpreter()->adaptivePredict(_input, 73, _ctx)) { case 1: { - setState(589); + setState(597); _errHandler->sync(this); _la = _input->LA(1); if (_la == HogQLParser::ALL || _la == HogQLParser::ANY) { - setState(588); + setState(596); _la = _input->LA(1); if (!(_la == HogQLParser::ALL @@ -4887,38 +4974,38 @@ HogQLParser::JoinOpContext* HogQLParser::joinOp() { consume(); } } - setState(591); + setState(599); match(HogQLParser::FULL); - setState(593); + setState(601); _errHandler->sync(this); _la = _input->LA(1); if (_la == HogQLParser::OUTER) { - setState(592); + setState(600); match(HogQLParser::OUTER); } break; } case 2: { - setState(595); + setState(603); match(HogQLParser::FULL); - setState(597); + setState(605); _errHandler->sync(this); _la = _input->LA(1); if (_la == HogQLParser::OUTER) { - setState(596); + setState(604); match(HogQLParser::OUTER); } - setState(600); + setState(608); _errHandler->sync(this); _la = _input->LA(1); if (_la == HogQLParser::ALL || _la == HogQLParser::ANY) { - setState(599); + setState(607); _la = _input->LA(1); if (!(_la == HogQLParser::ALL @@ -4986,7 +5073,7 @@ std::any HogQLParser::JoinOpCrossContext::accept(tree::ParseTreeVisitor *visitor HogQLParser::JoinOpCrossContext* HogQLParser::joinOpCross() { JoinOpCrossContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 82, HogQLParser::RuleJoinOpCross); + enterRule(_localctx, 84, HogQLParser::RuleJoinOpCross); #if __cplusplus > 201703L auto onExit = finally([=, this] { @@ -4996,21 +5083,21 @@ HogQLParser::JoinOpCrossContext* HogQLParser::joinOpCross() { exitRule(); }); try { - setState(609); + setState(617); _errHandler->sync(this); switch (_input->LA(1)) { case HogQLParser::CROSS: { enterOuterAlt(_localctx, 1); - setState(606); + setState(614); match(HogQLParser::CROSS); - setState(607); + setState(615); match(HogQLParser::JOIN); break; } case HogQLParser::COMMA: { enterOuterAlt(_localctx, 2); - setState(608); + setState(616); match(HogQLParser::COMMA); break; } @@ -5070,7 +5157,7 @@ std::any HogQLParser::JoinConstraintClauseContext::accept(tree::ParseTreeVisitor HogQLParser::JoinConstraintClauseContext* HogQLParser::joinConstraintClause() { JoinConstraintClauseContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 84, HogQLParser::RuleJoinConstraintClause); + enterRule(_localctx, 86, HogQLParser::RuleJoinConstraintClause); #if __cplusplus > 201703L auto onExit = finally([=, this] { @@ -5080,36 +5167,36 @@ HogQLParser::JoinConstraintClauseContext* HogQLParser::joinConstraintClause() { exitRule(); }); try { - setState(620); + setState(628); _errHandler->sync(this); - switch (getInterpreter()->adaptivePredict(_input, 75, _ctx)) { + switch (getInterpreter()->adaptivePredict(_input, 76, _ctx)) { case 1: { enterOuterAlt(_localctx, 1); - setState(611); + setState(619); match(HogQLParser::ON); - setState(612); + setState(620); columnExprList(); break; } case 2: { enterOuterAlt(_localctx, 2); - setState(613); + setState(621); match(HogQLParser::USING); - setState(614); + setState(622); match(HogQLParser::LPAREN); - setState(615); + setState(623); columnExprList(); - setState(616); + setState(624); match(HogQLParser::RPAREN); break; } case 3: { enterOuterAlt(_localctx, 3); - setState(618); + setState(626); match(HogQLParser::USING); - setState(619); + setState(627); columnExprList(); break; } @@ -5165,7 +5252,7 @@ std::any HogQLParser::SampleClauseContext::accept(tree::ParseTreeVisitor *visito HogQLParser::SampleClauseContext* HogQLParser::sampleClause() { SampleClauseContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 86, HogQLParser::RuleSampleClause); + enterRule(_localctx, 88, HogQLParser::RuleSampleClause); #if __cplusplus > 201703L auto onExit = finally([=, this] { @@ -5176,18 +5263,18 @@ HogQLParser::SampleClauseContext* HogQLParser::sampleClause() { }); try { enterOuterAlt(_localctx, 1); - setState(622); + setState(630); match(HogQLParser::SAMPLE); - setState(623); + setState(631); ratioExpr(); - setState(626); + setState(634); _errHandler->sync(this); - switch (getInterpreter()->adaptivePredict(_input, 76, _ctx)) { + switch (getInterpreter()->adaptivePredict(_input, 77, _ctx)) { case 1: { - setState(624); + setState(632); match(HogQLParser::OFFSET); - setState(625); + setState(633); ratioExpr(); break; } @@ -5243,7 +5330,7 @@ std::any HogQLParser::OrderExprListContext::accept(tree::ParseTreeVisitor *visit HogQLParser::OrderExprListContext* HogQLParser::orderExprList() { OrderExprListContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 88, HogQLParser::RuleOrderExprList); + enterRule(_localctx, 90, HogQLParser::RuleOrderExprList); size_t _la = 0; #if __cplusplus > 201703L @@ -5255,17 +5342,17 @@ HogQLParser::OrderExprListContext* HogQLParser::orderExprList() { }); try { enterOuterAlt(_localctx, 1); - setState(628); + setState(636); orderExpr(); - setState(633); + setState(641); _errHandler->sync(this); _la = _input->LA(1); while (_la == HogQLParser::COMMA) { - setState(629); + setState(637); match(HogQLParser::COMMA); - setState(630); + setState(638); orderExpr(); - setState(635); + setState(643); _errHandler->sync(this); _la = _input->LA(1); } @@ -5337,7 +5424,7 @@ std::any HogQLParser::OrderExprContext::accept(tree::ParseTreeVisitor *visitor) HogQLParser::OrderExprContext* HogQLParser::orderExpr() { OrderExprContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 90, HogQLParser::RuleOrderExpr); + enterRule(_localctx, 92, HogQLParser::RuleOrderExpr); size_t _la = 0; #if __cplusplus > 201703L @@ -5349,15 +5436,15 @@ HogQLParser::OrderExprContext* HogQLParser::orderExpr() { }); try { enterOuterAlt(_localctx, 1); - setState(636); + setState(644); columnExpr(0); - setState(638); + setState(646); _errHandler->sync(this); _la = _input->LA(1); if ((((_la & ~ 0x3fULL) == 0) && ((1ULL << _la) & 12583040) != 0)) { - setState(637); + setState(645); _la = _input->LA(1); if (!((((_la & ~ 0x3fULL) == 0) && ((1ULL << _la) & 12583040) != 0))) { @@ -5368,14 +5455,14 @@ HogQLParser::OrderExprContext* HogQLParser::orderExpr() { consume(); } } - setState(642); + setState(650); _errHandler->sync(this); _la = _input->LA(1); if (_la == HogQLParser::NULLS) { - setState(640); + setState(648); match(HogQLParser::NULLS); - setState(641); + setState(649); _la = _input->LA(1); if (!(_la == HogQLParser::FIRST @@ -5387,14 +5474,14 @@ HogQLParser::OrderExprContext* HogQLParser::orderExpr() { consume(); } } - setState(646); + setState(654); _errHandler->sync(this); _la = _input->LA(1); if (_la == HogQLParser::COLLATE) { - setState(644); + setState(652); match(HogQLParser::COLLATE); - setState(645); + setState(653); match(HogQLParser::STRING_LITERAL); } @@ -5445,7 +5532,7 @@ std::any HogQLParser::RatioExprContext::accept(tree::ParseTreeVisitor *visitor) HogQLParser::RatioExprContext* HogQLParser::ratioExpr() { RatioExprContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 92, HogQLParser::RuleRatioExpr); + enterRule(_localctx, 94, HogQLParser::RuleRatioExpr); #if __cplusplus > 201703L auto onExit = finally([=, this] { @@ -5455,12 +5542,12 @@ HogQLParser::RatioExprContext* HogQLParser::ratioExpr() { exitRule(); }); try { - setState(654); + setState(662); _errHandler->sync(this); switch (_input->LA(1)) { case HogQLParser::LBRACE: { enterOuterAlt(_localctx, 1); - setState(648); + setState(656); placeholder(); break; } @@ -5475,16 +5562,16 @@ HogQLParser::RatioExprContext* HogQLParser::ratioExpr() { case HogQLParser::DOT: case HogQLParser::PLUS: { enterOuterAlt(_localctx, 2); - setState(649); + setState(657); numberLiteral(); - setState(652); + setState(660); _errHandler->sync(this); - switch (getInterpreter()->adaptivePredict(_input, 81, _ctx)) { + switch (getInterpreter()->adaptivePredict(_input, 82, _ctx)) { case 1: { - setState(650); + setState(658); match(HogQLParser::SLASH); - setState(651); + setState(659); numberLiteral(); break; } @@ -5546,7 +5633,7 @@ std::any HogQLParser::SettingExprListContext::accept(tree::ParseTreeVisitor *vis HogQLParser::SettingExprListContext* HogQLParser::settingExprList() { SettingExprListContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 94, HogQLParser::RuleSettingExprList); + enterRule(_localctx, 96, HogQLParser::RuleSettingExprList); size_t _la = 0; #if __cplusplus > 201703L @@ -5558,17 +5645,17 @@ HogQLParser::SettingExprListContext* HogQLParser::settingExprList() { }); try { enterOuterAlt(_localctx, 1); - setState(656); + setState(664); settingExpr(); - setState(661); + setState(669); _errHandler->sync(this); _la = _input->LA(1); while (_la == HogQLParser::COMMA) { - setState(657); + setState(665); match(HogQLParser::COMMA); - setState(658); + setState(666); settingExpr(); - setState(663); + setState(671); _errHandler->sync(this); _la = _input->LA(1); } @@ -5616,7 +5703,7 @@ std::any HogQLParser::SettingExprContext::accept(tree::ParseTreeVisitor *visitor HogQLParser::SettingExprContext* HogQLParser::settingExpr() { SettingExprContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 96, HogQLParser::RuleSettingExpr); + enterRule(_localctx, 98, HogQLParser::RuleSettingExpr); #if __cplusplus > 201703L auto onExit = finally([=, this] { @@ -5627,11 +5714,11 @@ HogQLParser::SettingExprContext* HogQLParser::settingExpr() { }); try { enterOuterAlt(_localctx, 1); - setState(664); + setState(672); identifier(); - setState(665); + setState(673); match(HogQLParser::EQ_SINGLE); - setState(666); + setState(674); literal(); } @@ -5677,7 +5764,7 @@ std::any HogQLParser::WindowExprContext::accept(tree::ParseTreeVisitor *visitor) HogQLParser::WindowExprContext* HogQLParser::windowExpr() { WindowExprContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 98, HogQLParser::RuleWindowExpr); + enterRule(_localctx, 100, HogQLParser::RuleWindowExpr); size_t _la = 0; #if __cplusplus > 201703L @@ -5689,30 +5776,30 @@ HogQLParser::WindowExprContext* HogQLParser::windowExpr() { }); try { enterOuterAlt(_localctx, 1); - setState(669); + setState(677); _errHandler->sync(this); _la = _input->LA(1); if (_la == HogQLParser::PARTITION) { - setState(668); + setState(676); winPartitionByClause(); } - setState(672); + setState(680); _errHandler->sync(this); _la = _input->LA(1); if (_la == HogQLParser::ORDER) { - setState(671); + setState(679); winOrderByClause(); } - setState(675); + setState(683); _errHandler->sync(this); _la = _input->LA(1); if (_la == HogQLParser::RANGE || _la == HogQLParser::ROWS) { - setState(674); + setState(682); winFrameClause(); } @@ -5759,7 +5846,7 @@ std::any HogQLParser::WinPartitionByClauseContext::accept(tree::ParseTreeVisitor HogQLParser::WinPartitionByClauseContext* HogQLParser::winPartitionByClause() { WinPartitionByClauseContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 100, HogQLParser::RuleWinPartitionByClause); + enterRule(_localctx, 102, HogQLParser::RuleWinPartitionByClause); #if __cplusplus > 201703L auto onExit = finally([=, this] { @@ -5770,11 +5857,11 @@ HogQLParser::WinPartitionByClauseContext* HogQLParser::winPartitionByClause() { }); try { enterOuterAlt(_localctx, 1); - setState(677); + setState(685); match(HogQLParser::PARTITION); - setState(678); + setState(686); match(HogQLParser::BY); - setState(679); + setState(687); columnExprList(); } @@ -5820,7 +5907,7 @@ std::any HogQLParser::WinOrderByClauseContext::accept(tree::ParseTreeVisitor *vi HogQLParser::WinOrderByClauseContext* HogQLParser::winOrderByClause() { WinOrderByClauseContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 102, HogQLParser::RuleWinOrderByClause); + enterRule(_localctx, 104, HogQLParser::RuleWinOrderByClause); #if __cplusplus > 201703L auto onExit = finally([=, this] { @@ -5831,11 +5918,11 @@ HogQLParser::WinOrderByClauseContext* HogQLParser::winOrderByClause() { }); try { enterOuterAlt(_localctx, 1); - setState(681); + setState(689); match(HogQLParser::ORDER); - setState(682); + setState(690); match(HogQLParser::BY); - setState(683); + setState(691); orderExprList(); } @@ -5881,7 +5968,7 @@ std::any HogQLParser::WinFrameClauseContext::accept(tree::ParseTreeVisitor *visi HogQLParser::WinFrameClauseContext* HogQLParser::winFrameClause() { WinFrameClauseContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 104, HogQLParser::RuleWinFrameClause); + enterRule(_localctx, 106, HogQLParser::RuleWinFrameClause); size_t _la = 0; #if __cplusplus > 201703L @@ -5893,7 +5980,7 @@ HogQLParser::WinFrameClauseContext* HogQLParser::winFrameClause() { }); try { enterOuterAlt(_localctx, 1); - setState(685); + setState(693); _la = _input->LA(1); if (!(_la == HogQLParser::RANGE @@ -5904,7 +5991,7 @@ HogQLParser::WinFrameClauseContext* HogQLParser::winFrameClause() { _errHandler->reportMatch(this); consume(); } - setState(686); + setState(694); winFrameExtend(); } @@ -5976,7 +6063,7 @@ std::any HogQLParser::FrameBetweenContext::accept(tree::ParseTreeVisitor *visito } HogQLParser::WinFrameExtendContext* HogQLParser::winFrameExtend() { WinFrameExtendContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 106, HogQLParser::RuleWinFrameExtend); + enterRule(_localctx, 108, HogQLParser::RuleWinFrameExtend); #if __cplusplus > 201703L auto onExit = finally([=, this] { @@ -5986,7 +6073,7 @@ HogQLParser::WinFrameExtendContext* HogQLParser::winFrameExtend() { exitRule(); }); try { - setState(694); + setState(702); _errHandler->sync(this); switch (_input->LA(1)) { case HogQLParser::CURRENT: @@ -6002,7 +6089,7 @@ HogQLParser::WinFrameExtendContext* HogQLParser::winFrameExtend() { case HogQLParser::PLUS: { _localctx = _tracker.createInstance(_localctx); enterOuterAlt(_localctx, 1); - setState(688); + setState(696); winFrameBound(); break; } @@ -6010,13 +6097,13 @@ HogQLParser::WinFrameExtendContext* HogQLParser::winFrameExtend() { case HogQLParser::BETWEEN: { _localctx = _tracker.createInstance(_localctx); enterOuterAlt(_localctx, 2); - setState(689); + setState(697); match(HogQLParser::BETWEEN); - setState(690); + setState(698); winFrameBound(); - setState(691); + setState(699); match(HogQLParser::AND); - setState(692); + setState(700); winFrameBound(); break; } @@ -6080,7 +6167,7 @@ std::any HogQLParser::WinFrameBoundContext::accept(tree::ParseTreeVisitor *visit HogQLParser::WinFrameBoundContext* HogQLParser::winFrameBound() { WinFrameBoundContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 108, HogQLParser::RuleWinFrameBound); + enterRule(_localctx, 110, HogQLParser::RuleWinFrameBound); #if __cplusplus > 201703L auto onExit = finally([=, this] { @@ -6091,45 +6178,45 @@ HogQLParser::WinFrameBoundContext* HogQLParser::winFrameBound() { }); try { enterOuterAlt(_localctx, 1); - setState(708); + setState(716); _errHandler->sync(this); - switch (getInterpreter()->adaptivePredict(_input, 88, _ctx)) { + switch (getInterpreter()->adaptivePredict(_input, 89, _ctx)) { case 1: { - setState(696); + setState(704); match(HogQLParser::CURRENT); - setState(697); + setState(705); match(HogQLParser::ROW); break; } case 2: { - setState(698); + setState(706); match(HogQLParser::UNBOUNDED); - setState(699); + setState(707); match(HogQLParser::PRECEDING); break; } case 3: { - setState(700); + setState(708); match(HogQLParser::UNBOUNDED); - setState(701); + setState(709); match(HogQLParser::FOLLOWING); break; } case 4: { - setState(702); + setState(710); numberLiteral(); - setState(703); + setState(711); match(HogQLParser::PRECEDING); break; } case 5: { - setState(705); + setState(713); numberLiteral(); - setState(706); + setState(714); match(HogQLParser::FOLLOWING); break; } @@ -6177,7 +6264,7 @@ std::any HogQLParser::ExprContext::accept(tree::ParseTreeVisitor *visitor) { HogQLParser::ExprContext* HogQLParser::expr() { ExprContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 110, HogQLParser::RuleExpr); + enterRule(_localctx, 112, HogQLParser::RuleExpr); #if __cplusplus > 201703L auto onExit = finally([=, this] { @@ -6188,9 +6275,9 @@ HogQLParser::ExprContext* HogQLParser::expr() { }); try { enterOuterAlt(_localctx, 1); - setState(710); + setState(718); columnExpr(0); - setState(711); + setState(719); match(HogQLParser::EOF); } @@ -6383,7 +6470,7 @@ std::any HogQLParser::ColumnTypeExprEnumContext::accept(tree::ParseTreeVisitor * } HogQLParser::ColumnTypeExprContext* HogQLParser::columnTypeExpr() { ColumnTypeExprContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 112, HogQLParser::RuleColumnTypeExpr); + enterRule(_localctx, 114, HogQLParser::RuleColumnTypeExpr); size_t _la = 0; #if __cplusplus > 201703L @@ -6395,13 +6482,13 @@ HogQLParser::ColumnTypeExprContext* HogQLParser::columnTypeExpr() { }); try { size_t alt; - setState(769); + setState(777); _errHandler->sync(this); - switch (getInterpreter()->adaptivePredict(_input, 96, _ctx)) { + switch (getInterpreter()->adaptivePredict(_input, 97, _ctx)) { case 1: { _localctx = _tracker.createInstance(_localctx); enterOuterAlt(_localctx, 1); - setState(713); + setState(721); identifier(); break; } @@ -6409,39 +6496,39 @@ HogQLParser::ColumnTypeExprContext* HogQLParser::columnTypeExpr() { case 2: { _localctx = _tracker.createInstance(_localctx); enterOuterAlt(_localctx, 2); - setState(714); + setState(722); identifier(); - setState(715); + setState(723); match(HogQLParser::LPAREN); - setState(716); + setState(724); identifier(); - setState(717); + setState(725); columnTypeExpr(); - setState(724); + setState(732); _errHandler->sync(this); - alt = getInterpreter()->adaptivePredict(_input, 89, _ctx); + alt = getInterpreter()->adaptivePredict(_input, 90, _ctx); while (alt != 2 && alt != atn::ATN::INVALID_ALT_NUMBER) { if (alt == 1) { - setState(718); + setState(726); match(HogQLParser::COMMA); - setState(719); + setState(727); identifier(); - setState(720); + setState(728); columnTypeExpr(); } - setState(726); + setState(734); _errHandler->sync(this); - alt = getInterpreter()->adaptivePredict(_input, 89, _ctx); + alt = getInterpreter()->adaptivePredict(_input, 90, _ctx); } - setState(728); + setState(736); _errHandler->sync(this); _la = _input->LA(1); if (_la == HogQLParser::COMMA) { - setState(727); + setState(735); match(HogQLParser::COMMA); } - setState(730); + setState(738); match(HogQLParser::RPAREN); break; } @@ -6449,35 +6536,35 @@ HogQLParser::ColumnTypeExprContext* HogQLParser::columnTypeExpr() { case 3: { _localctx = _tracker.createInstance(_localctx); enterOuterAlt(_localctx, 3); - setState(732); + setState(740); identifier(); - setState(733); + setState(741); match(HogQLParser::LPAREN); - setState(734); + setState(742); enumValue(); - setState(739); + setState(747); _errHandler->sync(this); - alt = getInterpreter()->adaptivePredict(_input, 91, _ctx); + alt = getInterpreter()->adaptivePredict(_input, 92, _ctx); while (alt != 2 && alt != atn::ATN::INVALID_ALT_NUMBER) { if (alt == 1) { - setState(735); + setState(743); match(HogQLParser::COMMA); - setState(736); + setState(744); enumValue(); } - setState(741); + setState(749); _errHandler->sync(this); - alt = getInterpreter()->adaptivePredict(_input, 91, _ctx); + alt = getInterpreter()->adaptivePredict(_input, 92, _ctx); } - setState(743); + setState(751); _errHandler->sync(this); _la = _input->LA(1); if (_la == HogQLParser::COMMA) { - setState(742); + setState(750); match(HogQLParser::COMMA); } - setState(745); + setState(753); match(HogQLParser::RPAREN); break; } @@ -6485,35 +6572,35 @@ HogQLParser::ColumnTypeExprContext* HogQLParser::columnTypeExpr() { case 4: { _localctx = _tracker.createInstance(_localctx); enterOuterAlt(_localctx, 4); - setState(747); + setState(755); identifier(); - setState(748); + setState(756); match(HogQLParser::LPAREN); - setState(749); + setState(757); columnTypeExpr(); - setState(754); + setState(762); _errHandler->sync(this); - alt = getInterpreter()->adaptivePredict(_input, 93, _ctx); + alt = getInterpreter()->adaptivePredict(_input, 94, _ctx); while (alt != 2 && alt != atn::ATN::INVALID_ALT_NUMBER) { if (alt == 1) { - setState(750); + setState(758); match(HogQLParser::COMMA); - setState(751); + setState(759); columnTypeExpr(); } - setState(756); + setState(764); _errHandler->sync(this); - alt = getInterpreter()->adaptivePredict(_input, 93, _ctx); + alt = getInterpreter()->adaptivePredict(_input, 94, _ctx); } - setState(758); + setState(766); _errHandler->sync(this); _la = _input->LA(1); if (_la == HogQLParser::COMMA) { - setState(757); + setState(765); match(HogQLParser::COMMA); } - setState(760); + setState(768); match(HogQLParser::RPAREN); break; } @@ -6521,22 +6608,22 @@ HogQLParser::ColumnTypeExprContext* HogQLParser::columnTypeExpr() { case 5: { _localctx = _tracker.createInstance(_localctx); enterOuterAlt(_localctx, 5); - setState(762); + setState(770); identifier(); - setState(763); + setState(771); match(HogQLParser::LPAREN); - setState(765); + setState(773); _errHandler->sync(this); _la = _input->LA(1); if ((((_la & ~ 0x3fULL) == 0) && - ((1ULL << _la) & -9007270658588674) != 0) || ((((_la - 64) & ~ 0x3fULL) == 0) && - ((1ULL << (_la - 64)) & 180986072486903807) != 0) || ((((_la - 129) & ~ 0x3fULL) == 0) && - ((1ULL << (_la - 129)) & 18455) != 0)) { - setState(764); + ((1ULL << _la) & -36169677449216002) != 0) || ((((_la - 64) & ~ 0x3fULL) == 0) && + ((1ULL << (_la - 64)) & 723944289947615231) != 0) || ((((_la - 131) & ~ 0x3fULL) == 0) && + ((1ULL << (_la - 131)) & 18455) != 0)) { + setState(772); columnExprList(); } - setState(767); + setState(775); match(HogQLParser::RPAREN); break; } @@ -6592,7 +6679,7 @@ std::any HogQLParser::ColumnExprListContext::accept(tree::ParseTreeVisitor *visi HogQLParser::ColumnExprListContext* HogQLParser::columnExprList() { ColumnExprListContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 114, HogQLParser::RuleColumnExprList); + enterRule(_localctx, 116, HogQLParser::RuleColumnExprList); #if __cplusplus > 201703L auto onExit = finally([=, this] { @@ -6604,28 +6691,28 @@ HogQLParser::ColumnExprListContext* HogQLParser::columnExprList() { try { size_t alt; enterOuterAlt(_localctx, 1); - setState(771); + setState(779); columnExpr(0); - setState(776); + setState(784); _errHandler->sync(this); - alt = getInterpreter()->adaptivePredict(_input, 97, _ctx); + alt = getInterpreter()->adaptivePredict(_input, 98, _ctx); while (alt != 2 && alt != atn::ATN::INVALID_ALT_NUMBER) { if (alt == 1) { - setState(772); + setState(780); match(HogQLParser::COMMA); - setState(773); + setState(781); columnExpr(0); } - setState(778); + setState(786); _errHandler->sync(this); - alt = getInterpreter()->adaptivePredict(_input, 97, _ctx); + alt = getInterpreter()->adaptivePredict(_input, 98, _ctx); } - setState(780); + setState(788); _errHandler->sync(this); - switch (getInterpreter()->adaptivePredict(_input, 98, _ctx)) { + switch (getInterpreter()->adaptivePredict(_input, 99, _ctx)) { case 1: { - setState(779); + setState(787); match(HogQLParser::COMMA); break; } @@ -6761,8 +6848,8 @@ tree::TerminalNode* HogQLParser::ColumnExprSubqueryContext::LPAREN() { return getToken(HogQLParser::LPAREN, 0); } -HogQLParser::SelectUnionStmtContext* HogQLParser::ColumnExprSubqueryContext::selectUnionStmt() { - return getRuleContext(0); +HogQLParser::SelectSetStmtContext* HogQLParser::ColumnExprSubqueryContext::selectSetStmt() { + return getRuleContext(0); } tree::TerminalNode* HogQLParser::ColumnExprSubqueryContext::RPAREN() { @@ -7806,8 +7893,8 @@ HogQLParser::ColumnExprContext* HogQLParser::columnExpr(int precedence) { HogQLParser::ColumnExprContext *_localctx = _tracker.createInstance(_ctx, parentState); HogQLParser::ColumnExprContext *previousContext = _localctx; (void)previousContext; // Silence compiler, in case the context is not used by generated code. - size_t startState = 116; - enterRecursionRule(_localctx, 116, HogQLParser::RuleColumnExpr, precedence); + size_t startState = 118; + enterRecursionRule(_localctx, 118, HogQLParser::RuleColumnExpr, precedence); size_t _la = 0; @@ -7821,22 +7908,22 @@ HogQLParser::ColumnExprContext* HogQLParser::columnExpr(int precedence) { try { size_t alt; enterOuterAlt(_localctx, 1); - setState(932); + setState(940); _errHandler->sync(this); - switch (getInterpreter()->adaptivePredict(_input, 118, _ctx)) { + switch (getInterpreter()->adaptivePredict(_input, 119, _ctx)) { case 1: { _localctx = _tracker.createInstance(_localctx); _ctx = _localctx; previousContext = _localctx; - setState(783); + setState(791); match(HogQLParser::CASE); - setState(785); + setState(793); _errHandler->sync(this); - switch (getInterpreter()->adaptivePredict(_input, 99, _ctx)) { + switch (getInterpreter()->adaptivePredict(_input, 100, _ctx)) { case 1: { - setState(784); + setState(792); antlrcpp::downCast(_localctx)->caseExpr = columnExpr(0); break; } @@ -7844,33 +7931,33 @@ HogQLParser::ColumnExprContext* HogQLParser::columnExpr(int precedence) { default: break; } - setState(792); + setState(800); _errHandler->sync(this); _la = _input->LA(1); do { - setState(787); + setState(795); match(HogQLParser::WHEN); - setState(788); + setState(796); antlrcpp::downCast(_localctx)->whenExpr = columnExpr(0); - setState(789); + setState(797); match(HogQLParser::THEN); - setState(790); + setState(798); antlrcpp::downCast(_localctx)->thenExpr = columnExpr(0); - setState(794); + setState(802); _errHandler->sync(this); _la = _input->LA(1); } while (_la == HogQLParser::WHEN); - setState(798); + setState(806); _errHandler->sync(this); _la = _input->LA(1); if (_la == HogQLParser::ELSE) { - setState(796); + setState(804); match(HogQLParser::ELSE); - setState(797); + setState(805); antlrcpp::downCast(_localctx)->elseExpr = columnExpr(0); } - setState(800); + setState(808); match(HogQLParser::END); break; } @@ -7879,17 +7966,17 @@ HogQLParser::ColumnExprContext* HogQLParser::columnExpr(int precedence) { _localctx = _tracker.createInstance(_localctx); _ctx = _localctx; previousContext = _localctx; - setState(802); + setState(810); match(HogQLParser::CAST); - setState(803); + setState(811); match(HogQLParser::LPAREN); - setState(804); + setState(812); columnExpr(0); - setState(805); + setState(813); match(HogQLParser::AS); - setState(806); + setState(814); columnTypeExpr(); - setState(807); + setState(815); match(HogQLParser::RPAREN); break; } @@ -7898,9 +7985,9 @@ HogQLParser::ColumnExprContext* HogQLParser::columnExpr(int precedence) { _localctx = _tracker.createInstance(_localctx); _ctx = _localctx; previousContext = _localctx; - setState(809); + setState(817); match(HogQLParser::DATE); - setState(810); + setState(818); match(HogQLParser::STRING_LITERAL); break; } @@ -7909,11 +7996,11 @@ HogQLParser::ColumnExprContext* HogQLParser::columnExpr(int precedence) { _localctx = _tracker.createInstance(_localctx); _ctx = _localctx; previousContext = _localctx; - setState(811); + setState(819); match(HogQLParser::INTERVAL); - setState(812); + setState(820); columnExpr(0); - setState(813); + setState(821); interval(); break; } @@ -7922,27 +8009,27 @@ HogQLParser::ColumnExprContext* HogQLParser::columnExpr(int precedence) { _localctx = _tracker.createInstance(_localctx); _ctx = _localctx; previousContext = _localctx; - setState(815); + setState(823); match(HogQLParser::SUBSTRING); - setState(816); + setState(824); match(HogQLParser::LPAREN); - setState(817); + setState(825); columnExpr(0); - setState(818); + setState(826); match(HogQLParser::FROM); - setState(819); + setState(827); columnExpr(0); - setState(822); + setState(830); _errHandler->sync(this); _la = _input->LA(1); if (_la == HogQLParser::FOR) { - setState(820); + setState(828); match(HogQLParser::FOR); - setState(821); + setState(829); columnExpr(0); } - setState(824); + setState(832); match(HogQLParser::RPAREN); break; } @@ -7951,9 +8038,9 @@ HogQLParser::ColumnExprContext* HogQLParser::columnExpr(int precedence) { _localctx = _tracker.createInstance(_localctx); _ctx = _localctx; previousContext = _localctx; - setState(826); + setState(834); match(HogQLParser::TIMESTAMP); - setState(827); + setState(835); match(HogQLParser::STRING_LITERAL); break; } @@ -7962,11 +8049,11 @@ HogQLParser::ColumnExprContext* HogQLParser::columnExpr(int precedence) { _localctx = _tracker.createInstance(_localctx); _ctx = _localctx; previousContext = _localctx; - setState(828); + setState(836); match(HogQLParser::TRIM); - setState(829); + setState(837); match(HogQLParser::LPAREN); - setState(830); + setState(838); _la = _input->LA(1); if (!(_la == HogQLParser::BOTH @@ -7977,13 +8064,13 @@ HogQLParser::ColumnExprContext* HogQLParser::columnExpr(int precedence) { _errHandler->reportMatch(this); consume(); } - setState(831); + setState(839); string(); - setState(832); + setState(840); match(HogQLParser::FROM); - setState(833); + setState(841); columnExpr(0); - setState(834); + setState(842); match(HogQLParser::RPAREN); break; } @@ -7992,37 +8079,37 @@ HogQLParser::ColumnExprContext* HogQLParser::columnExpr(int precedence) { _localctx = _tracker.createInstance(_localctx); _ctx = _localctx; previousContext = _localctx; - setState(836); + setState(844); identifier(); - setState(837); + setState(845); match(HogQLParser::LPAREN); - setState(839); + setState(847); _errHandler->sync(this); _la = _input->LA(1); if ((((_la & ~ 0x3fULL) == 0) && - ((1ULL << _la) & -9007270658588674) != 0) || ((((_la - 64) & ~ 0x3fULL) == 0) && - ((1ULL << (_la - 64)) & 180986072486903807) != 0) || ((((_la - 129) & ~ 0x3fULL) == 0) && - ((1ULL << (_la - 129)) & 18455) != 0)) { - setState(838); + ((1ULL << _la) & -36169677449216002) != 0) || ((((_la - 64) & ~ 0x3fULL) == 0) && + ((1ULL << (_la - 64)) & 723944289947615231) != 0) || ((((_la - 131) & ~ 0x3fULL) == 0) && + ((1ULL << (_la - 131)) & 18455) != 0)) { + setState(846); antlrcpp::downCast(_localctx)->columnExprs = columnExprList(); } - setState(841); + setState(849); match(HogQLParser::RPAREN); - setState(851); + setState(859); _errHandler->sync(this); _la = _input->LA(1); if (_la == HogQLParser::LPAREN) { - setState(843); + setState(851); match(HogQLParser::LPAREN); - setState(845); + setState(853); _errHandler->sync(this); - switch (getInterpreter()->adaptivePredict(_input, 104, _ctx)) { + switch (getInterpreter()->adaptivePredict(_input, 105, _ctx)) { case 1: { - setState(844); + setState(852); match(HogQLParser::DISTINCT); break; } @@ -8030,27 +8117,27 @@ HogQLParser::ColumnExprContext* HogQLParser::columnExpr(int precedence) { default: break; } - setState(848); + setState(856); _errHandler->sync(this); _la = _input->LA(1); if ((((_la & ~ 0x3fULL) == 0) && - ((1ULL << _la) & -9007270658588674) != 0) || ((((_la - 64) & ~ 0x3fULL) == 0) && - ((1ULL << (_la - 64)) & 180986072486903807) != 0) || ((((_la - 129) & ~ 0x3fULL) == 0) && - ((1ULL << (_la - 129)) & 18455) != 0)) { - setState(847); + ((1ULL << _la) & -36169677449216002) != 0) || ((((_la - 64) & ~ 0x3fULL) == 0) && + ((1ULL << (_la - 64)) & 723944289947615231) != 0) || ((((_la - 131) & ~ 0x3fULL) == 0) && + ((1ULL << (_la - 131)) & 18455) != 0)) { + setState(855); antlrcpp::downCast(_localctx)->columnArgList = columnExprList(); } - setState(850); + setState(858); match(HogQLParser::RPAREN); } - setState(853); + setState(861); match(HogQLParser::OVER); - setState(854); + setState(862); match(HogQLParser::LPAREN); - setState(855); + setState(863); windowExpr(); - setState(856); + setState(864); match(HogQLParser::RPAREN); break; } @@ -8059,37 +8146,37 @@ HogQLParser::ColumnExprContext* HogQLParser::columnExpr(int precedence) { _localctx = _tracker.createInstance(_localctx); _ctx = _localctx; previousContext = _localctx; - setState(858); + setState(866); identifier(); - setState(859); + setState(867); match(HogQLParser::LPAREN); - setState(861); + setState(869); _errHandler->sync(this); _la = _input->LA(1); if ((((_la & ~ 0x3fULL) == 0) && - ((1ULL << _la) & -9007270658588674) != 0) || ((((_la - 64) & ~ 0x3fULL) == 0) && - ((1ULL << (_la - 64)) & 180986072486903807) != 0) || ((((_la - 129) & ~ 0x3fULL) == 0) && - ((1ULL << (_la - 129)) & 18455) != 0)) { - setState(860); + ((1ULL << _la) & -36169677449216002) != 0) || ((((_la - 64) & ~ 0x3fULL) == 0) && + ((1ULL << (_la - 64)) & 723944289947615231) != 0) || ((((_la - 131) & ~ 0x3fULL) == 0) && + ((1ULL << (_la - 131)) & 18455) != 0)) { + setState(868); antlrcpp::downCast(_localctx)->columnExprs = columnExprList(); } - setState(863); + setState(871); match(HogQLParser::RPAREN); - setState(873); + setState(881); _errHandler->sync(this); _la = _input->LA(1); if (_la == HogQLParser::LPAREN) { - setState(865); + setState(873); match(HogQLParser::LPAREN); - setState(867); + setState(875); _errHandler->sync(this); - switch (getInterpreter()->adaptivePredict(_input, 108, _ctx)) { + switch (getInterpreter()->adaptivePredict(_input, 109, _ctx)) { case 1: { - setState(866); + setState(874); match(HogQLParser::DISTINCT); break; } @@ -8097,23 +8184,23 @@ HogQLParser::ColumnExprContext* HogQLParser::columnExpr(int precedence) { default: break; } - setState(870); + setState(878); _errHandler->sync(this); _la = _input->LA(1); if ((((_la & ~ 0x3fULL) == 0) && - ((1ULL << _la) & -9007270658588674) != 0) || ((((_la - 64) & ~ 0x3fULL) == 0) && - ((1ULL << (_la - 64)) & 180986072486903807) != 0) || ((((_la - 129) & ~ 0x3fULL) == 0) && - ((1ULL << (_la - 129)) & 18455) != 0)) { - setState(869); + ((1ULL << _la) & -36169677449216002) != 0) || ((((_la - 64) & ~ 0x3fULL) == 0) && + ((1ULL << (_la - 64)) & 723944289947615231) != 0) || ((((_la - 131) & ~ 0x3fULL) == 0) && + ((1ULL << (_la - 131)) & 18455) != 0)) { + setState(877); antlrcpp::downCast(_localctx)->columnArgList = columnExprList(); } - setState(872); + setState(880); match(HogQLParser::RPAREN); } - setState(875); + setState(883); match(HogQLParser::OVER); - setState(876); + setState(884); identifier(); break; } @@ -8122,27 +8209,27 @@ HogQLParser::ColumnExprContext* HogQLParser::columnExpr(int precedence) { _localctx = _tracker.createInstance(_localctx); _ctx = _localctx; previousContext = _localctx; - setState(878); + setState(886); identifier(); - setState(884); + setState(892); _errHandler->sync(this); - switch (getInterpreter()->adaptivePredict(_input, 112, _ctx)) { + switch (getInterpreter()->adaptivePredict(_input, 113, _ctx)) { case 1: { - setState(879); + setState(887); match(HogQLParser::LPAREN); - setState(881); + setState(889); _errHandler->sync(this); _la = _input->LA(1); if ((((_la & ~ 0x3fULL) == 0) && - ((1ULL << _la) & -9007270658588674) != 0) || ((((_la - 64) & ~ 0x3fULL) == 0) && - ((1ULL << (_la - 64)) & 180986072486903807) != 0) || ((((_la - 129) & ~ 0x3fULL) == 0) && - ((1ULL << (_la - 129)) & 18455) != 0)) { - setState(880); + ((1ULL << _la) & -36169677449216002) != 0) || ((((_la - 64) & ~ 0x3fULL) == 0) && + ((1ULL << (_la - 64)) & 723944289947615231) != 0) || ((((_la - 131) & ~ 0x3fULL) == 0) && + ((1ULL << (_la - 131)) & 18455) != 0)) { + setState(888); antlrcpp::downCast(_localctx)->columnExprs = columnExprList(); } - setState(883); + setState(891); match(HogQLParser::RPAREN); break; } @@ -8150,14 +8237,14 @@ HogQLParser::ColumnExprContext* HogQLParser::columnExpr(int precedence) { default: break; } - setState(886); + setState(894); match(HogQLParser::LPAREN); - setState(888); + setState(896); _errHandler->sync(this); - switch (getInterpreter()->adaptivePredict(_input, 113, _ctx)) { + switch (getInterpreter()->adaptivePredict(_input, 114, _ctx)) { case 1: { - setState(887); + setState(895); match(HogQLParser::DISTINCT); break; } @@ -8165,18 +8252,18 @@ HogQLParser::ColumnExprContext* HogQLParser::columnExpr(int precedence) { default: break; } - setState(891); + setState(899); _errHandler->sync(this); _la = _input->LA(1); if ((((_la & ~ 0x3fULL) == 0) && - ((1ULL << _la) & -9007270658588674) != 0) || ((((_la - 64) & ~ 0x3fULL) == 0) && - ((1ULL << (_la - 64)) & 180986072486903807) != 0) || ((((_la - 129) & ~ 0x3fULL) == 0) && - ((1ULL << (_la - 129)) & 18455) != 0)) { - setState(890); + ((1ULL << _la) & -36169677449216002) != 0) || ((((_la - 64) & ~ 0x3fULL) == 0) && + ((1ULL << (_la - 64)) & 723944289947615231) != 0) || ((((_la - 131) & ~ 0x3fULL) == 0) && + ((1ULL << (_la - 131)) & 18455) != 0)) { + setState(898); antlrcpp::downCast(_localctx)->columnArgList = columnExprList(); } - setState(893); + setState(901); match(HogQLParser::RPAREN); break; } @@ -8185,7 +8272,7 @@ HogQLParser::ColumnExprContext* HogQLParser::columnExpr(int precedence) { _localctx = _tracker.createInstance(_localctx); _ctx = _localctx; previousContext = _localctx; - setState(895); + setState(903); hogqlxTagElement(); break; } @@ -8194,7 +8281,7 @@ HogQLParser::ColumnExprContext* HogQLParser::columnExpr(int precedence) { _localctx = _tracker.createInstance(_localctx); _ctx = _localctx; previousContext = _localctx; - setState(896); + setState(904); templateString(); break; } @@ -8203,7 +8290,7 @@ HogQLParser::ColumnExprContext* HogQLParser::columnExpr(int precedence) { _localctx = _tracker.createInstance(_localctx); _ctx = _localctx; previousContext = _localctx; - setState(897); + setState(905); literal(); break; } @@ -8212,9 +8299,9 @@ HogQLParser::ColumnExprContext* HogQLParser::columnExpr(int precedence) { _localctx = _tracker.createInstance(_localctx); _ctx = _localctx; previousContext = _localctx; - setState(898); + setState(906); match(HogQLParser::DASH); - setState(899); + setState(907); columnExpr(20); break; } @@ -8223,9 +8310,9 @@ HogQLParser::ColumnExprContext* HogQLParser::columnExpr(int precedence) { _localctx = _tracker.createInstance(_localctx); _ctx = _localctx; previousContext = _localctx; - setState(900); + setState(908); match(HogQLParser::NOT); - setState(901); + setState(909); columnExpr(14); break; } @@ -8234,19 +8321,19 @@ HogQLParser::ColumnExprContext* HogQLParser::columnExpr(int precedence) { _localctx = _tracker.createInstance(_localctx); _ctx = _localctx; previousContext = _localctx; - setState(905); + setState(913); _errHandler->sync(this); _la = _input->LA(1); if ((((_la & ~ 0x3fULL) == 0) && - ((1ULL << _la) & -1450176743603191810) != 0) || ((((_la - 64) & ~ 0x3fULL) == 0) && - ((1ULL << (_la - 64)) & 6458554974207) != 0)) { - setState(902); + ((1ULL << _la) & -5800812384855539714) != 0) || ((((_la - 64) & ~ 0x3fULL) == 0) && + ((1ULL << (_la - 64)) & 25834219896831) != 0)) { + setState(910); tableIdentifier(); - setState(903); + setState(911); match(HogQLParser::DOT); } - setState(907); + setState(915); match(HogQLParser::ASTERISK); break; } @@ -8255,11 +8342,11 @@ HogQLParser::ColumnExprContext* HogQLParser::columnExpr(int precedence) { _localctx = _tracker.createInstance(_localctx); _ctx = _localctx; previousContext = _localctx; - setState(908); + setState(916); match(HogQLParser::LPAREN); - setState(909); - selectUnionStmt(); - setState(910); + setState(917); + selectSetStmt(); + setState(918); match(HogQLParser::RPAREN); break; } @@ -8268,11 +8355,11 @@ HogQLParser::ColumnExprContext* HogQLParser::columnExpr(int precedence) { _localctx = _tracker.createInstance(_localctx); _ctx = _localctx; previousContext = _localctx; - setState(912); + setState(920); match(HogQLParser::LPAREN); - setState(913); + setState(921); columnExpr(0); - setState(914); + setState(922); match(HogQLParser::RPAREN); break; } @@ -8281,11 +8368,11 @@ HogQLParser::ColumnExprContext* HogQLParser::columnExpr(int precedence) { _localctx = _tracker.createInstance(_localctx); _ctx = _localctx; previousContext = _localctx; - setState(916); + setState(924); match(HogQLParser::LPAREN); - setState(917); + setState(925); columnExprList(); - setState(918); + setState(926); match(HogQLParser::RPAREN); break; } @@ -8294,20 +8381,20 @@ HogQLParser::ColumnExprContext* HogQLParser::columnExpr(int precedence) { _localctx = _tracker.createInstance(_localctx); _ctx = _localctx; previousContext = _localctx; - setState(920); + setState(928); match(HogQLParser::LBRACKET); - setState(922); + setState(930); _errHandler->sync(this); _la = _input->LA(1); if ((((_la & ~ 0x3fULL) == 0) && - ((1ULL << _la) & -9007270658588674) != 0) || ((((_la - 64) & ~ 0x3fULL) == 0) && - ((1ULL << (_la - 64)) & 180986072486903807) != 0) || ((((_la - 129) & ~ 0x3fULL) == 0) && - ((1ULL << (_la - 129)) & 18455) != 0)) { - setState(921); + ((1ULL << _la) & -36169677449216002) != 0) || ((((_la - 64) & ~ 0x3fULL) == 0) && + ((1ULL << (_la - 64)) & 723944289947615231) != 0) || ((((_la - 131) & ~ 0x3fULL) == 0) && + ((1ULL << (_la - 131)) & 18455) != 0)) { + setState(929); columnExprList(); } - setState(924); + setState(932); match(HogQLParser::RBRACKET); break; } @@ -8316,20 +8403,20 @@ HogQLParser::ColumnExprContext* HogQLParser::columnExpr(int precedence) { _localctx = _tracker.createInstance(_localctx); _ctx = _localctx; previousContext = _localctx; - setState(925); + setState(933); match(HogQLParser::LBRACE); - setState(927); + setState(935); _errHandler->sync(this); _la = _input->LA(1); if ((((_la & ~ 0x3fULL) == 0) && - ((1ULL << _la) & -9007270658588674) != 0) || ((((_la - 64) & ~ 0x3fULL) == 0) && - ((1ULL << (_la - 64)) & 180986072486903807) != 0) || ((((_la - 129) & ~ 0x3fULL) == 0) && - ((1ULL << (_la - 129)) & 18455) != 0)) { - setState(926); + ((1ULL << _la) & -36169677449216002) != 0) || ((((_la - 64) & ~ 0x3fULL) == 0) && + ((1ULL << (_la - 64)) & 723944289947615231) != 0) || ((((_la - 131) & ~ 0x3fULL) == 0) && + ((1ULL << (_la - 131)) & 18455) != 0)) { + setState(934); kvPairList(); } - setState(929); + setState(937); match(HogQLParser::RBRACE); break; } @@ -8338,7 +8425,7 @@ HogQLParser::ColumnExprContext* HogQLParser::columnExpr(int precedence) { _localctx = _tracker.createInstance(_localctx); _ctx = _localctx; previousContext = _localctx; - setState(930); + setState(938); columnLambdaExpr(); break; } @@ -8347,7 +8434,7 @@ HogQLParser::ColumnExprContext* HogQLParser::columnExpr(int precedence) { _localctx = _tracker.createInstance(_localctx); _ctx = _localctx; previousContext = _localctx; - setState(931); + setState(939); columnIdentifier(); break; } @@ -8356,42 +8443,42 @@ HogQLParser::ColumnExprContext* HogQLParser::columnExpr(int precedence) { break; } _ctx->stop = _input->LT(-1); - setState(1044); + setState(1052); _errHandler->sync(this); - alt = getInterpreter()->adaptivePredict(_input, 130, _ctx); + alt = getInterpreter()->adaptivePredict(_input, 131, _ctx); while (alt != 2 && alt != atn::ATN::INVALID_ALT_NUMBER) { if (alt == 1) { if (!_parseListeners.empty()) triggerExitRuleEvent(); previousContext = _localctx; - setState(1042); + setState(1050); _errHandler->sync(this); - switch (getInterpreter()->adaptivePredict(_input, 129, _ctx)) { + switch (getInterpreter()->adaptivePredict(_input, 130, _ctx)) { case 1: { auto newContext = _tracker.createInstance(_tracker.createInstance(parentContext, parentState)); _localctx = newContext; newContext->left = previousContext; pushNewRecursionContext(newContext, startState, RuleColumnExpr); - setState(934); + setState(942); if (!(precpred(_ctx, 19))) throw FailedPredicateException(this, "precpred(_ctx, 19)"); - setState(938); + setState(946); _errHandler->sync(this); switch (_input->LA(1)) { case HogQLParser::ASTERISK: { - setState(935); + setState(943); antlrcpp::downCast(_localctx)->operator_ = match(HogQLParser::ASTERISK); break; } case HogQLParser::SLASH: { - setState(936); + setState(944); antlrcpp::downCast(_localctx)->operator_ = match(HogQLParser::SLASH); break; } case HogQLParser::PERCENT: { - setState(937); + setState(945); antlrcpp::downCast(_localctx)->operator_ = match(HogQLParser::PERCENT); break; } @@ -8399,7 +8486,7 @@ HogQLParser::ColumnExprContext* HogQLParser::columnExpr(int precedence) { default: throw NoViableAltException(this); } - setState(940); + setState(948); antlrcpp::downCast(_localctx)->right = columnExpr(20); break; } @@ -8409,26 +8496,26 @@ HogQLParser::ColumnExprContext* HogQLParser::columnExpr(int precedence) { _localctx = newContext; newContext->left = previousContext; pushNewRecursionContext(newContext, startState, RuleColumnExpr); - setState(941); + setState(949); if (!(precpred(_ctx, 18))) throw FailedPredicateException(this, "precpred(_ctx, 18)"); - setState(945); + setState(953); _errHandler->sync(this); switch (_input->LA(1)) { case HogQLParser::PLUS: { - setState(942); + setState(950); antlrcpp::downCast(_localctx)->operator_ = match(HogQLParser::PLUS); break; } case HogQLParser::DASH: { - setState(943); + setState(951); antlrcpp::downCast(_localctx)->operator_ = match(HogQLParser::DASH); break; } case HogQLParser::CONCAT: { - setState(944); + setState(952); antlrcpp::downCast(_localctx)->operator_ = match(HogQLParser::CONCAT); break; } @@ -8436,7 +8523,7 @@ HogQLParser::ColumnExprContext* HogQLParser::columnExpr(int precedence) { default: throw NoViableAltException(this); } - setState(947); + setState(955); antlrcpp::downCast(_localctx)->right = columnExpr(19); break; } @@ -8446,71 +8533,71 @@ HogQLParser::ColumnExprContext* HogQLParser::columnExpr(int precedence) { _localctx = newContext; newContext->left = previousContext; pushNewRecursionContext(newContext, startState, RuleColumnExpr); - setState(948); + setState(956); if (!(precpred(_ctx, 17))) throw FailedPredicateException(this, "precpred(_ctx, 17)"); - setState(973); + setState(981); _errHandler->sync(this); - switch (getInterpreter()->adaptivePredict(_input, 124, _ctx)) { + switch (getInterpreter()->adaptivePredict(_input, 125, _ctx)) { case 1: { - setState(949); + setState(957); antlrcpp::downCast(_localctx)->operator_ = match(HogQLParser::EQ_DOUBLE); break; } case 2: { - setState(950); + setState(958); antlrcpp::downCast(_localctx)->operator_ = match(HogQLParser::EQ_SINGLE); break; } case 3: { - setState(951); + setState(959); antlrcpp::downCast(_localctx)->operator_ = match(HogQLParser::NOT_EQ); break; } case 4: { - setState(952); + setState(960); antlrcpp::downCast(_localctx)->operator_ = match(HogQLParser::LT_EQ); break; } case 5: { - setState(953); + setState(961); antlrcpp::downCast(_localctx)->operator_ = match(HogQLParser::LT); break; } case 6: { - setState(954); + setState(962); antlrcpp::downCast(_localctx)->operator_ = match(HogQLParser::GT_EQ); break; } case 7: { - setState(955); + setState(963); antlrcpp::downCast(_localctx)->operator_ = match(HogQLParser::GT); break; } case 8: { - setState(957); + setState(965); _errHandler->sync(this); _la = _input->LA(1); if (_la == HogQLParser::NOT) { - setState(956); + setState(964); antlrcpp::downCast(_localctx)->operator_ = match(HogQLParser::NOT); } - setState(959); + setState(967); match(HogQLParser::IN); - setState(961); + setState(969); _errHandler->sync(this); - switch (getInterpreter()->adaptivePredict(_input, 122, _ctx)) { + switch (getInterpreter()->adaptivePredict(_input, 123, _ctx)) { case 1: { - setState(960); + setState(968); match(HogQLParser::COHORT); break; } @@ -8522,15 +8609,15 @@ HogQLParser::ColumnExprContext* HogQLParser::columnExpr(int precedence) { } case 9: { - setState(964); + setState(972); _errHandler->sync(this); _la = _input->LA(1); if (_la == HogQLParser::NOT) { - setState(963); + setState(971); antlrcpp::downCast(_localctx)->operator_ = match(HogQLParser::NOT); } - setState(966); + setState(974); _la = _input->LA(1); if (!(_la == HogQLParser::ILIKE @@ -8545,37 +8632,37 @@ HogQLParser::ColumnExprContext* HogQLParser::columnExpr(int precedence) { } case 10: { - setState(967); + setState(975); antlrcpp::downCast(_localctx)->operator_ = match(HogQLParser::REGEX_SINGLE); break; } case 11: { - setState(968); + setState(976); antlrcpp::downCast(_localctx)->operator_ = match(HogQLParser::REGEX_DOUBLE); break; } case 12: { - setState(969); + setState(977); antlrcpp::downCast(_localctx)->operator_ = match(HogQLParser::NOT_REGEX); break; } case 13: { - setState(970); + setState(978); antlrcpp::downCast(_localctx)->operator_ = match(HogQLParser::IREGEX_SINGLE); break; } case 14: { - setState(971); + setState(979); antlrcpp::downCast(_localctx)->operator_ = match(HogQLParser::IREGEX_DOUBLE); break; } case 15: { - setState(972); + setState(980); antlrcpp::downCast(_localctx)->operator_ = match(HogQLParser::NOT_IREGEX); break; } @@ -8583,7 +8670,7 @@ HogQLParser::ColumnExprContext* HogQLParser::columnExpr(int precedence) { default: break; } - setState(975); + setState(983); antlrcpp::downCast(_localctx)->right = columnExpr(18); break; } @@ -8592,12 +8679,12 @@ HogQLParser::ColumnExprContext* HogQLParser::columnExpr(int precedence) { auto newContext = _tracker.createInstance(_tracker.createInstance(parentContext, parentState)); _localctx = newContext; pushNewRecursionContext(newContext, startState, RuleColumnExpr); - setState(976); + setState(984); if (!(precpred(_ctx, 15))) throw FailedPredicateException(this, "precpred(_ctx, 15)"); - setState(977); + setState(985); match(HogQLParser::NULLISH); - setState(978); + setState(986); columnExpr(16); break; } @@ -8606,12 +8693,12 @@ HogQLParser::ColumnExprContext* HogQLParser::columnExpr(int precedence) { auto newContext = _tracker.createInstance(_tracker.createInstance(parentContext, parentState)); _localctx = newContext; pushNewRecursionContext(newContext, startState, RuleColumnExpr); - setState(979); + setState(987); if (!(precpred(_ctx, 13))) throw FailedPredicateException(this, "precpred(_ctx, 13)"); - setState(980); + setState(988); match(HogQLParser::AND); - setState(981); + setState(989); columnExpr(14); break; } @@ -8620,12 +8707,12 @@ HogQLParser::ColumnExprContext* HogQLParser::columnExpr(int precedence) { auto newContext = _tracker.createInstance(_tracker.createInstance(parentContext, parentState)); _localctx = newContext; pushNewRecursionContext(newContext, startState, RuleColumnExpr); - setState(982); + setState(990); if (!(precpred(_ctx, 12))) throw FailedPredicateException(this, "precpred(_ctx, 12)"); - setState(983); + setState(991); match(HogQLParser::OR); - setState(984); + setState(992); columnExpr(13); break; } @@ -8634,24 +8721,24 @@ HogQLParser::ColumnExprContext* HogQLParser::columnExpr(int precedence) { auto newContext = _tracker.createInstance(_tracker.createInstance(parentContext, parentState)); _localctx = newContext; pushNewRecursionContext(newContext, startState, RuleColumnExpr); - setState(985); + setState(993); if (!(precpred(_ctx, 11))) throw FailedPredicateException(this, "precpred(_ctx, 11)"); - setState(987); + setState(995); _errHandler->sync(this); _la = _input->LA(1); if (_la == HogQLParser::NOT) { - setState(986); + setState(994); match(HogQLParser::NOT); } - setState(989); + setState(997); match(HogQLParser::BETWEEN); - setState(990); + setState(998); columnExpr(0); - setState(991); + setState(999); match(HogQLParser::AND); - setState(992); + setState(1000); columnExpr(12); break; } @@ -8660,16 +8747,16 @@ HogQLParser::ColumnExprContext* HogQLParser::columnExpr(int precedence) { auto newContext = _tracker.createInstance(_tracker.createInstance(parentContext, parentState)); _localctx = newContext; pushNewRecursionContext(newContext, startState, RuleColumnExpr); - setState(994); + setState(1002); if (!(precpred(_ctx, 10))) throw FailedPredicateException(this, "precpred(_ctx, 10)"); - setState(995); + setState(1003); match(HogQLParser::QUERY); - setState(996); + setState(1004); columnExpr(0); - setState(997); + setState(1005); match(HogQLParser::COLON); - setState(998); + setState(1006); columnExpr(10); break; } @@ -8678,23 +8765,23 @@ HogQLParser::ColumnExprContext* HogQLParser::columnExpr(int precedence) { auto newContext = _tracker.createInstance(_tracker.createInstance(parentContext, parentState)); _localctx = newContext; pushNewRecursionContext(newContext, startState, RuleColumnExpr); - setState(1000); + setState(1008); if (!(precpred(_ctx, 30))) throw FailedPredicateException(this, "precpred(_ctx, 30)"); - setState(1001); + setState(1009); match(HogQLParser::LPAREN); - setState(1003); + setState(1011); _errHandler->sync(this); _la = _input->LA(1); if ((((_la & ~ 0x3fULL) == 0) && - ((1ULL << _la) & -9007270658588674) != 0) || ((((_la - 64) & ~ 0x3fULL) == 0) && - ((1ULL << (_la - 64)) & 180986072486903807) != 0) || ((((_la - 129) & ~ 0x3fULL) == 0) && - ((1ULL << (_la - 129)) & 18455) != 0)) { - setState(1002); + ((1ULL << _la) & -36169677449216002) != 0) || ((((_la - 64) & ~ 0x3fULL) == 0) && + ((1ULL << (_la - 64)) & 723944289947615231) != 0) || ((((_la - 131) & ~ 0x3fULL) == 0) && + ((1ULL << (_la - 131)) & 18455) != 0)) { + setState(1010); columnExprList(); } - setState(1005); + setState(1013); match(HogQLParser::RPAREN); break; } @@ -8703,14 +8790,14 @@ HogQLParser::ColumnExprContext* HogQLParser::columnExpr(int precedence) { auto newContext = _tracker.createInstance(_tracker.createInstance(parentContext, parentState)); _localctx = newContext; pushNewRecursionContext(newContext, startState, RuleColumnExpr); - setState(1006); + setState(1014); if (!(precpred(_ctx, 26))) throw FailedPredicateException(this, "precpred(_ctx, 26)"); - setState(1007); + setState(1015); match(HogQLParser::LBRACKET); - setState(1008); + setState(1016); columnExpr(0); - setState(1009); + setState(1017); match(HogQLParser::RBRACKET); break; } @@ -8719,12 +8806,12 @@ HogQLParser::ColumnExprContext* HogQLParser::columnExpr(int precedence) { auto newContext = _tracker.createInstance(_tracker.createInstance(parentContext, parentState)); _localctx = newContext; pushNewRecursionContext(newContext, startState, RuleColumnExpr); - setState(1011); + setState(1019); if (!(precpred(_ctx, 25))) throw FailedPredicateException(this, "precpred(_ctx, 25)"); - setState(1012); + setState(1020); match(HogQLParser::DOT); - setState(1013); + setState(1021); match(HogQLParser::DECIMAL_LITERAL); break; } @@ -8733,12 +8820,12 @@ HogQLParser::ColumnExprContext* HogQLParser::columnExpr(int precedence) { auto newContext = _tracker.createInstance(_tracker.createInstance(parentContext, parentState)); _localctx = newContext; pushNewRecursionContext(newContext, startState, RuleColumnExpr); - setState(1014); + setState(1022); if (!(precpred(_ctx, 24))) throw FailedPredicateException(this, "precpred(_ctx, 24)"); - setState(1015); + setState(1023); match(HogQLParser::DOT); - setState(1016); + setState(1024); identifier(); break; } @@ -8747,16 +8834,16 @@ HogQLParser::ColumnExprContext* HogQLParser::columnExpr(int precedence) { auto newContext = _tracker.createInstance(_tracker.createInstance(parentContext, parentState)); _localctx = newContext; pushNewRecursionContext(newContext, startState, RuleColumnExpr); - setState(1017); + setState(1025); if (!(precpred(_ctx, 23))) throw FailedPredicateException(this, "precpred(_ctx, 23)"); - setState(1018); + setState(1026); match(HogQLParser::NULL_PROPERTY); - setState(1019); + setState(1027); match(HogQLParser::LBRACKET); - setState(1020); + setState(1028); columnExpr(0); - setState(1021); + setState(1029); match(HogQLParser::RBRACKET); break; } @@ -8765,12 +8852,12 @@ HogQLParser::ColumnExprContext* HogQLParser::columnExpr(int precedence) { auto newContext = _tracker.createInstance(_tracker.createInstance(parentContext, parentState)); _localctx = newContext; pushNewRecursionContext(newContext, startState, RuleColumnExpr); - setState(1023); + setState(1031); if (!(precpred(_ctx, 22))) throw FailedPredicateException(this, "precpred(_ctx, 22)"); - setState(1024); + setState(1032); match(HogQLParser::NULL_PROPERTY); - setState(1025); + setState(1033); match(HogQLParser::DECIMAL_LITERAL); break; } @@ -8779,12 +8866,12 @@ HogQLParser::ColumnExprContext* HogQLParser::columnExpr(int precedence) { auto newContext = _tracker.createInstance(_tracker.createInstance(parentContext, parentState)); _localctx = newContext; pushNewRecursionContext(newContext, startState, RuleColumnExpr); - setState(1026); + setState(1034); if (!(precpred(_ctx, 21))) throw FailedPredicateException(this, "precpred(_ctx, 21)"); - setState(1027); + setState(1035); match(HogQLParser::NULL_PROPERTY); - setState(1028); + setState(1036); identifier(); break; } @@ -8793,20 +8880,20 @@ HogQLParser::ColumnExprContext* HogQLParser::columnExpr(int precedence) { auto newContext = _tracker.createInstance(_tracker.createInstance(parentContext, parentState)); _localctx = newContext; pushNewRecursionContext(newContext, startState, RuleColumnExpr); - setState(1029); + setState(1037); if (!(precpred(_ctx, 16))) throw FailedPredicateException(this, "precpred(_ctx, 16)"); - setState(1030); + setState(1038); match(HogQLParser::IS); - setState(1032); + setState(1040); _errHandler->sync(this); _la = _input->LA(1); if (_la == HogQLParser::NOT) { - setState(1031); + setState(1039); match(HogQLParser::NOT); } - setState(1034); + setState(1042); match(HogQLParser::NULL_SQL); break; } @@ -8815,24 +8902,24 @@ HogQLParser::ColumnExprContext* HogQLParser::columnExpr(int precedence) { auto newContext = _tracker.createInstance(_tracker.createInstance(parentContext, parentState)); _localctx = newContext; pushNewRecursionContext(newContext, startState, RuleColumnExpr); - setState(1035); + setState(1043); if (!(precpred(_ctx, 9))) throw FailedPredicateException(this, "precpred(_ctx, 9)"); - setState(1040); + setState(1048); _errHandler->sync(this); - switch (getInterpreter()->adaptivePredict(_input, 128, _ctx)) { + switch (getInterpreter()->adaptivePredict(_input, 129, _ctx)) { case 1: { - setState(1036); + setState(1044); match(HogQLParser::AS); - setState(1037); + setState(1045); identifier(); break; } case 2: { - setState(1038); + setState(1046); match(HogQLParser::AS); - setState(1039); + setState(1047); match(HogQLParser::STRING_LITERAL); break; } @@ -8847,9 +8934,9 @@ HogQLParser::ColumnExprContext* HogQLParser::columnExpr(int precedence) { break; } } - setState(1046); + setState(1054); _errHandler->sync(this); - alt = getInterpreter()->adaptivePredict(_input, 130, _ctx); + alt = getInterpreter()->adaptivePredict(_input, 131, _ctx); } } catch (RecognitionException &e) { @@ -8917,7 +9004,7 @@ std::any HogQLParser::ColumnLambdaExprContext::accept(tree::ParseTreeVisitor *vi HogQLParser::ColumnLambdaExprContext* HogQLParser::columnLambdaExpr() { ColumnLambdaExprContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 118, HogQLParser::RuleColumnLambdaExpr); + enterRule(_localctx, 120, HogQLParser::RuleColumnLambdaExpr); size_t _la = 0; #if __cplusplus > 201703L @@ -8930,73 +9017,73 @@ HogQLParser::ColumnLambdaExprContext* HogQLParser::columnLambdaExpr() { try { size_t alt; enterOuterAlt(_localctx, 1); - setState(1074); + setState(1082); _errHandler->sync(this); - switch (getInterpreter()->adaptivePredict(_input, 135, _ctx)) { + switch (getInterpreter()->adaptivePredict(_input, 136, _ctx)) { case 1: { - setState(1047); + setState(1055); match(HogQLParser::LPAREN); - setState(1048); + setState(1056); identifier(); - setState(1053); + setState(1061); _errHandler->sync(this); - alt = getInterpreter()->adaptivePredict(_input, 131, _ctx); + alt = getInterpreter()->adaptivePredict(_input, 132, _ctx); while (alt != 2 && alt != atn::ATN::INVALID_ALT_NUMBER) { if (alt == 1) { - setState(1049); + setState(1057); match(HogQLParser::COMMA); - setState(1050); + setState(1058); identifier(); } - setState(1055); + setState(1063); _errHandler->sync(this); - alt = getInterpreter()->adaptivePredict(_input, 131, _ctx); + alt = getInterpreter()->adaptivePredict(_input, 132, _ctx); } - setState(1057); + setState(1065); _errHandler->sync(this); _la = _input->LA(1); if (_la == HogQLParser::COMMA) { - setState(1056); + setState(1064); match(HogQLParser::COMMA); } - setState(1059); + setState(1067); match(HogQLParser::RPAREN); break; } case 2: { - setState(1061); + setState(1069); identifier(); - setState(1066); + setState(1074); _errHandler->sync(this); - alt = getInterpreter()->adaptivePredict(_input, 133, _ctx); + alt = getInterpreter()->adaptivePredict(_input, 134, _ctx); while (alt != 2 && alt != atn::ATN::INVALID_ALT_NUMBER) { if (alt == 1) { - setState(1062); + setState(1070); match(HogQLParser::COMMA); - setState(1063); + setState(1071); identifier(); } - setState(1068); + setState(1076); _errHandler->sync(this); - alt = getInterpreter()->adaptivePredict(_input, 133, _ctx); + alt = getInterpreter()->adaptivePredict(_input, 134, _ctx); } - setState(1070); + setState(1078); _errHandler->sync(this); _la = _input->LA(1); if (_la == HogQLParser::COMMA) { - setState(1069); + setState(1077); match(HogQLParser::COMMA); } break; } case 3: { - setState(1072); + setState(1080); match(HogQLParser::LPAREN); - setState(1073); + setState(1081); match(HogQLParser::RPAREN); break; } @@ -9004,19 +9091,19 @@ HogQLParser::ColumnLambdaExprContext* HogQLParser::columnLambdaExpr() { default: break; } - setState(1076); + setState(1084); match(HogQLParser::ARROW); - setState(1079); + setState(1087); _errHandler->sync(this); - switch (getInterpreter()->adaptivePredict(_input, 136, _ctx)) { + switch (getInterpreter()->adaptivePredict(_input, 137, _ctx)) { case 1: { - setState(1077); + setState(1085); columnExpr(0); break; } case 2: { - setState(1078); + setState(1086); block(); break; } @@ -9150,7 +9237,7 @@ std::any HogQLParser::HogqlxTagElementNestedContext::accept(tree::ParseTreeVisit } HogQLParser::HogqlxTagElementContext* HogQLParser::hogqlxTagElement() { HogqlxTagElementContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 120, HogQLParser::RuleHogqlxTagElement); + enterRule(_localctx, 122, HogQLParser::RuleHogqlxTagElement); size_t _la = 0; #if __cplusplus > 201703L @@ -9161,31 +9248,31 @@ HogQLParser::HogqlxTagElementContext* HogQLParser::hogqlxTagElement() { exitRule(); }); try { - setState(1113); + setState(1121); _errHandler->sync(this); - switch (getInterpreter()->adaptivePredict(_input, 140, _ctx)) { + switch (getInterpreter()->adaptivePredict(_input, 141, _ctx)) { case 1: { _localctx = _tracker.createInstance(_localctx); enterOuterAlt(_localctx, 1); - setState(1081); + setState(1089); match(HogQLParser::LT); - setState(1082); + setState(1090); identifier(); - setState(1086); + setState(1094); _errHandler->sync(this); _la = _input->LA(1); while ((((_la & ~ 0x3fULL) == 0) && - ((1ULL << _la) & -1450176743603191810) != 0) || ((((_la - 64) & ~ 0x3fULL) == 0) && - ((1ULL << (_la - 64)) & 6458554974207) != 0)) { - setState(1083); + ((1ULL << _la) & -5800812384855539714) != 0) || ((((_la - 64) & ~ 0x3fULL) == 0) && + ((1ULL << (_la - 64)) & 25834219896831) != 0)) { + setState(1091); hogqlxTagAttribute(); - setState(1088); + setState(1096); _errHandler->sync(this); _la = _input->LA(1); } - setState(1089); + setState(1097); match(HogQLParser::SLASH); - setState(1090); + setState(1098); match(HogQLParser::GT); break; } @@ -9193,40 +9280,40 @@ HogQLParser::HogqlxTagElementContext* HogQLParser::hogqlxTagElement() { case 2: { _localctx = _tracker.createInstance(_localctx); enterOuterAlt(_localctx, 2); - setState(1092); + setState(1100); match(HogQLParser::LT); - setState(1093); + setState(1101); identifier(); - setState(1097); + setState(1105); _errHandler->sync(this); _la = _input->LA(1); while ((((_la & ~ 0x3fULL) == 0) && - ((1ULL << _la) & -1450176743603191810) != 0) || ((((_la - 64) & ~ 0x3fULL) == 0) && - ((1ULL << (_la - 64)) & 6458554974207) != 0)) { - setState(1094); + ((1ULL << _la) & -5800812384855539714) != 0) || ((((_la - 64) & ~ 0x3fULL) == 0) && + ((1ULL << (_la - 64)) & 25834219896831) != 0)) { + setState(1102); hogqlxTagAttribute(); - setState(1099); + setState(1107); _errHandler->sync(this); _la = _input->LA(1); } - setState(1100); + setState(1108); match(HogQLParser::GT); - setState(1106); + setState(1114); _errHandler->sync(this); - switch (getInterpreter()->adaptivePredict(_input, 139, _ctx)) { + switch (getInterpreter()->adaptivePredict(_input, 140, _ctx)) { case 1: { - setState(1101); + setState(1109); hogqlxTagElement(); break; } case 2: { - setState(1102); + setState(1110); match(HogQLParser::LBRACE); - setState(1103); + setState(1111); columnExpr(0); - setState(1104); + setState(1112); match(HogQLParser::RBRACE); break; } @@ -9234,13 +9321,13 @@ HogQLParser::HogqlxTagElementContext* HogQLParser::hogqlxTagElement() { default: break; } - setState(1108); + setState(1116); match(HogQLParser::LT); - setState(1109); + setState(1117); match(HogQLParser::SLASH); - setState(1110); + setState(1118); identifier(); - setState(1111); + setState(1119); match(HogQLParser::GT); break; } @@ -9304,7 +9391,7 @@ std::any HogQLParser::HogqlxTagAttributeContext::accept(tree::ParseTreeVisitor * HogQLParser::HogqlxTagAttributeContext* HogQLParser::hogqlxTagAttribute() { HogqlxTagAttributeContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 122, HogQLParser::RuleHogqlxTagAttribute); + enterRule(_localctx, 124, HogQLParser::RuleHogqlxTagAttribute); #if __cplusplus > 201703L auto onExit = finally([=, this] { @@ -9314,38 +9401,38 @@ HogQLParser::HogqlxTagAttributeContext* HogQLParser::hogqlxTagAttribute() { exitRule(); }); try { - setState(1126); + setState(1134); _errHandler->sync(this); - switch (getInterpreter()->adaptivePredict(_input, 141, _ctx)) { + switch (getInterpreter()->adaptivePredict(_input, 142, _ctx)) { case 1: { enterOuterAlt(_localctx, 1); - setState(1115); + setState(1123); identifier(); - setState(1116); + setState(1124); match(HogQLParser::EQ_SINGLE); - setState(1117); + setState(1125); string(); break; } case 2: { enterOuterAlt(_localctx, 2); - setState(1119); + setState(1127); identifier(); - setState(1120); + setState(1128); match(HogQLParser::EQ_SINGLE); - setState(1121); + setState(1129); match(HogQLParser::LBRACE); - setState(1122); + setState(1130); columnExpr(0); - setState(1123); + setState(1131); match(HogQLParser::RBRACE); break; } case 3: { enterOuterAlt(_localctx, 3); - setState(1125); + setState(1133); identifier(); break; } @@ -9401,7 +9488,7 @@ std::any HogQLParser::WithExprListContext::accept(tree::ParseTreeVisitor *visito HogQLParser::WithExprListContext* HogQLParser::withExprList() { WithExprListContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 124, HogQLParser::RuleWithExprList); + enterRule(_localctx, 126, HogQLParser::RuleWithExprList); size_t _la = 0; #if __cplusplus > 201703L @@ -9414,28 +9501,28 @@ HogQLParser::WithExprListContext* HogQLParser::withExprList() { try { size_t alt; enterOuterAlt(_localctx, 1); - setState(1128); + setState(1136); withExpr(); - setState(1133); + setState(1141); _errHandler->sync(this); - alt = getInterpreter()->adaptivePredict(_input, 142, _ctx); + alt = getInterpreter()->adaptivePredict(_input, 143, _ctx); while (alt != 2 && alt != atn::ATN::INVALID_ALT_NUMBER) { if (alt == 1) { - setState(1129); + setState(1137); match(HogQLParser::COMMA); - setState(1130); + setState(1138); withExpr(); } - setState(1135); + setState(1143); _errHandler->sync(this); - alt = getInterpreter()->adaptivePredict(_input, 142, _ctx); + alt = getInterpreter()->adaptivePredict(_input, 143, _ctx); } - setState(1137); + setState(1145); _errHandler->sync(this); _la = _input->LA(1); if (_la == HogQLParser::COMMA) { - setState(1136); + setState(1144); match(HogQLParser::COMMA); } @@ -9501,8 +9588,8 @@ tree::TerminalNode* HogQLParser::WithExprSubqueryContext::LPAREN() { return getToken(HogQLParser::LPAREN, 0); } -HogQLParser::SelectUnionStmtContext* HogQLParser::WithExprSubqueryContext::selectUnionStmt() { - return getRuleContext(0); +HogQLParser::SelectSetStmtContext* HogQLParser::WithExprSubqueryContext::selectSetStmt() { + return getRuleContext(0); } tree::TerminalNode* HogQLParser::WithExprSubqueryContext::RPAREN() { @@ -9520,7 +9607,7 @@ std::any HogQLParser::WithExprSubqueryContext::accept(tree::ParseTreeVisitor *vi } HogQLParser::WithExprContext* HogQLParser::withExpr() { WithExprContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 126, HogQLParser::RuleWithExpr); + enterRule(_localctx, 128, HogQLParser::RuleWithExpr); #if __cplusplus > 201703L auto onExit = finally([=, this] { @@ -9530,21 +9617,21 @@ HogQLParser::WithExprContext* HogQLParser::withExpr() { exitRule(); }); try { - setState(1149); + setState(1157); _errHandler->sync(this); - switch (getInterpreter()->adaptivePredict(_input, 144, _ctx)) { + switch (getInterpreter()->adaptivePredict(_input, 145, _ctx)) { case 1: { _localctx = _tracker.createInstance(_localctx); enterOuterAlt(_localctx, 1); - setState(1139); + setState(1147); identifier(); - setState(1140); + setState(1148); match(HogQLParser::AS); - setState(1141); + setState(1149); match(HogQLParser::LPAREN); - setState(1142); - selectUnionStmt(); - setState(1143); + setState(1150); + selectSetStmt(); + setState(1151); match(HogQLParser::RPAREN); break; } @@ -9552,11 +9639,11 @@ HogQLParser::WithExprContext* HogQLParser::withExpr() { case 2: { _localctx = _tracker.createInstance(_localctx); enterOuterAlt(_localctx, 2); - setState(1145); + setState(1153); columnExpr(0); - setState(1146); + setState(1154); match(HogQLParser::AS); - setState(1147); + setState(1155); identifier(); break; } @@ -9612,7 +9699,7 @@ std::any HogQLParser::ColumnIdentifierContext::accept(tree::ParseTreeVisitor *vi HogQLParser::ColumnIdentifierContext* HogQLParser::columnIdentifier() { ColumnIdentifierContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 128, HogQLParser::RuleColumnIdentifier); + enterRule(_localctx, 130, HogQLParser::RuleColumnIdentifier); #if __cplusplus > 201703L auto onExit = finally([=, this] { @@ -9622,12 +9709,12 @@ HogQLParser::ColumnIdentifierContext* HogQLParser::columnIdentifier() { exitRule(); }); try { - setState(1158); + setState(1166); _errHandler->sync(this); switch (_input->LA(1)) { case HogQLParser::LBRACE: { enterOuterAlt(_localctx, 1); - setState(1151); + setState(1159); placeholder(); break; } @@ -9727,14 +9814,14 @@ HogQLParser::ColumnIdentifierContext* HogQLParser::columnIdentifier() { case HogQLParser::YEAR: case HogQLParser::IDENTIFIER: { enterOuterAlt(_localctx, 2); - setState(1155); + setState(1163); _errHandler->sync(this); - switch (getInterpreter()->adaptivePredict(_input, 145, _ctx)) { + switch (getInterpreter()->adaptivePredict(_input, 146, _ctx)) { case 1: { - setState(1152); + setState(1160); tableIdentifier(); - setState(1153); + setState(1161); match(HogQLParser::DOT); break; } @@ -9742,7 +9829,7 @@ HogQLParser::ColumnIdentifierContext* HogQLParser::columnIdentifier() { default: break; } - setState(1157); + setState(1165); nestedIdentifier(); break; } @@ -9798,7 +9885,7 @@ std::any HogQLParser::NestedIdentifierContext::accept(tree::ParseTreeVisitor *vi HogQLParser::NestedIdentifierContext* HogQLParser::nestedIdentifier() { NestedIdentifierContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 130, HogQLParser::RuleNestedIdentifier); + enterRule(_localctx, 132, HogQLParser::RuleNestedIdentifier); #if __cplusplus > 201703L auto onExit = finally([=, this] { @@ -9810,21 +9897,21 @@ HogQLParser::NestedIdentifierContext* HogQLParser::nestedIdentifier() { try { size_t alt; enterOuterAlt(_localctx, 1); - setState(1160); + setState(1168); identifier(); - setState(1165); + setState(1173); _errHandler->sync(this); - alt = getInterpreter()->adaptivePredict(_input, 147, _ctx); + alt = getInterpreter()->adaptivePredict(_input, 148, _ctx); while (alt != 2 && alt != atn::ATN::INVALID_ALT_NUMBER) { if (alt == 1) { - setState(1161); + setState(1169); match(HogQLParser::DOT); - setState(1162); + setState(1170); identifier(); } - setState(1167); + setState(1175); _errHandler->sync(this); - alt = getInterpreter()->adaptivePredict(_input, 147, _ctx); + alt = getInterpreter()->adaptivePredict(_input, 148, _ctx); } } @@ -9903,8 +9990,8 @@ tree::TerminalNode* HogQLParser::TableExprSubqueryContext::LPAREN() { return getToken(HogQLParser::LPAREN, 0); } -HogQLParser::SelectUnionStmtContext* HogQLParser::TableExprSubqueryContext::selectUnionStmt() { - return getRuleContext(0); +HogQLParser::SelectSetStmtContext* HogQLParser::TableExprSubqueryContext::selectSetStmt() { + return getRuleContext(0); } tree::TerminalNode* HogQLParser::TableExprSubqueryContext::RPAREN() { @@ -9973,8 +10060,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 = 132; - enterRecursionRule(_localctx, 132, HogQLParser::RuleTableExpr, precedence); + size_t startState = 134; + enterRecursionRule(_localctx, 134, HogQLParser::RuleTableExpr, precedence); @@ -9988,15 +10075,15 @@ HogQLParser::TableExprContext* HogQLParser::tableExpr(int precedence) { try { size_t alt; enterOuterAlt(_localctx, 1); - setState(1177); + setState(1185); _errHandler->sync(this); - switch (getInterpreter()->adaptivePredict(_input, 148, _ctx)) { + switch (getInterpreter()->adaptivePredict(_input, 149, _ctx)) { case 1: { _localctx = _tracker.createInstance(_localctx); _ctx = _localctx; previousContext = _localctx; - setState(1169); + setState(1177); tableIdentifier(); break; } @@ -10005,7 +10092,7 @@ HogQLParser::TableExprContext* HogQLParser::tableExpr(int precedence) { _localctx = _tracker.createInstance(_localctx); _ctx = _localctx; previousContext = _localctx; - setState(1170); + setState(1178); tableFunctionExpr(); break; } @@ -10014,11 +10101,11 @@ HogQLParser::TableExprContext* HogQLParser::tableExpr(int precedence) { _localctx = _tracker.createInstance(_localctx); _ctx = _localctx; previousContext = _localctx; - setState(1171); + setState(1179); match(HogQLParser::LPAREN); - setState(1172); - selectUnionStmt(); - setState(1173); + setState(1180); + selectSetStmt(); + setState(1181); match(HogQLParser::RPAREN); break; } @@ -10027,7 +10114,7 @@ HogQLParser::TableExprContext* HogQLParser::tableExpr(int precedence) { _localctx = _tracker.createInstance(_localctx); _ctx = _localctx; previousContext = _localctx; - setState(1175); + setState(1183); hogqlxTagElement(); break; } @@ -10036,7 +10123,7 @@ HogQLParser::TableExprContext* HogQLParser::tableExpr(int precedence) { _localctx = _tracker.createInstance(_localctx); _ctx = _localctx; previousContext = _localctx; - setState(1176); + setState(1184); placeholder(); break; } @@ -10045,9 +10132,9 @@ HogQLParser::TableExprContext* HogQLParser::tableExpr(int precedence) { break; } _ctx->stop = _input->LT(-1); - setState(1187); + setState(1195); _errHandler->sync(this); - alt = getInterpreter()->adaptivePredict(_input, 150, _ctx); + alt = getInterpreter()->adaptivePredict(_input, 151, _ctx); while (alt != 2 && alt != atn::ATN::INVALID_ALT_NUMBER) { if (alt == 1) { if (!_parseListeners.empty()) @@ -10056,10 +10143,10 @@ HogQLParser::TableExprContext* HogQLParser::tableExpr(int precedence) { auto newContext = _tracker.createInstance(_tracker.createInstance(parentContext, parentState)); _localctx = newContext; pushNewRecursionContext(newContext, startState, RuleTableExpr); - setState(1179); + setState(1187); if (!(precpred(_ctx, 3))) throw FailedPredicateException(this, "precpred(_ctx, 3)"); - setState(1183); + setState(1191); _errHandler->sync(this); switch (_input->LA(1)) { case HogQLParser::DATE: @@ -10067,15 +10154,15 @@ HogQLParser::TableExprContext* HogQLParser::tableExpr(int precedence) { case HogQLParser::ID: case HogQLParser::KEY: case HogQLParser::IDENTIFIER: { - setState(1180); + setState(1188); alias(); break; } case HogQLParser::AS: { - setState(1181); + setState(1189); match(HogQLParser::AS); - setState(1182); + setState(1190); identifier(); break; } @@ -10084,9 +10171,9 @@ HogQLParser::TableExprContext* HogQLParser::tableExpr(int precedence) { throw NoViableAltException(this); } } - setState(1189); + setState(1197); _errHandler->sync(this); - alt = getInterpreter()->adaptivePredict(_input, 150, _ctx); + alt = getInterpreter()->adaptivePredict(_input, 151, _ctx); } } catch (RecognitionException &e) { @@ -10134,7 +10221,7 @@ std::any HogQLParser::TableFunctionExprContext::accept(tree::ParseTreeVisitor *v HogQLParser::TableFunctionExprContext* HogQLParser::tableFunctionExpr() { TableFunctionExprContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 134, HogQLParser::RuleTableFunctionExpr); + enterRule(_localctx, 136, HogQLParser::RuleTableFunctionExpr); size_t _la = 0; #if __cplusplus > 201703L @@ -10146,22 +10233,22 @@ HogQLParser::TableFunctionExprContext* HogQLParser::tableFunctionExpr() { }); try { enterOuterAlt(_localctx, 1); - setState(1190); + setState(1198); identifier(); - setState(1191); + setState(1199); match(HogQLParser::LPAREN); - setState(1193); + setState(1201); _errHandler->sync(this); _la = _input->LA(1); if ((((_la & ~ 0x3fULL) == 0) && - ((1ULL << _la) & -9007270658588674) != 0) || ((((_la - 64) & ~ 0x3fULL) == 0) && - ((1ULL << (_la - 64)) & 180986072486903807) != 0) || ((((_la - 129) & ~ 0x3fULL) == 0) && - ((1ULL << (_la - 129)) & 18455) != 0)) { - setState(1192); + ((1ULL << _la) & -36169677449216002) != 0) || ((((_la - 64) & ~ 0x3fULL) == 0) && + ((1ULL << (_la - 64)) & 723944289947615231) != 0) || ((((_la - 131) & ~ 0x3fULL) == 0) && + ((1ULL << (_la - 131)) & 18455) != 0)) { + setState(1200); tableArgList(); } - setState(1195); + setState(1203); match(HogQLParser::RPAREN); } @@ -10207,7 +10294,7 @@ std::any HogQLParser::TableIdentifierContext::accept(tree::ParseTreeVisitor *vis HogQLParser::TableIdentifierContext* HogQLParser::tableIdentifier() { TableIdentifierContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 136, HogQLParser::RuleTableIdentifier); + enterRule(_localctx, 138, HogQLParser::RuleTableIdentifier); #if __cplusplus > 201703L auto onExit = finally([=, this] { @@ -10218,14 +10305,14 @@ HogQLParser::TableIdentifierContext* HogQLParser::tableIdentifier() { }); try { enterOuterAlt(_localctx, 1); - setState(1200); + setState(1208); _errHandler->sync(this); - switch (getInterpreter()->adaptivePredict(_input, 152, _ctx)) { + switch (getInterpreter()->adaptivePredict(_input, 153, _ctx)) { case 1: { - setState(1197); + setState(1205); databaseIdentifier(); - setState(1198); + setState(1206); match(HogQLParser::DOT); break; } @@ -10233,7 +10320,7 @@ HogQLParser::TableIdentifierContext* HogQLParser::tableIdentifier() { default: break; } - setState(1202); + setState(1210); identifier(); } @@ -10283,7 +10370,7 @@ std::any HogQLParser::TableArgListContext::accept(tree::ParseTreeVisitor *visito HogQLParser::TableArgListContext* HogQLParser::tableArgList() { TableArgListContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 138, HogQLParser::RuleTableArgList); + enterRule(_localctx, 140, HogQLParser::RuleTableArgList); size_t _la = 0; #if __cplusplus > 201703L @@ -10296,28 +10383,28 @@ HogQLParser::TableArgListContext* HogQLParser::tableArgList() { try { size_t alt; enterOuterAlt(_localctx, 1); - setState(1204); + setState(1212); columnExpr(0); - setState(1209); + setState(1217); _errHandler->sync(this); - alt = getInterpreter()->adaptivePredict(_input, 153, _ctx); + alt = getInterpreter()->adaptivePredict(_input, 154, _ctx); while (alt != 2 && alt != atn::ATN::INVALID_ALT_NUMBER) { if (alt == 1) { - setState(1205); + setState(1213); match(HogQLParser::COMMA); - setState(1206); + setState(1214); columnExpr(0); } - setState(1211); + setState(1219); _errHandler->sync(this); - alt = getInterpreter()->adaptivePredict(_input, 153, _ctx); + alt = getInterpreter()->adaptivePredict(_input, 154, _ctx); } - setState(1213); + setState(1221); _errHandler->sync(this); _la = _input->LA(1); if (_la == HogQLParser::COMMA) { - setState(1212); + setState(1220); match(HogQLParser::COMMA); } @@ -10356,7 +10443,7 @@ std::any HogQLParser::DatabaseIdentifierContext::accept(tree::ParseTreeVisitor * HogQLParser::DatabaseIdentifierContext* HogQLParser::databaseIdentifier() { DatabaseIdentifierContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 140, HogQLParser::RuleDatabaseIdentifier); + enterRule(_localctx, 142, HogQLParser::RuleDatabaseIdentifier); #if __cplusplus > 201703L auto onExit = finally([=, this] { @@ -10367,7 +10454,7 @@ HogQLParser::DatabaseIdentifierContext* HogQLParser::databaseIdentifier() { }); try { enterOuterAlt(_localctx, 1); - setState(1215); + setState(1223); identifier(); } @@ -10421,7 +10508,7 @@ std::any HogQLParser::FloatingLiteralContext::accept(tree::ParseTreeVisitor *vis HogQLParser::FloatingLiteralContext* HogQLParser::floatingLiteral() { FloatingLiteralContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 142, HogQLParser::RuleFloatingLiteral); + enterRule(_localctx, 144, HogQLParser::RuleFloatingLiteral); size_t _la = 0; #if __cplusplus > 201703L @@ -10432,21 +10519,21 @@ HogQLParser::FloatingLiteralContext* HogQLParser::floatingLiteral() { exitRule(); }); try { - setState(1225); + setState(1233); _errHandler->sync(this); switch (_input->LA(1)) { case HogQLParser::FLOATING_LITERAL: { enterOuterAlt(_localctx, 1); - setState(1217); + setState(1225); match(HogQLParser::FLOATING_LITERAL); break; } case HogQLParser::DOT: { enterOuterAlt(_localctx, 2); - setState(1218); + setState(1226); match(HogQLParser::DOT); - setState(1219); + setState(1227); _la = _input->LA(1); if (!(_la == HogQLParser::OCTAL_LITERAL @@ -10462,16 +10549,16 @@ HogQLParser::FloatingLiteralContext* HogQLParser::floatingLiteral() { case HogQLParser::DECIMAL_LITERAL: { enterOuterAlt(_localctx, 3); - setState(1220); + setState(1228); match(HogQLParser::DECIMAL_LITERAL); - setState(1221); + setState(1229); match(HogQLParser::DOT); - setState(1223); + setState(1231); _errHandler->sync(this); - switch (getInterpreter()->adaptivePredict(_input, 155, _ctx)) { + switch (getInterpreter()->adaptivePredict(_input, 156, _ctx)) { case 1: { - setState(1222); + setState(1230); _la = _input->LA(1); if (!(_la == HogQLParser::OCTAL_LITERAL @@ -10558,7 +10645,7 @@ std::any HogQLParser::NumberLiteralContext::accept(tree::ParseTreeVisitor *visit HogQLParser::NumberLiteralContext* HogQLParser::numberLiteral() { NumberLiteralContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 144, HogQLParser::RuleNumberLiteral); + enterRule(_localctx, 146, HogQLParser::RuleNumberLiteral); size_t _la = 0; #if __cplusplus > 201703L @@ -10570,14 +10657,14 @@ HogQLParser::NumberLiteralContext* HogQLParser::numberLiteral() { }); try { enterOuterAlt(_localctx, 1); - setState(1228); + setState(1236); _errHandler->sync(this); _la = _input->LA(1); if (_la == HogQLParser::DASH || _la == HogQLParser::PLUS) { - setState(1227); + setState(1235); _la = _input->LA(1); if (!(_la == HogQLParser::DASH @@ -10589,41 +10676,41 @@ HogQLParser::NumberLiteralContext* HogQLParser::numberLiteral() { consume(); } } - setState(1236); + setState(1244); _errHandler->sync(this); - switch (getInterpreter()->adaptivePredict(_input, 158, _ctx)) { + switch (getInterpreter()->adaptivePredict(_input, 159, _ctx)) { case 1: { - setState(1230); + setState(1238); floatingLiteral(); break; } case 2: { - setState(1231); + setState(1239); match(HogQLParser::OCTAL_LITERAL); break; } case 3: { - setState(1232); + setState(1240); match(HogQLParser::DECIMAL_LITERAL); break; } case 4: { - setState(1233); + setState(1241); match(HogQLParser::HEXADECIMAL_LITERAL); break; } case 5: { - setState(1234); + setState(1242); match(HogQLParser::INF); break; } case 6: { - setState(1235); + setState(1243); match(HogQLParser::NAN_SQL); break; } @@ -10675,7 +10762,7 @@ std::any HogQLParser::LiteralContext::accept(tree::ParseTreeVisitor *visitor) { HogQLParser::LiteralContext* HogQLParser::literal() { LiteralContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 146, HogQLParser::RuleLiteral); + enterRule(_localctx, 148, HogQLParser::RuleLiteral); #if __cplusplus > 201703L auto onExit = finally([=, this] { @@ -10685,7 +10772,7 @@ HogQLParser::LiteralContext* HogQLParser::literal() { exitRule(); }); try { - setState(1241); + setState(1249); _errHandler->sync(this); switch (_input->LA(1)) { case HogQLParser::INF: @@ -10698,21 +10785,21 @@ HogQLParser::LiteralContext* HogQLParser::literal() { case HogQLParser::DOT: case HogQLParser::PLUS: { enterOuterAlt(_localctx, 1); - setState(1238); + setState(1246); numberLiteral(); break; } case HogQLParser::STRING_LITERAL: { enterOuterAlt(_localctx, 2); - setState(1239); + setState(1247); match(HogQLParser::STRING_LITERAL); break; } case HogQLParser::NULL_SQL: { enterOuterAlt(_localctx, 3); - setState(1240); + setState(1248); match(HogQLParser::NULL_SQL); break; } @@ -10784,7 +10871,7 @@ std::any HogQLParser::IntervalContext::accept(tree::ParseTreeVisitor *visitor) { HogQLParser::IntervalContext* HogQLParser::interval() { IntervalContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 148, HogQLParser::RuleInterval); + enterRule(_localctx, 150, HogQLParser::RuleInterval); size_t _la = 0; #if __cplusplus > 201703L @@ -10796,11 +10883,11 @@ HogQLParser::IntervalContext* HogQLParser::interval() { }); try { enterOuterAlt(_localctx, 1); - setState(1243); + setState(1251); _la = _input->LA(1); if (!((((_la & ~ 0x3fULL) == 0) && - ((1ULL << _la) & 216173331871694848) != 0) || ((((_la - 71) & ~ 0x3fULL) == 0) && - ((1ULL << (_la - 71)) & 8724152577) != 0))) { + ((1ULL << _la) & 864692227968860160) != 0) || ((((_la - 73) & ~ 0x3fULL) == 0) && + ((1ULL << (_la - 73)) & 8724152577) != 0))) { _errHandler->recoverInline(this); } else { @@ -11179,7 +11266,7 @@ std::any HogQLParser::KeywordContext::accept(tree::ParseTreeVisitor *visitor) { HogQLParser::KeywordContext* HogQLParser::keyword() { KeywordContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 150, HogQLParser::RuleKeyword); + enterRule(_localctx, 152, HogQLParser::RuleKeyword); size_t _la = 0; #if __cplusplus > 201703L @@ -11191,11 +11278,11 @@ HogQLParser::KeywordContext* HogQLParser::keyword() { }); try { enterOuterAlt(_localctx, 1); - setState(1245); + setState(1253); _la = _input->LA(1); if (!((((_la & ~ 0x3fULL) == 0) && - ((1ULL << _la) & -1666350075474886658) != 0) || ((((_la - 64) & ~ 0x3fULL) == 0) && - ((1ULL << (_la - 64)) & 943816933247) != 0))) { + ((1ULL << _la) & -6665504612824399874) != 0) || ((((_la - 64) & ~ 0x3fULL) == 0) && + ((1ULL << (_la - 64)) & 3775267732991) != 0))) { _errHandler->recoverInline(this); } else { @@ -11250,7 +11337,7 @@ std::any HogQLParser::KeywordForAliasContext::accept(tree::ParseTreeVisitor *vis HogQLParser::KeywordForAliasContext* HogQLParser::keywordForAlias() { KeywordForAliasContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 152, HogQLParser::RuleKeywordForAlias); + enterRule(_localctx, 154, HogQLParser::RuleKeywordForAlias); size_t _la = 0; #if __cplusplus > 201703L @@ -11262,10 +11349,10 @@ HogQLParser::KeywordForAliasContext* HogQLParser::keywordForAlias() { }); try { enterOuterAlt(_localctx, 1); - setState(1247); + setState(1255); _la = _input->LA(1); if (!((((_la & ~ 0x3fULL) == 0) && - ((1ULL << _la) & 564050539839488) != 0))) { + ((1ULL << _la) & 2254000985473024) != 0))) { _errHandler->recoverInline(this); } else { @@ -11312,7 +11399,7 @@ std::any HogQLParser::AliasContext::accept(tree::ParseTreeVisitor *visitor) { HogQLParser::AliasContext* HogQLParser::alias() { AliasContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 154, HogQLParser::RuleAlias); + enterRule(_localctx, 156, HogQLParser::RuleAlias); #if __cplusplus > 201703L auto onExit = finally([=, this] { @@ -11322,12 +11409,12 @@ HogQLParser::AliasContext* HogQLParser::alias() { exitRule(); }); try { - setState(1251); + setState(1259); _errHandler->sync(this); switch (_input->LA(1)) { case HogQLParser::IDENTIFIER: { enterOuterAlt(_localctx, 1); - setState(1249); + setState(1257); match(HogQLParser::IDENTIFIER); break; } @@ -11337,7 +11424,7 @@ HogQLParser::AliasContext* HogQLParser::alias() { case HogQLParser::ID: case HogQLParser::KEY: { enterOuterAlt(_localctx, 2); - setState(1250); + setState(1258); keywordForAlias(); break; } @@ -11389,7 +11476,7 @@ std::any HogQLParser::IdentifierContext::accept(tree::ParseTreeVisitor *visitor) HogQLParser::IdentifierContext* HogQLParser::identifier() { IdentifierContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 156, HogQLParser::RuleIdentifier); + enterRule(_localctx, 158, HogQLParser::RuleIdentifier); #if __cplusplus > 201703L auto onExit = finally([=, this] { @@ -11399,12 +11486,12 @@ HogQLParser::IdentifierContext* HogQLParser::identifier() { exitRule(); }); try { - setState(1256); + setState(1264); _errHandler->sync(this); switch (_input->LA(1)) { case HogQLParser::IDENTIFIER: { enterOuterAlt(_localctx, 1); - setState(1253); + setState(1261); match(HogQLParser::IDENTIFIER); break; } @@ -11418,7 +11505,7 @@ HogQLParser::IdentifierContext* HogQLParser::identifier() { case HogQLParser::WEEK: case HogQLParser::YEAR: { enterOuterAlt(_localctx, 2); - setState(1254); + setState(1262); interval(); break; } @@ -11509,7 +11596,7 @@ HogQLParser::IdentifierContext* HogQLParser::identifier() { case HogQLParser::WINDOW: case HogQLParser::WITH: { enterOuterAlt(_localctx, 3); - setState(1255); + setState(1263); keyword(); break; } @@ -11561,7 +11648,7 @@ std::any HogQLParser::EnumValueContext::accept(tree::ParseTreeVisitor *visitor) HogQLParser::EnumValueContext* HogQLParser::enumValue() { EnumValueContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 158, HogQLParser::RuleEnumValue); + enterRule(_localctx, 160, HogQLParser::RuleEnumValue); #if __cplusplus > 201703L auto onExit = finally([=, this] { @@ -11572,11 +11659,11 @@ HogQLParser::EnumValueContext* HogQLParser::enumValue() { }); try { enterOuterAlt(_localctx, 1); - setState(1258); + setState(1266); string(); - setState(1259); + setState(1267); match(HogQLParser::EQ_SINGLE); - setState(1260); + setState(1268); numberLiteral(); } @@ -11622,7 +11709,7 @@ std::any HogQLParser::PlaceholderContext::accept(tree::ParseTreeVisitor *visitor HogQLParser::PlaceholderContext* HogQLParser::placeholder() { PlaceholderContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 160, HogQLParser::RulePlaceholder); + enterRule(_localctx, 162, HogQLParser::RulePlaceholder); #if __cplusplus > 201703L auto onExit = finally([=, this] { @@ -11633,11 +11720,11 @@ HogQLParser::PlaceholderContext* HogQLParser::placeholder() { }); try { enterOuterAlt(_localctx, 1); - setState(1262); + setState(1270); match(HogQLParser::LBRACE); - setState(1263); + setState(1271); columnExpr(0); - setState(1264); + setState(1272); match(HogQLParser::RBRACE); } @@ -11679,7 +11766,7 @@ std::any HogQLParser::StringContext::accept(tree::ParseTreeVisitor *visitor) { HogQLParser::StringContext* HogQLParser::string() { StringContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 162, HogQLParser::RuleString); + enterRule(_localctx, 164, HogQLParser::RuleString); #if __cplusplus > 201703L auto onExit = finally([=, this] { @@ -11689,19 +11776,19 @@ HogQLParser::StringContext* HogQLParser::string() { exitRule(); }); try { - setState(1268); + setState(1276); _errHandler->sync(this); switch (_input->LA(1)) { case HogQLParser::STRING_LITERAL: { enterOuterAlt(_localctx, 1); - setState(1266); + setState(1274); match(HogQLParser::STRING_LITERAL); break; } case HogQLParser::QUOTE_SINGLE_TEMPLATE: { enterOuterAlt(_localctx, 2); - setState(1267); + setState(1275); templateString(); break; } @@ -11757,7 +11844,7 @@ std::any HogQLParser::TemplateStringContext::accept(tree::ParseTreeVisitor *visi HogQLParser::TemplateStringContext* HogQLParser::templateString() { TemplateStringContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 164, HogQLParser::RuleTemplateString); + enterRule(_localctx, 166, HogQLParser::RuleTemplateString); size_t _la = 0; #if __cplusplus > 201703L @@ -11769,21 +11856,21 @@ HogQLParser::TemplateStringContext* HogQLParser::templateString() { }); try { enterOuterAlt(_localctx, 1); - setState(1270); + setState(1278); match(HogQLParser::QUOTE_SINGLE_TEMPLATE); - setState(1274); + setState(1282); _errHandler->sync(this); _la = _input->LA(1); while (_la == HogQLParser::STRING_TEXT || _la == HogQLParser::STRING_ESCAPE_TRIGGER) { - setState(1271); + setState(1279); stringContents(); - setState(1276); + setState(1284); _errHandler->sync(this); _la = _input->LA(1); } - setState(1277); + setState(1285); match(HogQLParser::QUOTE_SINGLE); } @@ -11833,7 +11920,7 @@ std::any HogQLParser::StringContentsContext::accept(tree::ParseTreeVisitor *visi HogQLParser::StringContentsContext* HogQLParser::stringContents() { StringContentsContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 166, HogQLParser::RuleStringContents); + enterRule(_localctx, 168, HogQLParser::RuleStringContents); #if __cplusplus > 201703L auto onExit = finally([=, this] { @@ -11843,23 +11930,23 @@ HogQLParser::StringContentsContext* HogQLParser::stringContents() { exitRule(); }); try { - setState(1284); + setState(1292); _errHandler->sync(this); switch (_input->LA(1)) { case HogQLParser::STRING_ESCAPE_TRIGGER: { enterOuterAlt(_localctx, 1); - setState(1279); + setState(1287); match(HogQLParser::STRING_ESCAPE_TRIGGER); - setState(1280); + setState(1288); columnExpr(0); - setState(1281); + setState(1289); match(HogQLParser::RBRACE); break; } case HogQLParser::STRING_TEXT: { enterOuterAlt(_localctx, 2); - setState(1283); + setState(1291); match(HogQLParser::STRING_TEXT); break; } @@ -11915,7 +12002,7 @@ std::any HogQLParser::FullTemplateStringContext::accept(tree::ParseTreeVisitor * HogQLParser::FullTemplateStringContext* HogQLParser::fullTemplateString() { FullTemplateStringContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 168, HogQLParser::RuleFullTemplateString); + enterRule(_localctx, 170, HogQLParser::RuleFullTemplateString); size_t _la = 0; #if __cplusplus > 201703L @@ -11927,21 +12014,21 @@ HogQLParser::FullTemplateStringContext* HogQLParser::fullTemplateString() { }); try { enterOuterAlt(_localctx, 1); - setState(1286); + setState(1294); match(HogQLParser::QUOTE_SINGLE_TEMPLATE_FULL); - setState(1290); + setState(1298); _errHandler->sync(this); _la = _input->LA(1); while (_la == HogQLParser::FULL_STRING_TEXT || _la == HogQLParser::FULL_STRING_ESCAPE_TRIGGER) { - setState(1287); + setState(1295); stringContentsFull(); - setState(1292); + setState(1300); _errHandler->sync(this); _la = _input->LA(1); } - setState(1293); + setState(1301); match(HogQLParser::EOF); } @@ -11991,7 +12078,7 @@ std::any HogQLParser::StringContentsFullContext::accept(tree::ParseTreeVisitor * HogQLParser::StringContentsFullContext* HogQLParser::stringContentsFull() { StringContentsFullContext *_localctx = _tracker.createInstance(_ctx, getState()); - enterRule(_localctx, 170, HogQLParser::RuleStringContentsFull); + enterRule(_localctx, 172, HogQLParser::RuleStringContentsFull); #if __cplusplus > 201703L auto onExit = finally([=, this] { @@ -12001,23 +12088,23 @@ HogQLParser::StringContentsFullContext* HogQLParser::stringContentsFull() { exitRule(); }); try { - setState(1300); + setState(1308); _errHandler->sync(this); switch (_input->LA(1)) { case HogQLParser::FULL_STRING_ESCAPE_TRIGGER: { enterOuterAlt(_localctx, 1); - setState(1295); + setState(1303); match(HogQLParser::FULL_STRING_ESCAPE_TRIGGER); - setState(1296); + setState(1304); columnExpr(0); - setState(1297); + setState(1305); match(HogQLParser::RBRACE); break; } case HogQLParser::FULL_STRING_TEXT: { enterOuterAlt(_localctx, 2); - setState(1299); + setState(1307); match(HogQLParser::FULL_STRING_TEXT); break; } @@ -12038,9 +12125,9 @@ HogQLParser::StringContentsFullContext* HogQLParser::stringContentsFull() { bool HogQLParser::sempred(RuleContext *context, size_t ruleIndex, size_t predicateIndex) { switch (ruleIndex) { - case 39: return joinExprSempred(antlrcpp::downCast(context), predicateIndex); - case 58: return columnExprSempred(antlrcpp::downCast(context), predicateIndex); - case 66: return tableExprSempred(antlrcpp::downCast(context), predicateIndex); + case 40: return joinExprSempred(antlrcpp::downCast(context), predicateIndex); + case 59: return columnExprSempred(antlrcpp::downCast(context), predicateIndex); + case 67: return tableExprSempred(antlrcpp::downCast(context), predicateIndex); default: break; diff --git a/hogql_parser/HogQLParser.h b/hogql_parser/HogQLParser.h index f607422676954..4c59a3bdc4209 100644 --- a/hogql_parser/HogQLParser.h +++ b/hogql_parser/HogQLParser.h @@ -16,32 +16,33 @@ class HogQLParser : public antlr4::Parser { ASOF = 8, BETWEEN = 9, BOTH = 10, BY = 11, CASE = 12, CAST = 13, CATCH = 14, COHORT = 15, COLLATE = 16, CROSS = 17, CUBE = 18, CURRENT = 19, DATE = 20, DAY = 21, DESC = 22, DESCENDING = 23, DISTINCT = 24, ELSE = 25, END = 26, - EXTRACT = 27, FINAL = 28, FINALLY = 29, FIRST = 30, FN = 31, FOLLOWING = 32, - FOR = 33, FROM = 34, FULL = 35, FUN = 36, GROUP = 37, HAVING = 38, HOUR = 39, - ID = 40, IF = 41, ILIKE = 42, IN = 43, INF = 44, INNER = 45, INTERVAL = 46, - IS = 47, JOIN = 48, KEY = 49, LAST = 50, LEADING = 51, LEFT = 52, LET = 53, - LIKE = 54, LIMIT = 55, MINUTE = 56, MONTH = 57, NAN_SQL = 58, NOT = 59, - NULL_SQL = 60, NULLS = 61, OFFSET = 62, ON = 63, OR = 64, ORDER = 65, - OUTER = 66, OVER = 67, PARTITION = 68, PRECEDING = 69, PREWHERE = 70, - QUARTER = 71, RANGE = 72, RETURN = 73, RIGHT = 74, ROLLUP = 75, ROW = 76, - ROWS = 77, SAMPLE = 78, SECOND = 79, SELECT = 80, SEMI = 81, SETTINGS = 82, - SUBSTRING = 83, THEN = 84, THROW = 85, TIES = 86, TIMESTAMP = 87, TO = 88, - TOP = 89, TOTALS = 90, TRAILING = 91, TRIM = 92, TRUNCATE = 93, TRY = 94, - UNBOUNDED = 95, UNION = 96, USING = 97, WEEK = 98, WHEN = 99, WHERE = 100, - WHILE = 101, WINDOW = 102, WITH = 103, YEAR = 104, ESCAPE_CHAR_COMMON = 105, - IDENTIFIER = 106, FLOATING_LITERAL = 107, OCTAL_LITERAL = 108, DECIMAL_LITERAL = 109, - HEXADECIMAL_LITERAL = 110, STRING_LITERAL = 111, ARROW = 112, ASTERISK = 113, - BACKQUOTE = 114, BACKSLASH = 115, COLON = 116, COMMA = 117, CONCAT = 118, - DASH = 119, DOLLAR = 120, DOT = 121, EQ_DOUBLE = 122, EQ_SINGLE = 123, - GT_EQ = 124, GT = 125, HASH = 126, IREGEX_SINGLE = 127, IREGEX_DOUBLE = 128, - LBRACE = 129, LBRACKET = 130, LPAREN = 131, LT_EQ = 132, LT = 133, NOT_EQ = 134, - NOT_IREGEX = 135, NOT_REGEX = 136, NULL_PROPERTY = 137, NULLISH = 138, - PERCENT = 139, PLUS = 140, QUERY = 141, QUOTE_DOUBLE = 142, QUOTE_SINGLE_TEMPLATE = 143, - QUOTE_SINGLE_TEMPLATE_FULL = 144, QUOTE_SINGLE = 145, REGEX_SINGLE = 146, - REGEX_DOUBLE = 147, RBRACE = 148, RBRACKET = 149, RPAREN = 150, SEMICOLON = 151, - SLASH = 152, UNDERSCORE = 153, MULTI_LINE_COMMENT = 154, SINGLE_LINE_COMMENT = 155, - WHITESPACE = 156, STRING_TEXT = 157, STRING_ESCAPE_TRIGGER = 158, FULL_STRING_TEXT = 159, - FULL_STRING_ESCAPE_TRIGGER = 160 + EXCEPT = 27, EXTRACT = 28, FINAL = 29, FINALLY = 30, FIRST = 31, FN = 32, + FOLLOWING = 33, FOR = 34, FROM = 35, FULL = 36, FUN = 37, GROUP = 38, + HAVING = 39, HOUR = 40, ID = 41, IF = 42, ILIKE = 43, IN = 44, INF = 45, + INNER = 46, INTERSECT = 47, INTERVAL = 48, IS = 49, JOIN = 50, KEY = 51, + LAST = 52, LEADING = 53, LEFT = 54, LET = 55, LIKE = 56, LIMIT = 57, + MINUTE = 58, MONTH = 59, NAN_SQL = 60, NOT = 61, NULL_SQL = 62, NULLS = 63, + OFFSET = 64, ON = 65, OR = 66, ORDER = 67, OUTER = 68, OVER = 69, PARTITION = 70, + PRECEDING = 71, PREWHERE = 72, QUARTER = 73, RANGE = 74, RETURN = 75, + RIGHT = 76, ROLLUP = 77, ROW = 78, ROWS = 79, SAMPLE = 80, SECOND = 81, + SELECT = 82, SEMI = 83, SETTINGS = 84, SUBSTRING = 85, THEN = 86, THROW = 87, + TIES = 88, TIMESTAMP = 89, TO = 90, TOP = 91, TOTALS = 92, TRAILING = 93, + TRIM = 94, TRUNCATE = 95, TRY = 96, UNBOUNDED = 97, UNION = 98, USING = 99, + WEEK = 100, WHEN = 101, WHERE = 102, WHILE = 103, WINDOW = 104, WITH = 105, + YEAR = 106, ESCAPE_CHAR_COMMON = 107, IDENTIFIER = 108, FLOATING_LITERAL = 109, + OCTAL_LITERAL = 110, DECIMAL_LITERAL = 111, HEXADECIMAL_LITERAL = 112, + STRING_LITERAL = 113, ARROW = 114, ASTERISK = 115, BACKQUOTE = 116, + BACKSLASH = 117, COLON = 118, COMMA = 119, CONCAT = 120, DASH = 121, + DOLLAR = 122, DOT = 123, EQ_DOUBLE = 124, EQ_SINGLE = 125, GT_EQ = 126, + GT = 127, HASH = 128, IREGEX_SINGLE = 129, IREGEX_DOUBLE = 130, LBRACE = 131, + LBRACKET = 132, LPAREN = 133, LT_EQ = 134, LT = 135, NOT_EQ = 136, NOT_IREGEX = 137, + NOT_REGEX = 138, NULL_PROPERTY = 139, NULLISH = 140, PERCENT = 141, + PLUS = 142, QUERY = 143, QUOTE_DOUBLE = 144, QUOTE_SINGLE_TEMPLATE = 145, + QUOTE_SINGLE_TEMPLATE_FULL = 146, QUOTE_SINGLE = 147, REGEX_SINGLE = 148, + REGEX_DOUBLE = 149, RBRACE = 150, RBRACKET = 151, RPAREN = 152, SEMICOLON = 153, + SLASH = 154, UNDERSCORE = 155, MULTI_LINE_COMMENT = 156, SINGLE_LINE_COMMENT = 157, + WHITESPACE = 158, STRING_TEXT = 159, STRING_ESCAPE_TRIGGER = 160, FULL_STRING_TEXT = 161, + FULL_STRING_ESCAPE_TRIGGER = 162 }; enum { @@ -50,26 +51,27 @@ class HogQLParser : public antlr4::Parser { RuleCatchBlock = 8, RuleTryCatchStmt = 9, RuleIfStmt = 10, RuleWhileStmt = 11, RuleForStmt = 12, RuleForInStmt = 13, RuleFuncStmt = 14, RuleVarAssignment = 15, RuleExprStmt = 16, RuleEmptyStmt = 17, RuleBlock = 18, RuleKvPair = 19, - RuleKvPairList = 20, RuleSelect = 21, RuleSelectUnionStmt = 22, RuleSelectStmtWithParens = 23, - RuleSelectStmt = 24, RuleWithClause = 25, RuleTopClause = 26, RuleFromClause = 27, - RuleArrayJoinClause = 28, RuleWindowClause = 29, RulePrewhereClause = 30, - RuleWhereClause = 31, RuleGroupByClause = 32, RuleHavingClause = 33, - RuleOrderByClause = 34, RuleProjectionOrderByClause = 35, RuleLimitAndOffsetClause = 36, - RuleOffsetOnlyClause = 37, RuleSettingsClause = 38, RuleJoinExpr = 39, - RuleJoinOp = 40, RuleJoinOpCross = 41, RuleJoinConstraintClause = 42, - RuleSampleClause = 43, RuleOrderExprList = 44, RuleOrderExpr = 45, RuleRatioExpr = 46, - RuleSettingExprList = 47, RuleSettingExpr = 48, RuleWindowExpr = 49, - RuleWinPartitionByClause = 50, RuleWinOrderByClause = 51, RuleWinFrameClause = 52, - RuleWinFrameExtend = 53, RuleWinFrameBound = 54, RuleExpr = 55, RuleColumnTypeExpr = 56, - 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 + RuleKvPairList = 20, RuleSelect = 21, RuleSelectStmtWithParens = 22, + RuleSubsequentSelectSetClause = 23, RuleSelectSetStmt = 24, RuleSelectStmt = 25, + RuleWithClause = 26, RuleTopClause = 27, RuleFromClause = 28, RuleArrayJoinClause = 29, + RuleWindowClause = 30, RulePrewhereClause = 31, RuleWhereClause = 32, + RuleGroupByClause = 33, RuleHavingClause = 34, RuleOrderByClause = 35, + RuleProjectionOrderByClause = 36, RuleLimitAndOffsetClause = 37, RuleOffsetOnlyClause = 38, + RuleSettingsClause = 39, RuleJoinExpr = 40, RuleJoinOp = 41, RuleJoinOpCross = 42, + RuleJoinConstraintClause = 43, RuleSampleClause = 44, RuleOrderExprList = 45, + RuleOrderExpr = 46, RuleRatioExpr = 47, RuleSettingExprList = 48, RuleSettingExpr = 49, + RuleWindowExpr = 50, RuleWinPartitionByClause = 51, RuleWinOrderByClause = 52, + RuleWinFrameClause = 53, RuleWinFrameExtend = 54, RuleWinFrameBound = 55, + RuleExpr = 56, RuleColumnTypeExpr = 57, RuleColumnExprList = 58, RuleColumnExpr = 59, + RuleColumnLambdaExpr = 60, RuleHogqlxTagElement = 61, RuleHogqlxTagAttribute = 62, + RuleWithExprList = 63, RuleWithExpr = 64, RuleColumnIdentifier = 65, + RuleNestedIdentifier = 66, RuleTableExpr = 67, RuleTableFunctionExpr = 68, + RuleTableIdentifier = 69, RuleTableArgList = 70, RuleDatabaseIdentifier = 71, + RuleFloatingLiteral = 72, RuleNumberLiteral = 73, RuleLiteral = 74, + RuleInterval = 75, RuleKeyword = 76, RuleKeywordForAlias = 77, RuleAlias = 78, + RuleIdentifier = 79, RuleEnumValue = 80, RulePlaceholder = 81, RuleString = 82, + RuleTemplateString = 83, RuleStringContents = 84, RuleFullTemplateString = 85, + RuleStringContentsFull = 86 }; explicit HogQLParser(antlr4::TokenStream *input); @@ -111,8 +113,9 @@ class HogQLParser : public antlr4::Parser { class KvPairContext; class KvPairListContext; class SelectContext; - class SelectUnionStmtContext; class SelectStmtWithParensContext; + class SubsequentSelectSetClauseContext; + class SelectSetStmtContext; class SelectStmtContext; class WithClauseContext; class TopClauseContext; @@ -552,7 +555,7 @@ class HogQLParser : public antlr4::Parser { SelectContext(antlr4::ParserRuleContext *parent, size_t invokingState); virtual size_t getRuleIndex() const override; antlr4::tree::TerminalNode *EOF(); - SelectUnionStmtContext *selectUnionStmt(); + SelectSetStmtContext *selectSetStmt(); SelectStmtContext *selectStmt(); HogqlxTagElementContext *hogqlxTagElement(); @@ -563,40 +566,54 @@ class HogQLParser : public antlr4::Parser { SelectContext* select(); - class SelectUnionStmtContext : public antlr4::ParserRuleContext { + class SelectStmtWithParensContext : public antlr4::ParserRuleContext { public: - SelectUnionStmtContext(antlr4::ParserRuleContext *parent, size_t invokingState); + SelectStmtWithParensContext(antlr4::ParserRuleContext *parent, size_t invokingState); virtual size_t getRuleIndex() const override; - std::vector selectStmtWithParens(); - SelectStmtWithParensContext* selectStmtWithParens(size_t i); - std::vector UNION(); - antlr4::tree::TerminalNode* UNION(size_t i); - std::vector ALL(); - antlr4::tree::TerminalNode* ALL(size_t i); + SelectStmtContext *selectStmt(); + antlr4::tree::TerminalNode *LPAREN(); + SelectSetStmtContext *selectSetStmt(); + antlr4::tree::TerminalNode *RPAREN(); + PlaceholderContext *placeholder(); virtual std::any accept(antlr4::tree::ParseTreeVisitor *visitor) override; }; - SelectUnionStmtContext* selectUnionStmt(); + SelectStmtWithParensContext* selectStmtWithParens(); - class SelectStmtWithParensContext : public antlr4::ParserRuleContext { + class SubsequentSelectSetClauseContext : public antlr4::ParserRuleContext { public: - SelectStmtWithParensContext(antlr4::ParserRuleContext *parent, size_t invokingState); + SubsequentSelectSetClauseContext(antlr4::ParserRuleContext *parent, size_t invokingState); virtual size_t getRuleIndex() const override; - SelectStmtContext *selectStmt(); - antlr4::tree::TerminalNode *LPAREN(); - SelectUnionStmtContext *selectUnionStmt(); - antlr4::tree::TerminalNode *RPAREN(); - PlaceholderContext *placeholder(); + SelectStmtWithParensContext *selectStmtWithParens(); + antlr4::tree::TerminalNode *EXCEPT(); + antlr4::tree::TerminalNode *UNION(); + antlr4::tree::TerminalNode *ALL(); + antlr4::tree::TerminalNode *INTERSECT(); virtual std::any accept(antlr4::tree::ParseTreeVisitor *visitor) override; }; - SelectStmtWithParensContext* selectStmtWithParens(); + SubsequentSelectSetClauseContext* subsequentSelectSetClause(); + + class SelectSetStmtContext : public antlr4::ParserRuleContext { + public: + SelectSetStmtContext(antlr4::ParserRuleContext *parent, size_t invokingState); + virtual size_t getRuleIndex() const override; + SelectStmtWithParensContext *selectStmtWithParens(); + std::vector subsequentSelectSetClause(); + SubsequentSelectSetClauseContext* subsequentSelectSetClause(size_t i); + + + virtual std::any accept(antlr4::tree::ParseTreeVisitor *visitor) override; + + }; + + SelectSetStmtContext* selectSetStmt(); class SelectStmtContext : public antlr4::ParserRuleContext { public: @@ -1398,7 +1415,7 @@ class HogQLParser : public antlr4::Parser { ColumnExprSubqueryContext(ColumnExprContext *ctx); antlr4::tree::TerminalNode *LPAREN(); - SelectUnionStmtContext *selectUnionStmt(); + SelectSetStmtContext *selectSetStmt(); antlr4::tree::TerminalNode *RPAREN(); virtual std::any accept(antlr4::tree::ParseTreeVisitor *visitor) override; @@ -1999,7 +2016,7 @@ class HogQLParser : public antlr4::Parser { IdentifierContext *identifier(); antlr4::tree::TerminalNode *AS(); antlr4::tree::TerminalNode *LPAREN(); - SelectUnionStmtContext *selectUnionStmt(); + SelectSetStmtContext *selectSetStmt(); antlr4::tree::TerminalNode *RPAREN(); virtual std::any accept(antlr4::tree::ParseTreeVisitor *visitor) override; @@ -2084,7 +2101,7 @@ class HogQLParser : public antlr4::Parser { TableExprSubqueryContext(TableExprContext *ctx); antlr4::tree::TerminalNode *LPAREN(); - SelectUnionStmtContext *selectUnionStmt(); + SelectSetStmtContext *selectSetStmt(); antlr4::tree::TerminalNode *RPAREN(); virtual std::any accept(antlr4::tree::ParseTreeVisitor *visitor) override; diff --git a/hogql_parser/HogQLParser.interp b/hogql_parser/HogQLParser.interp index 86b5777f1ff22..4308ee42ae9b9 100644 --- a/hogql_parser/HogQLParser.interp +++ b/hogql_parser/HogQLParser.interp @@ -111,6 +111,8 @@ null null null null +null +null '->' '*' '`' @@ -189,6 +191,7 @@ DESCENDING DISTINCT ELSE END +EXCEPT EXTRACT FINAL FINALLY @@ -208,6 +211,7 @@ ILIKE IN INF INNER +INTERSECT INTERVAL IS JOIN @@ -347,8 +351,9 @@ block kvPair kvPairList select -selectUnionStmt selectStmtWithParens +subsequentSelectSetClause +selectSetStmt selectStmt withClause topClause @@ -414,4 +419,4 @@ stringContentsFull atn: -[4, 1, 160, 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, 17, 2, 0, 31, 31, 36, 36, 2, 0, 18, 18, 75, 75, 2, 0, 45, 45, 52, 52, 3, 0, 1, 1, 4, 4, 8, 8, 4, 0, 1, 1, 3, 4, 8, 8, 81, 81, 2, 0, 52, 52, 74, 74, 2, 0, 1, 1, 4, 4, 2, 0, 7, 7, 22, 23, 2, 0, 30, 30, 50, 50, 2, 0, 72, 72, 77, 77, 3, 0, 10, 10, 51, 51, 91, 91, 2, 0, 42, 42, 54, 54, 1, 0, 108, 109, 2, 0, 119, 119, 140, 140, 7, 0, 21, 21, 39, 39, 56, 57, 71, 71, 79, 79, 98, 98, 104, 104, 17, 0, 1, 13, 15, 20, 22, 28, 30, 30, 32, 35, 37, 38, 40, 43, 45, 52, 54, 55, 59, 59, 61, 70, 72, 78, 80, 84, 86, 93, 95, 97, 99, 100, 102, 103, 4, 0, 20, 20, 30, 30, 40, 40, 49, 49, 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, 53, 0, 0, 187, 191, 3, 156, 78, 0, 188, 189, 5, 116, 0, 0, 189, 190, 5, 123, 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, 117, 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, 117, 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, 73, 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, 151, 0, 0, 223, 222, 1, 0, 0, 0, 223, 224, 1, 0, 0, 0, 224, 13, 1, 0, 0, 0, 225, 227, 5, 85, 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, 151, 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, 131, 0, 0, 234, 237, 3, 156, 78, 0, 235, 236, 5, 116, 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, 150, 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, 94, 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, 41, 0, 0, 258, 259, 5, 131, 0, 0, 259, 260, 3, 4, 2, 0, 260, 261, 5, 150, 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, 101, 0, 0, 267, 268, 5, 131, 0, 0, 268, 269, 3, 4, 2, 0, 269, 270, 5, 150, 0, 0, 270, 272, 3, 10, 5, 0, 271, 273, 5, 151, 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, 131, 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, 151, 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, 151, 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, 150, 0, 0, 292, 294, 3, 10, 5, 0, 293, 295, 5, 151, 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, 131, 0, 0, 298, 299, 5, 53, 0, 0, 299, 302, 3, 156, 78, 0, 300, 301, 5, 117, 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, 43, 0, 0, 305, 306, 3, 4, 2, 0, 306, 307, 5, 150, 0, 0, 307, 309, 3, 10, 5, 0, 308, 310, 5, 151, 0, 0, 309, 308, 1, 0, 0, 0, 309, 310, 1, 0, 0, 0, 310, 27, 1, 0, 0, 0, 311, 312, 7, 0, 0, 0, 312, 313, 3, 156, 78, 0, 313, 315, 5, 131, 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, 150, 0, 0, 318, 319, 3, 36, 18, 0, 319, 29, 1, 0, 0, 0, 320, 321, 3, 4, 2, 0, 321, 322, 5, 116, 0, 0, 322, 323, 5, 123, 0, 0, 323, 324, 3, 4, 2, 0, 324, 31, 1, 0, 0, 0, 325, 327, 3, 4, 2, 0, 326, 328, 5, 151, 0, 0, 327, 326, 1, 0, 0, 0, 327, 328, 1, 0, 0, 0, 328, 33, 1, 0, 0, 0, 329, 330, 5, 151, 0, 0, 330, 35, 1, 0, 0, 0, 331, 335, 5, 129, 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, 148, 0, 0, 339, 37, 1, 0, 0, 0, 340, 341, 3, 4, 2, 0, 341, 342, 5, 116, 0, 0, 342, 343, 3, 4, 2, 0, 343, 39, 1, 0, 0, 0, 344, 349, 3, 38, 19, 0, 345, 346, 5, 117, 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, 117, 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, 96, 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, 131, 0, 0, 373, 374, 3, 44, 22, 0, 374, 375, 5, 150, 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, 80, 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, 103, 0, 0, 406, 408, 7, 1, 0, 0, 407, 405, 1, 0, 0, 0, 407, 408, 1, 0, 0, 0, 408, 411, 1, 0, 0, 0, 409, 410, 5, 103, 0, 0, 410, 412, 5, 90, 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, 103, 0, 0, 430, 431, 3, 124, 62, 0, 431, 51, 1, 0, 0, 0, 432, 433, 5, 89, 0, 0, 433, 436, 5, 109, 0, 0, 434, 435, 5, 103, 0, 0, 435, 437, 5, 86, 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, 2, 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, 48, 0, 0, 446, 447, 3, 114, 57, 0, 447, 57, 1, 0, 0, 0, 448, 449, 5, 102, 0, 0, 449, 450, 3, 156, 78, 0, 450, 451, 5, 6, 0, 0, 451, 452, 5, 131, 0, 0, 452, 453, 3, 98, 49, 0, 453, 463, 5, 150, 0, 0, 454, 455, 5, 117, 0, 0, 455, 456, 3, 156, 78, 0, 456, 457, 5, 6, 0, 0, 457, 458, 5, 131, 0, 0, 458, 459, 3, 98, 49, 0, 459, 460, 5, 150, 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, 70, 0, 0, 467, 468, 3, 116, 58, 0, 468, 61, 1, 0, 0, 0, 469, 470, 5, 100, 0, 0, 470, 471, 3, 116, 58, 0, 471, 63, 1, 0, 0, 0, 472, 473, 5, 37, 0, 0, 473, 480, 5, 11, 0, 0, 474, 475, 7, 1, 0, 0, 475, 476, 5, 131, 0, 0, 476, 477, 3, 114, 57, 0, 477, 478, 5, 150, 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, 38, 0, 0, 483, 484, 3, 116, 58, 0, 484, 67, 1, 0, 0, 0, 485, 486, 5, 65, 0, 0, 486, 487, 5, 11, 0, 0, 487, 488, 3, 88, 44, 0, 488, 69, 1, 0, 0, 0, 489, 490, 5, 65, 0, 0, 490, 491, 5, 11, 0, 0, 491, 492, 3, 114, 57, 0, 492, 71, 1, 0, 0, 0, 493, 494, 5, 55, 0, 0, 494, 497, 3, 116, 58, 0, 495, 496, 5, 117, 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, 103, 0, 0, 500, 504, 5, 86, 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, 55, 0, 0, 506, 509, 3, 116, 58, 0, 507, 508, 5, 103, 0, 0, 508, 510, 5, 86, 0, 0, 509, 507, 1, 0, 0, 0, 509, 510, 1, 0, 0, 0, 510, 511, 1, 0, 0, 0, 511, 512, 5, 62, 0, 0, 512, 513, 3, 116, 58, 0, 513, 523, 1, 0, 0, 0, 514, 515, 5, 55, 0, 0, 515, 516, 3, 116, 58, 0, 516, 517, 5, 62, 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, 62, 0, 0, 525, 526, 3, 116, 58, 0, 526, 75, 1, 0, 0, 0, 527, 528, 5, 82, 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, 131, 0, 0, 539, 540, 3, 78, 39, 0, 540, 541, 5, 150, 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, 48, 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, 3, 0, 0, 562, 561, 1, 0, 0, 0, 562, 563, 1, 0, 0, 0, 563, 564, 1, 0, 0, 0, 564, 571, 5, 45, 0, 0, 565, 567, 5, 45, 0, 0, 566, 568, 7, 3, 0, 0, 567, 566, 1, 0, 0, 0, 567, 568, 1, 0, 0, 0, 568, 571, 1, 0, 0, 0, 569, 571, 7, 3, 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, 4, 0, 0, 573, 572, 1, 0, 0, 0, 573, 574, 1, 0, 0, 0, 574, 575, 1, 0, 0, 0, 575, 577, 7, 5, 0, 0, 576, 578, 5, 66, 0, 0, 577, 576, 1, 0, 0, 0, 577, 578, 1, 0, 0, 0, 578, 587, 1, 0, 0, 0, 579, 581, 7, 5, 0, 0, 580, 582, 5, 66, 0, 0, 581, 580, 1, 0, 0, 0, 581, 582, 1, 0, 0, 0, 582, 584, 1, 0, 0, 0, 583, 585, 7, 4, 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, 6, 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, 66, 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, 66, 0, 0, 597, 596, 1, 0, 0, 0, 597, 598, 1, 0, 0, 0, 598, 600, 1, 0, 0, 0, 599, 601, 7, 6, 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, 48, 0, 0, 608, 610, 5, 117, 0, 0, 609, 606, 1, 0, 0, 0, 609, 608, 1, 0, 0, 0, 610, 83, 1, 0, 0, 0, 611, 612, 5, 63, 0, 0, 612, 621, 3, 114, 57, 0, 613, 614, 5, 97, 0, 0, 614, 615, 5, 131, 0, 0, 615, 616, 3, 114, 57, 0, 616, 617, 5, 150, 0, 0, 617, 621, 1, 0, 0, 0, 618, 619, 5, 97, 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, 78, 0, 0, 623, 626, 3, 92, 46, 0, 624, 625, 5, 62, 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, 117, 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, 7, 0, 0, 638, 637, 1, 0, 0, 0, 638, 639, 1, 0, 0, 0, 639, 642, 1, 0, 0, 0, 640, 641, 5, 61, 0, 0, 641, 643, 7, 8, 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, 111, 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, 152, 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, 117, 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, 123, 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, 68, 0, 0, 678, 679, 5, 11, 0, 0, 679, 680, 3, 114, 57, 0, 680, 101, 1, 0, 0, 0, 681, 682, 5, 65, 0, 0, 682, 683, 5, 11, 0, 0, 683, 684, 3, 88, 44, 0, 684, 103, 1, 0, 0, 0, 685, 686, 7, 9, 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, 76, 0, 0, 698, 699, 5, 95, 0, 0, 699, 709, 5, 69, 0, 0, 700, 701, 5, 95, 0, 0, 701, 709, 5, 32, 0, 0, 702, 703, 3, 144, 72, 0, 703, 704, 5, 69, 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, 131, 0, 0, 716, 717, 3, 156, 78, 0, 717, 724, 3, 112, 56, 0, 718, 719, 5, 117, 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, 117, 0, 0, 728, 727, 1, 0, 0, 0, 728, 729, 1, 0, 0, 0, 729, 730, 1, 0, 0, 0, 730, 731, 5, 150, 0, 0, 731, 770, 1, 0, 0, 0, 732, 733, 3, 156, 78, 0, 733, 734, 5, 131, 0, 0, 734, 739, 3, 158, 79, 0, 735, 736, 5, 117, 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, 117, 0, 0, 743, 742, 1, 0, 0, 0, 743, 744, 1, 0, 0, 0, 744, 745, 1, 0, 0, 0, 745, 746, 5, 150, 0, 0, 746, 770, 1, 0, 0, 0, 747, 748, 3, 156, 78, 0, 748, 749, 5, 131, 0, 0, 749, 754, 3, 112, 56, 0, 750, 751, 5, 117, 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, 117, 0, 0, 758, 757, 1, 0, 0, 0, 758, 759, 1, 0, 0, 0, 759, 760, 1, 0, 0, 0, 760, 761, 5, 150, 0, 0, 761, 770, 1, 0, 0, 0, 762, 763, 3, 156, 78, 0, 763, 765, 5, 131, 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, 150, 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, 117, 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, 117, 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, 99, 0, 0, 788, 789, 3, 116, 58, 0, 789, 790, 5, 84, 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, 131, 0, 0, 804, 805, 3, 116, 58, 0, 805, 806, 5, 6, 0, 0, 806, 807, 3, 112, 56, 0, 807, 808, 5, 150, 0, 0, 808, 933, 1, 0, 0, 0, 809, 810, 5, 20, 0, 0, 810, 933, 5, 111, 0, 0, 811, 812, 5, 46, 0, 0, 812, 813, 3, 116, 58, 0, 813, 814, 3, 148, 74, 0, 814, 933, 1, 0, 0, 0, 815, 816, 5, 83, 0, 0, 816, 817, 5, 131, 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, 150, 0, 0, 825, 933, 1, 0, 0, 0, 826, 827, 5, 87, 0, 0, 827, 933, 5, 111, 0, 0, 828, 829, 5, 92, 0, 0, 829, 830, 5, 131, 0, 0, 830, 831, 7, 10, 0, 0, 831, 832, 3, 162, 81, 0, 832, 833, 5, 34, 0, 0, 833, 834, 3, 116, 58, 0, 834, 835, 5, 150, 0, 0, 835, 933, 1, 0, 0, 0, 836, 837, 3, 156, 78, 0, 837, 839, 5, 131, 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, 150, 0, 0, 842, 851, 1, 0, 0, 0, 843, 845, 5, 131, 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, 150, 0, 0, 851, 843, 1, 0, 0, 0, 851, 852, 1, 0, 0, 0, 852, 853, 1, 0, 0, 0, 853, 854, 5, 67, 0, 0, 854, 855, 5, 131, 0, 0, 855, 856, 3, 98, 49, 0, 856, 857, 5, 150, 0, 0, 857, 933, 1, 0, 0, 0, 858, 859, 3, 156, 78, 0, 859, 861, 5, 131, 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, 150, 0, 0, 864, 873, 1, 0, 0, 0, 865, 867, 5, 131, 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, 150, 0, 0, 873, 865, 1, 0, 0, 0, 873, 874, 1, 0, 0, 0, 874, 875, 1, 0, 0, 0, 875, 876, 5, 67, 0, 0, 876, 877, 3, 156, 78, 0, 877, 933, 1, 0, 0, 0, 878, 884, 3, 156, 78, 0, 879, 881, 5, 131, 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, 150, 0, 0, 884, 879, 1, 0, 0, 0, 884, 885, 1, 0, 0, 0, 885, 886, 1, 0, 0, 0, 886, 888, 5, 131, 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, 150, 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, 119, 0, 0, 899, 933, 3, 116, 58, 20, 900, 901, 5, 59, 0, 0, 901, 933, 3, 116, 58, 14, 902, 903, 3, 136, 68, 0, 903, 904, 5, 121, 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, 113, 0, 0, 908, 909, 5, 131, 0, 0, 909, 910, 3, 44, 22, 0, 910, 911, 5, 150, 0, 0, 911, 933, 1, 0, 0, 0, 912, 913, 5, 131, 0, 0, 913, 914, 3, 116, 58, 0, 914, 915, 5, 150, 0, 0, 915, 933, 1, 0, 0, 0, 916, 917, 5, 131, 0, 0, 917, 918, 3, 114, 57, 0, 918, 919, 5, 150, 0, 0, 919, 933, 1, 0, 0, 0, 920, 922, 5, 130, 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, 149, 0, 0, 925, 927, 5, 129, 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, 148, 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, 113, 0, 0, 936, 939, 5, 152, 0, 0, 937, 939, 5, 139, 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, 140, 0, 0, 943, 946, 5, 119, 0, 0, 944, 946, 5, 118, 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, 122, 0, 0, 950, 974, 5, 123, 0, 0, 951, 974, 5, 134, 0, 0, 952, 974, 5, 132, 0, 0, 953, 974, 5, 133, 0, 0, 954, 974, 5, 124, 0, 0, 955, 974, 5, 125, 0, 0, 956, 958, 5, 59, 0, 0, 957, 956, 1, 0, 0, 0, 957, 958, 1, 0, 0, 0, 958, 959, 1, 0, 0, 0, 959, 961, 5, 43, 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, 59, 0, 0, 964, 963, 1, 0, 0, 0, 964, 965, 1, 0, 0, 0, 965, 966, 1, 0, 0, 0, 966, 974, 7, 11, 0, 0, 967, 974, 5, 146, 0, 0, 968, 974, 5, 147, 0, 0, 969, 974, 5, 136, 0, 0, 970, 974, 5, 127, 0, 0, 971, 974, 5, 128, 0, 0, 972, 974, 5, 135, 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, 138, 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, 64, 0, 0, 984, 1043, 3, 116, 58, 13, 985, 987, 10, 11, 0, 0, 986, 988, 5, 59, 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, 141, 0, 0, 996, 997, 3, 116, 58, 0, 997, 998, 5, 116, 0, 0, 998, 999, 3, 116, 58, 10, 999, 1043, 1, 0, 0, 0, 1000, 1001, 10, 30, 0, 0, 1001, 1003, 5, 131, 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, 150, 0, 0, 1006, 1007, 10, 26, 0, 0, 1007, 1008, 5, 130, 0, 0, 1008, 1009, 3, 116, 58, 0, 1009, 1010, 5, 149, 0, 0, 1010, 1043, 1, 0, 0, 0, 1011, 1012, 10, 25, 0, 0, 1012, 1013, 5, 121, 0, 0, 1013, 1043, 5, 109, 0, 0, 1014, 1015, 10, 24, 0, 0, 1015, 1016, 5, 121, 0, 0, 1016, 1043, 3, 156, 78, 0, 1017, 1018, 10, 23, 0, 0, 1018, 1019, 5, 137, 0, 0, 1019, 1020, 5, 130, 0, 0, 1020, 1021, 3, 116, 58, 0, 1021, 1022, 5, 149, 0, 0, 1022, 1043, 1, 0, 0, 0, 1023, 1024, 10, 22, 0, 0, 1024, 1025, 5, 137, 0, 0, 1025, 1043, 5, 109, 0, 0, 1026, 1027, 10, 21, 0, 0, 1027, 1028, 5, 137, 0, 0, 1028, 1043, 3, 156, 78, 0, 1029, 1030, 10, 16, 0, 0, 1030, 1032, 5, 47, 0, 0, 1031, 1033, 5, 59, 0, 0, 1032, 1031, 1, 0, 0, 0, 1032, 1033, 1, 0, 0, 0, 1033, 1034, 1, 0, 0, 0, 1034, 1043, 5, 60, 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, 111, 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, 131, 0, 0, 1048, 1053, 3, 156, 78, 0, 1049, 1050, 5, 117, 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, 117, 0, 0, 1057, 1056, 1, 0, 0, 0, 1057, 1058, 1, 0, 0, 0, 1058, 1059, 1, 0, 0, 0, 1059, 1060, 5, 150, 0, 0, 1060, 1075, 1, 0, 0, 0, 1061, 1066, 3, 156, 78, 0, 1062, 1063, 5, 117, 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, 117, 0, 0, 1070, 1069, 1, 0, 0, 0, 1070, 1071, 1, 0, 0, 0, 1071, 1075, 1, 0, 0, 0, 1072, 1073, 5, 131, 0, 0, 1073, 1075, 5, 150, 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, 112, 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, 133, 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, 152, 0, 0, 1090, 1091, 5, 125, 0, 0, 1091, 1114, 1, 0, 0, 0, 1092, 1093, 5, 133, 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, 125, 0, 0, 1101, 1107, 3, 120, 60, 0, 1102, 1103, 5, 129, 0, 0, 1103, 1104, 3, 116, 58, 0, 1104, 1105, 5, 148, 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, 133, 0, 0, 1109, 1110, 5, 152, 0, 0, 1110, 1111, 3, 156, 78, 0, 1111, 1112, 5, 125, 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, 123, 0, 0, 1117, 1118, 3, 162, 81, 0, 1118, 1127, 1, 0, 0, 0, 1119, 1120, 3, 156, 78, 0, 1120, 1121, 5, 123, 0, 0, 1121, 1122, 5, 129, 0, 0, 1122, 1123, 3, 116, 58, 0, 1123, 1124, 5, 148, 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, 117, 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, 117, 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, 131, 0, 0, 1142, 1143, 3, 44, 22, 0, 1143, 1144, 5, 150, 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, 121, 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, 121, 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, 131, 0, 0, 1172, 1173, 3, 44, 22, 0, 1173, 1174, 5, 150, 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, 131, 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, 150, 0, 0, 1196, 135, 1, 0, 0, 0, 1197, 1198, 3, 140, 70, 0, 1198, 1199, 5, 121, 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, 117, 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, 117, 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, 107, 0, 0, 1218, 1219, 5, 121, 0, 0, 1219, 1226, 7, 12, 0, 0, 1220, 1221, 5, 109, 0, 0, 1221, 1223, 5, 121, 0, 0, 1222, 1224, 7, 12, 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, 13, 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, 108, 0, 0, 1232, 1237, 5, 109, 0, 0, 1233, 1237, 5, 110, 0, 0, 1234, 1237, 5, 44, 0, 0, 1235, 1237, 5, 58, 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, 111, 0, 0, 1240, 1242, 5, 60, 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, 14, 0, 0, 1244, 149, 1, 0, 0, 0, 1245, 1246, 7, 15, 0, 0, 1246, 151, 1, 0, 0, 0, 1247, 1248, 7, 16, 0, 0, 1248, 153, 1, 0, 0, 0, 1249, 1252, 5, 106, 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, 106, 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, 123, 0, 0, 1260, 1261, 3, 144, 72, 0, 1261, 159, 1, 0, 0, 0, 1262, 1263, 5, 129, 0, 0, 1263, 1264, 3, 116, 58, 0, 1264, 1265, 5, 148, 0, 0, 1265, 161, 1, 0, 0, 0, 1266, 1269, 5, 111, 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, 143, 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, 145, 0, 0, 1278, 165, 1, 0, 0, 0, 1279, 1280, 5, 158, 0, 0, 1280, 1281, 3, 116, 58, 0, 1281, 1282, 5, 148, 0, 0, 1282, 1285, 1, 0, 0, 0, 1283, 1285, 5, 157, 0, 0, 1284, 1279, 1, 0, 0, 0, 1284, 1283, 1, 0, 0, 0, 1285, 167, 1, 0, 0, 0, 1286, 1290, 5, 144, 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, 160, 0, 0, 1296, 1297, 3, 116, 58, 0, 1297, 1298, 5, 148, 0, 0, 1298, 1301, 1, 0, 0, 0, 1299, 1301, 5, 159, 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 +[4, 1, 162, 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, 1, 0, 5, 0, 176, 8, 0, 10, 0, 12, 0, 179, 9, 0, 1, 0, 1, 0, 1, 1, 1, 1, 3, 1, 185, 8, 1, 1, 2, 1, 2, 1, 3, 1, 3, 1, 3, 1, 3, 1, 3, 3, 3, 194, 8, 3, 1, 4, 1, 4, 1, 4, 5, 4, 199, 8, 4, 10, 4, 12, 4, 202, 9, 4, 1, 4, 3, 4, 205, 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, 219, 8, 5, 1, 6, 1, 6, 3, 6, 223, 8, 6, 1, 6, 3, 6, 226, 8, 6, 1, 7, 1, 7, 3, 7, 230, 8, 7, 1, 7, 3, 7, 233, 8, 7, 1, 8, 1, 8, 1, 8, 1, 8, 1, 8, 3, 8, 240, 8, 8, 1, 8, 1, 8, 3, 8, 244, 8, 8, 1, 8, 1, 8, 1, 9, 1, 9, 1, 9, 5, 9, 251, 8, 9, 10, 9, 12, 9, 254, 9, 9, 1, 9, 1, 9, 3, 9, 258, 8, 9, 1, 10, 1, 10, 1, 10, 1, 10, 1, 10, 1, 10, 1, 10, 3, 10, 267, 8, 10, 1, 11, 1, 11, 1, 11, 1, 11, 1, 11, 1, 11, 3, 11, 275, 8, 11, 1, 12, 1, 12, 1, 12, 1, 12, 1, 12, 3, 12, 282, 8, 12, 1, 12, 1, 12, 3, 12, 286, 8, 12, 1, 12, 1, 12, 1, 12, 1, 12, 3, 12, 292, 8, 12, 1, 12, 1, 12, 1, 12, 3, 12, 297, 8, 12, 1, 13, 1, 13, 1, 13, 1, 13, 1, 13, 1, 13, 3, 13, 305, 8, 13, 1, 13, 1, 13, 1, 13, 1, 13, 1, 13, 3, 13, 312, 8, 13, 1, 14, 1, 14, 1, 14, 1, 14, 3, 14, 318, 8, 14, 1, 14, 1, 14, 1, 14, 1, 15, 1, 15, 1, 15, 1, 15, 1, 15, 1, 16, 1, 16, 3, 16, 330, 8, 16, 1, 17, 1, 17, 1, 18, 1, 18, 5, 18, 336, 8, 18, 10, 18, 12, 18, 339, 9, 18, 1, 18, 1, 18, 1, 19, 1, 19, 1, 19, 1, 19, 1, 20, 1, 20, 1, 20, 5, 20, 350, 8, 20, 10, 20, 12, 20, 353, 9, 20, 1, 20, 3, 20, 356, 8, 20, 1, 21, 1, 21, 1, 21, 3, 21, 361, 8, 21, 1, 21, 1, 21, 1, 22, 1, 22, 1, 22, 1, 22, 1, 22, 1, 22, 3, 22, 371, 8, 22, 1, 23, 1, 23, 1, 23, 1, 23, 3, 23, 377, 8, 23, 1, 23, 1, 23, 1, 24, 1, 24, 5, 24, 383, 8, 24, 10, 24, 12, 24, 386, 9, 24, 1, 25, 3, 25, 389, 8, 25, 1, 25, 1, 25, 3, 25, 393, 8, 25, 1, 25, 3, 25, 396, 8, 25, 1, 25, 1, 25, 3, 25, 400, 8, 25, 1, 25, 3, 25, 403, 8, 25, 1, 25, 3, 25, 406, 8, 25, 1, 25, 3, 25, 409, 8, 25, 1, 25, 3, 25, 412, 8, 25, 1, 25, 1, 25, 3, 25, 416, 8, 25, 1, 25, 1, 25, 3, 25, 420, 8, 25, 1, 25, 3, 25, 423, 8, 25, 1, 25, 3, 25, 426, 8, 25, 1, 25, 3, 25, 429, 8, 25, 1, 25, 1, 25, 3, 25, 433, 8, 25, 1, 25, 3, 25, 436, 8, 25, 1, 26, 1, 26, 1, 26, 1, 27, 1, 27, 1, 27, 1, 27, 3, 27, 445, 8, 27, 1, 28, 1, 28, 1, 28, 1, 29, 3, 29, 451, 8, 29, 1, 29, 1, 29, 1, 29, 1, 29, 1, 30, 1, 30, 1, 30, 1, 30, 1, 30, 1, 30, 1, 30, 1, 30, 1, 30, 1, 30, 1, 30, 1, 30, 1, 30, 5, 30, 470, 8, 30, 10, 30, 12, 30, 473, 9, 30, 1, 31, 1, 31, 1, 31, 1, 32, 1, 32, 1, 32, 1, 33, 1, 33, 1, 33, 1, 33, 1, 33, 1, 33, 1, 33, 1, 33, 3, 33, 489, 8, 33, 1, 34, 1, 34, 1, 34, 1, 35, 1, 35, 1, 35, 1, 35, 1, 36, 1, 36, 1, 36, 1, 36, 1, 37, 1, 37, 1, 37, 1, 37, 3, 37, 506, 8, 37, 1, 37, 1, 37, 1, 37, 1, 37, 3, 37, 512, 8, 37, 1, 37, 1, 37, 1, 37, 1, 37, 3, 37, 518, 8, 37, 1, 37, 1, 37, 1, 37, 1, 37, 1, 37, 1, 37, 1, 37, 1, 37, 1, 37, 3, 37, 529, 8, 37, 3, 37, 531, 8, 37, 1, 38, 1, 38, 1, 38, 1, 39, 1, 39, 1, 39, 1, 40, 1, 40, 1, 40, 3, 40, 542, 8, 40, 1, 40, 3, 40, 545, 8, 40, 1, 40, 1, 40, 1, 40, 1, 40, 3, 40, 551, 8, 40, 1, 40, 1, 40, 1, 40, 1, 40, 1, 40, 1, 40, 3, 40, 559, 8, 40, 1, 40, 1, 40, 1, 40, 1, 40, 5, 40, 565, 8, 40, 10, 40, 12, 40, 568, 9, 40, 1, 41, 3, 41, 571, 8, 41, 1, 41, 1, 41, 1, 41, 3, 41, 576, 8, 41, 1, 41, 3, 41, 579, 8, 41, 1, 41, 3, 41, 582, 8, 41, 1, 41, 1, 41, 3, 41, 586, 8, 41, 1, 41, 1, 41, 3, 41, 590, 8, 41, 1, 41, 3, 41, 593, 8, 41, 3, 41, 595, 8, 41, 1, 41, 3, 41, 598, 8, 41, 1, 41, 1, 41, 3, 41, 602, 8, 41, 1, 41, 1, 41, 3, 41, 606, 8, 41, 1, 41, 3, 41, 609, 8, 41, 3, 41, 611, 8, 41, 3, 41, 613, 8, 41, 1, 42, 1, 42, 1, 42, 3, 42, 618, 8, 42, 1, 43, 1, 43, 1, 43, 1, 43, 1, 43, 1, 43, 1, 43, 1, 43, 1, 43, 3, 43, 629, 8, 43, 1, 44, 1, 44, 1, 44, 1, 44, 3, 44, 635, 8, 44, 1, 45, 1, 45, 1, 45, 5, 45, 640, 8, 45, 10, 45, 12, 45, 643, 9, 45, 1, 46, 1, 46, 3, 46, 647, 8, 46, 1, 46, 1, 46, 3, 46, 651, 8, 46, 1, 46, 1, 46, 3, 46, 655, 8, 46, 1, 47, 1, 47, 1, 47, 1, 47, 3, 47, 661, 8, 47, 3, 47, 663, 8, 47, 1, 48, 1, 48, 1, 48, 5, 48, 668, 8, 48, 10, 48, 12, 48, 671, 9, 48, 1, 49, 1, 49, 1, 49, 1, 49, 1, 50, 3, 50, 678, 8, 50, 1, 50, 3, 50, 681, 8, 50, 1, 50, 3, 50, 684, 8, 50, 1, 51, 1, 51, 1, 51, 1, 51, 1, 52, 1, 52, 1, 52, 1, 52, 1, 53, 1, 53, 1, 53, 1, 54, 1, 54, 1, 54, 1, 54, 1, 54, 1, 54, 3, 54, 703, 8, 54, 1, 55, 1, 55, 1, 55, 1, 55, 1, 55, 1, 55, 1, 55, 1, 55, 1, 55, 1, 55, 1, 55, 1, 55, 3, 55, 717, 8, 55, 1, 56, 1, 56, 1, 56, 1, 57, 1, 57, 1, 57, 1, 57, 1, 57, 1, 57, 1, 57, 1, 57, 1, 57, 5, 57, 731, 8, 57, 10, 57, 12, 57, 734, 9, 57, 1, 57, 3, 57, 737, 8, 57, 1, 57, 1, 57, 1, 57, 1, 57, 1, 57, 1, 57, 1, 57, 5, 57, 746, 8, 57, 10, 57, 12, 57, 749, 9, 57, 1, 57, 3, 57, 752, 8, 57, 1, 57, 1, 57, 1, 57, 1, 57, 1, 57, 1, 57, 1, 57, 5, 57, 761, 8, 57, 10, 57, 12, 57, 764, 9, 57, 1, 57, 3, 57, 767, 8, 57, 1, 57, 1, 57, 1, 57, 1, 57, 1, 57, 3, 57, 774, 8, 57, 1, 57, 1, 57, 3, 57, 778, 8, 57, 1, 58, 1, 58, 1, 58, 5, 58, 783, 8, 58, 10, 58, 12, 58, 786, 9, 58, 1, 58, 3, 58, 789, 8, 58, 1, 59, 1, 59, 1, 59, 3, 59, 794, 8, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 4, 59, 801, 8, 59, 11, 59, 12, 59, 802, 1, 59, 1, 59, 3, 59, 807, 8, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 3, 59, 831, 8, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 3, 59, 848, 8, 59, 1, 59, 1, 59, 1, 59, 1, 59, 3, 59, 854, 8, 59, 1, 59, 3, 59, 857, 8, 59, 1, 59, 3, 59, 860, 8, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 3, 59, 870, 8, 59, 1, 59, 1, 59, 1, 59, 1, 59, 3, 59, 876, 8, 59, 1, 59, 3, 59, 879, 8, 59, 1, 59, 3, 59, 882, 8, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 3, 59, 890, 8, 59, 1, 59, 3, 59, 893, 8, 59, 1, 59, 1, 59, 3, 59, 897, 8, 59, 1, 59, 3, 59, 900, 8, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 3, 59, 914, 8, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 3, 59, 931, 8, 59, 1, 59, 1, 59, 1, 59, 3, 59, 936, 8, 59, 1, 59, 1, 59, 1, 59, 3, 59, 941, 8, 59, 1, 59, 1, 59, 1, 59, 1, 59, 3, 59, 947, 8, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 3, 59, 954, 8, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 3, 59, 966, 8, 59, 1, 59, 1, 59, 3, 59, 970, 8, 59, 1, 59, 3, 59, 973, 8, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 3, 59, 982, 8, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 3, 59, 996, 8, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 3, 59, 1012, 8, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 3, 59, 1041, 8, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 3, 59, 1049, 8, 59, 5, 59, 1051, 8, 59, 10, 59, 12, 59, 1054, 9, 59, 1, 60, 1, 60, 1, 60, 1, 60, 5, 60, 1060, 8, 60, 10, 60, 12, 60, 1063, 9, 60, 1, 60, 3, 60, 1066, 8, 60, 1, 60, 1, 60, 1, 60, 1, 60, 1, 60, 5, 60, 1073, 8, 60, 10, 60, 12, 60, 1076, 9, 60, 1, 60, 3, 60, 1079, 8, 60, 1, 60, 1, 60, 3, 60, 1083, 8, 60, 1, 60, 1, 60, 1, 60, 3, 60, 1088, 8, 60, 1, 61, 1, 61, 1, 61, 5, 61, 1093, 8, 61, 10, 61, 12, 61, 1096, 9, 61, 1, 61, 1, 61, 1, 61, 1, 61, 1, 61, 1, 61, 5, 61, 1104, 8, 61, 10, 61, 12, 61, 1107, 9, 61, 1, 61, 1, 61, 1, 61, 1, 61, 1, 61, 1, 61, 3, 61, 1115, 8, 61, 1, 61, 1, 61, 1, 61, 1, 61, 1, 61, 3, 61, 1122, 8, 61, 1, 62, 1, 62, 1, 62, 1, 62, 1, 62, 1, 62, 1, 62, 1, 62, 1, 62, 1, 62, 1, 62, 3, 62, 1135, 8, 62, 1, 63, 1, 63, 1, 63, 5, 63, 1140, 8, 63, 10, 63, 12, 63, 1143, 9, 63, 1, 63, 3, 63, 1146, 8, 63, 1, 64, 1, 64, 1, 64, 1, 64, 1, 64, 1, 64, 1, 64, 1, 64, 1, 64, 1, 64, 3, 64, 1158, 8, 64, 1, 65, 1, 65, 1, 65, 1, 65, 3, 65, 1164, 8, 65, 1, 65, 3, 65, 1167, 8, 65, 1, 66, 1, 66, 1, 66, 5, 66, 1172, 8, 66, 10, 66, 12, 66, 1175, 9, 66, 1, 67, 1, 67, 1, 67, 1, 67, 1, 67, 1, 67, 1, 67, 1, 67, 1, 67, 3, 67, 1186, 8, 67, 1, 67, 1, 67, 1, 67, 1, 67, 3, 67, 1192, 8, 67, 5, 67, 1194, 8, 67, 10, 67, 12, 67, 1197, 9, 67, 1, 68, 1, 68, 1, 68, 3, 68, 1202, 8, 68, 1, 68, 1, 68, 1, 69, 1, 69, 1, 69, 3, 69, 1209, 8, 69, 1, 69, 1, 69, 1, 70, 1, 70, 1, 70, 5, 70, 1216, 8, 70, 10, 70, 12, 70, 1219, 9, 70, 1, 70, 3, 70, 1222, 8, 70, 1, 71, 1, 71, 1, 72, 1, 72, 1, 72, 1, 72, 1, 72, 1, 72, 3, 72, 1232, 8, 72, 3, 72, 1234, 8, 72, 1, 73, 3, 73, 1237, 8, 73, 1, 73, 1, 73, 1, 73, 1, 73, 1, 73, 1, 73, 3, 73, 1245, 8, 73, 1, 74, 1, 74, 1, 74, 3, 74, 1250, 8, 74, 1, 75, 1, 75, 1, 76, 1, 76, 1, 77, 1, 77, 1, 78, 1, 78, 3, 78, 1260, 8, 78, 1, 79, 1, 79, 1, 79, 3, 79, 1265, 8, 79, 1, 80, 1, 80, 1, 80, 1, 80, 1, 81, 1, 81, 1, 81, 1, 81, 1, 82, 1, 82, 3, 82, 1277, 8, 82, 1, 83, 1, 83, 5, 83, 1281, 8, 83, 10, 83, 12, 83, 1284, 9, 83, 1, 83, 1, 83, 1, 84, 1, 84, 1, 84, 1, 84, 1, 84, 3, 84, 1293, 8, 84, 1, 85, 1, 85, 5, 85, 1297, 8, 85, 10, 85, 12, 85, 1300, 9, 85, 1, 85, 1, 85, 1, 86, 1, 86, 1, 86, 1, 86, 1, 86, 3, 86, 1309, 8, 86, 1, 86, 0, 3, 80, 118, 134, 87, 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, 0, 17, 2, 0, 32, 32, 37, 37, 2, 0, 18, 18, 77, 77, 2, 0, 46, 46, 54, 54, 3, 0, 1, 1, 4, 4, 8, 8, 4, 0, 1, 1, 3, 4, 8, 8, 83, 83, 2, 0, 54, 54, 76, 76, 2, 0, 1, 1, 4, 4, 2, 0, 7, 7, 22, 23, 2, 0, 31, 31, 52, 52, 2, 0, 74, 74, 79, 79, 3, 0, 10, 10, 53, 53, 93, 93, 2, 0, 43, 43, 56, 56, 1, 0, 110, 111, 2, 0, 121, 121, 142, 142, 7, 0, 21, 21, 40, 40, 58, 59, 73, 73, 81, 81, 100, 100, 106, 106, 19, 0, 1, 13, 15, 20, 22, 26, 28, 29, 31, 31, 33, 36, 38, 39, 41, 44, 46, 46, 48, 54, 56, 57, 61, 61, 63, 72, 74, 80, 82, 86, 88, 95, 97, 99, 101, 102, 104, 105, 4, 0, 20, 20, 31, 31, 41, 41, 51, 51, 1484, 0, 177, 1, 0, 0, 0, 2, 184, 1, 0, 0, 0, 4, 186, 1, 0, 0, 0, 6, 188, 1, 0, 0, 0, 8, 195, 1, 0, 0, 0, 10, 218, 1, 0, 0, 0, 12, 220, 1, 0, 0, 0, 14, 227, 1, 0, 0, 0, 16, 234, 1, 0, 0, 0, 18, 247, 1, 0, 0, 0, 20, 259, 1, 0, 0, 0, 22, 268, 1, 0, 0, 0, 24, 276, 1, 0, 0, 0, 26, 298, 1, 0, 0, 0, 28, 313, 1, 0, 0, 0, 30, 322, 1, 0, 0, 0, 32, 327, 1, 0, 0, 0, 34, 331, 1, 0, 0, 0, 36, 333, 1, 0, 0, 0, 38, 342, 1, 0, 0, 0, 40, 346, 1, 0, 0, 0, 42, 360, 1, 0, 0, 0, 44, 370, 1, 0, 0, 0, 46, 376, 1, 0, 0, 0, 48, 380, 1, 0, 0, 0, 50, 388, 1, 0, 0, 0, 52, 437, 1, 0, 0, 0, 54, 440, 1, 0, 0, 0, 56, 446, 1, 0, 0, 0, 58, 450, 1, 0, 0, 0, 60, 456, 1, 0, 0, 0, 62, 474, 1, 0, 0, 0, 64, 477, 1, 0, 0, 0, 66, 480, 1, 0, 0, 0, 68, 490, 1, 0, 0, 0, 70, 493, 1, 0, 0, 0, 72, 497, 1, 0, 0, 0, 74, 530, 1, 0, 0, 0, 76, 532, 1, 0, 0, 0, 78, 535, 1, 0, 0, 0, 80, 550, 1, 0, 0, 0, 82, 612, 1, 0, 0, 0, 84, 617, 1, 0, 0, 0, 86, 628, 1, 0, 0, 0, 88, 630, 1, 0, 0, 0, 90, 636, 1, 0, 0, 0, 92, 644, 1, 0, 0, 0, 94, 662, 1, 0, 0, 0, 96, 664, 1, 0, 0, 0, 98, 672, 1, 0, 0, 0, 100, 677, 1, 0, 0, 0, 102, 685, 1, 0, 0, 0, 104, 689, 1, 0, 0, 0, 106, 693, 1, 0, 0, 0, 108, 702, 1, 0, 0, 0, 110, 716, 1, 0, 0, 0, 112, 718, 1, 0, 0, 0, 114, 777, 1, 0, 0, 0, 116, 779, 1, 0, 0, 0, 118, 940, 1, 0, 0, 0, 120, 1082, 1, 0, 0, 0, 122, 1121, 1, 0, 0, 0, 124, 1134, 1, 0, 0, 0, 126, 1136, 1, 0, 0, 0, 128, 1157, 1, 0, 0, 0, 130, 1166, 1, 0, 0, 0, 132, 1168, 1, 0, 0, 0, 134, 1185, 1, 0, 0, 0, 136, 1198, 1, 0, 0, 0, 138, 1208, 1, 0, 0, 0, 140, 1212, 1, 0, 0, 0, 142, 1223, 1, 0, 0, 0, 144, 1233, 1, 0, 0, 0, 146, 1236, 1, 0, 0, 0, 148, 1249, 1, 0, 0, 0, 150, 1251, 1, 0, 0, 0, 152, 1253, 1, 0, 0, 0, 154, 1255, 1, 0, 0, 0, 156, 1259, 1, 0, 0, 0, 158, 1264, 1, 0, 0, 0, 160, 1266, 1, 0, 0, 0, 162, 1270, 1, 0, 0, 0, 164, 1276, 1, 0, 0, 0, 166, 1278, 1, 0, 0, 0, 168, 1292, 1, 0, 0, 0, 170, 1294, 1, 0, 0, 0, 172, 1308, 1, 0, 0, 0, 174, 176, 3, 2, 1, 0, 175, 174, 1, 0, 0, 0, 176, 179, 1, 0, 0, 0, 177, 175, 1, 0, 0, 0, 177, 178, 1, 0, 0, 0, 178, 180, 1, 0, 0, 0, 179, 177, 1, 0, 0, 0, 180, 181, 5, 0, 0, 1, 181, 1, 1, 0, 0, 0, 182, 185, 3, 6, 3, 0, 183, 185, 3, 10, 5, 0, 184, 182, 1, 0, 0, 0, 184, 183, 1, 0, 0, 0, 185, 3, 1, 0, 0, 0, 186, 187, 3, 118, 59, 0, 187, 5, 1, 0, 0, 0, 188, 189, 5, 55, 0, 0, 189, 193, 3, 158, 79, 0, 190, 191, 5, 118, 0, 0, 191, 192, 5, 125, 0, 0, 192, 194, 3, 4, 2, 0, 193, 190, 1, 0, 0, 0, 193, 194, 1, 0, 0, 0, 194, 7, 1, 0, 0, 0, 195, 200, 3, 158, 79, 0, 196, 197, 5, 119, 0, 0, 197, 199, 3, 158, 79, 0, 198, 196, 1, 0, 0, 0, 199, 202, 1, 0, 0, 0, 200, 198, 1, 0, 0, 0, 200, 201, 1, 0, 0, 0, 201, 204, 1, 0, 0, 0, 202, 200, 1, 0, 0, 0, 203, 205, 5, 119, 0, 0, 204, 203, 1, 0, 0, 0, 204, 205, 1, 0, 0, 0, 205, 9, 1, 0, 0, 0, 206, 219, 3, 12, 6, 0, 207, 219, 3, 14, 7, 0, 208, 219, 3, 18, 9, 0, 209, 219, 3, 20, 10, 0, 210, 219, 3, 22, 11, 0, 211, 219, 3, 26, 13, 0, 212, 219, 3, 24, 12, 0, 213, 219, 3, 28, 14, 0, 214, 219, 3, 30, 15, 0, 215, 219, 3, 36, 18, 0, 216, 219, 3, 32, 16, 0, 217, 219, 3, 34, 17, 0, 218, 206, 1, 0, 0, 0, 218, 207, 1, 0, 0, 0, 218, 208, 1, 0, 0, 0, 218, 209, 1, 0, 0, 0, 218, 210, 1, 0, 0, 0, 218, 211, 1, 0, 0, 0, 218, 212, 1, 0, 0, 0, 218, 213, 1, 0, 0, 0, 218, 214, 1, 0, 0, 0, 218, 215, 1, 0, 0, 0, 218, 216, 1, 0, 0, 0, 218, 217, 1, 0, 0, 0, 219, 11, 1, 0, 0, 0, 220, 222, 5, 75, 0, 0, 221, 223, 3, 4, 2, 0, 222, 221, 1, 0, 0, 0, 222, 223, 1, 0, 0, 0, 223, 225, 1, 0, 0, 0, 224, 226, 5, 153, 0, 0, 225, 224, 1, 0, 0, 0, 225, 226, 1, 0, 0, 0, 226, 13, 1, 0, 0, 0, 227, 229, 5, 87, 0, 0, 228, 230, 3, 4, 2, 0, 229, 228, 1, 0, 0, 0, 229, 230, 1, 0, 0, 0, 230, 232, 1, 0, 0, 0, 231, 233, 5, 153, 0, 0, 232, 231, 1, 0, 0, 0, 232, 233, 1, 0, 0, 0, 233, 15, 1, 0, 0, 0, 234, 243, 5, 14, 0, 0, 235, 236, 5, 133, 0, 0, 236, 239, 3, 158, 79, 0, 237, 238, 5, 118, 0, 0, 238, 240, 3, 158, 79, 0, 239, 237, 1, 0, 0, 0, 239, 240, 1, 0, 0, 0, 240, 241, 1, 0, 0, 0, 241, 242, 5, 152, 0, 0, 242, 244, 1, 0, 0, 0, 243, 235, 1, 0, 0, 0, 243, 244, 1, 0, 0, 0, 244, 245, 1, 0, 0, 0, 245, 246, 3, 36, 18, 0, 246, 17, 1, 0, 0, 0, 247, 248, 5, 96, 0, 0, 248, 252, 3, 36, 18, 0, 249, 251, 3, 16, 8, 0, 250, 249, 1, 0, 0, 0, 251, 254, 1, 0, 0, 0, 252, 250, 1, 0, 0, 0, 252, 253, 1, 0, 0, 0, 253, 257, 1, 0, 0, 0, 254, 252, 1, 0, 0, 0, 255, 256, 5, 30, 0, 0, 256, 258, 3, 36, 18, 0, 257, 255, 1, 0, 0, 0, 257, 258, 1, 0, 0, 0, 258, 19, 1, 0, 0, 0, 259, 260, 5, 42, 0, 0, 260, 261, 5, 133, 0, 0, 261, 262, 3, 4, 2, 0, 262, 263, 5, 152, 0, 0, 263, 266, 3, 10, 5, 0, 264, 265, 5, 25, 0, 0, 265, 267, 3, 10, 5, 0, 266, 264, 1, 0, 0, 0, 266, 267, 1, 0, 0, 0, 267, 21, 1, 0, 0, 0, 268, 269, 5, 103, 0, 0, 269, 270, 5, 133, 0, 0, 270, 271, 3, 4, 2, 0, 271, 272, 5, 152, 0, 0, 272, 274, 3, 10, 5, 0, 273, 275, 5, 153, 0, 0, 274, 273, 1, 0, 0, 0, 274, 275, 1, 0, 0, 0, 275, 23, 1, 0, 0, 0, 276, 277, 5, 34, 0, 0, 277, 281, 5, 133, 0, 0, 278, 282, 3, 6, 3, 0, 279, 282, 3, 30, 15, 0, 280, 282, 3, 4, 2, 0, 281, 278, 1, 0, 0, 0, 281, 279, 1, 0, 0, 0, 281, 280, 1, 0, 0, 0, 281, 282, 1, 0, 0, 0, 282, 283, 1, 0, 0, 0, 283, 285, 5, 153, 0, 0, 284, 286, 3, 4, 2, 0, 285, 284, 1, 0, 0, 0, 285, 286, 1, 0, 0, 0, 286, 287, 1, 0, 0, 0, 287, 291, 5, 153, 0, 0, 288, 292, 3, 6, 3, 0, 289, 292, 3, 30, 15, 0, 290, 292, 3, 4, 2, 0, 291, 288, 1, 0, 0, 0, 291, 289, 1, 0, 0, 0, 291, 290, 1, 0, 0, 0, 291, 292, 1, 0, 0, 0, 292, 293, 1, 0, 0, 0, 293, 294, 5, 152, 0, 0, 294, 296, 3, 10, 5, 0, 295, 297, 5, 153, 0, 0, 296, 295, 1, 0, 0, 0, 296, 297, 1, 0, 0, 0, 297, 25, 1, 0, 0, 0, 298, 299, 5, 34, 0, 0, 299, 300, 5, 133, 0, 0, 300, 301, 5, 55, 0, 0, 301, 304, 3, 158, 79, 0, 302, 303, 5, 119, 0, 0, 303, 305, 3, 158, 79, 0, 304, 302, 1, 0, 0, 0, 304, 305, 1, 0, 0, 0, 305, 306, 1, 0, 0, 0, 306, 307, 5, 44, 0, 0, 307, 308, 3, 4, 2, 0, 308, 309, 5, 152, 0, 0, 309, 311, 3, 10, 5, 0, 310, 312, 5, 153, 0, 0, 311, 310, 1, 0, 0, 0, 311, 312, 1, 0, 0, 0, 312, 27, 1, 0, 0, 0, 313, 314, 7, 0, 0, 0, 314, 315, 3, 158, 79, 0, 315, 317, 5, 133, 0, 0, 316, 318, 3, 8, 4, 0, 317, 316, 1, 0, 0, 0, 317, 318, 1, 0, 0, 0, 318, 319, 1, 0, 0, 0, 319, 320, 5, 152, 0, 0, 320, 321, 3, 36, 18, 0, 321, 29, 1, 0, 0, 0, 322, 323, 3, 4, 2, 0, 323, 324, 5, 118, 0, 0, 324, 325, 5, 125, 0, 0, 325, 326, 3, 4, 2, 0, 326, 31, 1, 0, 0, 0, 327, 329, 3, 4, 2, 0, 328, 330, 5, 153, 0, 0, 329, 328, 1, 0, 0, 0, 329, 330, 1, 0, 0, 0, 330, 33, 1, 0, 0, 0, 331, 332, 5, 153, 0, 0, 332, 35, 1, 0, 0, 0, 333, 337, 5, 131, 0, 0, 334, 336, 3, 2, 1, 0, 335, 334, 1, 0, 0, 0, 336, 339, 1, 0, 0, 0, 337, 335, 1, 0, 0, 0, 337, 338, 1, 0, 0, 0, 338, 340, 1, 0, 0, 0, 339, 337, 1, 0, 0, 0, 340, 341, 5, 150, 0, 0, 341, 37, 1, 0, 0, 0, 342, 343, 3, 4, 2, 0, 343, 344, 5, 118, 0, 0, 344, 345, 3, 4, 2, 0, 345, 39, 1, 0, 0, 0, 346, 351, 3, 38, 19, 0, 347, 348, 5, 119, 0, 0, 348, 350, 3, 38, 19, 0, 349, 347, 1, 0, 0, 0, 350, 353, 1, 0, 0, 0, 351, 349, 1, 0, 0, 0, 351, 352, 1, 0, 0, 0, 352, 355, 1, 0, 0, 0, 353, 351, 1, 0, 0, 0, 354, 356, 5, 119, 0, 0, 355, 354, 1, 0, 0, 0, 355, 356, 1, 0, 0, 0, 356, 41, 1, 0, 0, 0, 357, 361, 3, 48, 24, 0, 358, 361, 3, 50, 25, 0, 359, 361, 3, 122, 61, 0, 360, 357, 1, 0, 0, 0, 360, 358, 1, 0, 0, 0, 360, 359, 1, 0, 0, 0, 361, 362, 1, 0, 0, 0, 362, 363, 5, 0, 0, 1, 363, 43, 1, 0, 0, 0, 364, 371, 3, 50, 25, 0, 365, 366, 5, 133, 0, 0, 366, 367, 3, 48, 24, 0, 367, 368, 5, 152, 0, 0, 368, 371, 1, 0, 0, 0, 369, 371, 3, 162, 81, 0, 370, 364, 1, 0, 0, 0, 370, 365, 1, 0, 0, 0, 370, 369, 1, 0, 0, 0, 371, 45, 1, 0, 0, 0, 372, 377, 5, 27, 0, 0, 373, 374, 5, 98, 0, 0, 374, 377, 5, 1, 0, 0, 375, 377, 5, 47, 0, 0, 376, 372, 1, 0, 0, 0, 376, 373, 1, 0, 0, 0, 376, 375, 1, 0, 0, 0, 377, 378, 1, 0, 0, 0, 378, 379, 3, 44, 22, 0, 379, 47, 1, 0, 0, 0, 380, 384, 3, 44, 22, 0, 381, 383, 3, 46, 23, 0, 382, 381, 1, 0, 0, 0, 383, 386, 1, 0, 0, 0, 384, 382, 1, 0, 0, 0, 384, 385, 1, 0, 0, 0, 385, 49, 1, 0, 0, 0, 386, 384, 1, 0, 0, 0, 387, 389, 3, 52, 26, 0, 388, 387, 1, 0, 0, 0, 388, 389, 1, 0, 0, 0, 389, 390, 1, 0, 0, 0, 390, 392, 5, 82, 0, 0, 391, 393, 5, 24, 0, 0, 392, 391, 1, 0, 0, 0, 392, 393, 1, 0, 0, 0, 393, 395, 1, 0, 0, 0, 394, 396, 3, 54, 27, 0, 395, 394, 1, 0, 0, 0, 395, 396, 1, 0, 0, 0, 396, 397, 1, 0, 0, 0, 397, 399, 3, 116, 58, 0, 398, 400, 3, 56, 28, 0, 399, 398, 1, 0, 0, 0, 399, 400, 1, 0, 0, 0, 400, 402, 1, 0, 0, 0, 401, 403, 3, 58, 29, 0, 402, 401, 1, 0, 0, 0, 402, 403, 1, 0, 0, 0, 403, 405, 1, 0, 0, 0, 404, 406, 3, 62, 31, 0, 405, 404, 1, 0, 0, 0, 405, 406, 1, 0, 0, 0, 406, 408, 1, 0, 0, 0, 407, 409, 3, 64, 32, 0, 408, 407, 1, 0, 0, 0, 408, 409, 1, 0, 0, 0, 409, 411, 1, 0, 0, 0, 410, 412, 3, 66, 33, 0, 411, 410, 1, 0, 0, 0, 411, 412, 1, 0, 0, 0, 412, 415, 1, 0, 0, 0, 413, 414, 5, 105, 0, 0, 414, 416, 7, 1, 0, 0, 415, 413, 1, 0, 0, 0, 415, 416, 1, 0, 0, 0, 416, 419, 1, 0, 0, 0, 417, 418, 5, 105, 0, 0, 418, 420, 5, 92, 0, 0, 419, 417, 1, 0, 0, 0, 419, 420, 1, 0, 0, 0, 420, 422, 1, 0, 0, 0, 421, 423, 3, 68, 34, 0, 422, 421, 1, 0, 0, 0, 422, 423, 1, 0, 0, 0, 423, 425, 1, 0, 0, 0, 424, 426, 3, 60, 30, 0, 425, 424, 1, 0, 0, 0, 425, 426, 1, 0, 0, 0, 426, 428, 1, 0, 0, 0, 427, 429, 3, 70, 35, 0, 428, 427, 1, 0, 0, 0, 428, 429, 1, 0, 0, 0, 429, 432, 1, 0, 0, 0, 430, 433, 3, 74, 37, 0, 431, 433, 3, 76, 38, 0, 432, 430, 1, 0, 0, 0, 432, 431, 1, 0, 0, 0, 432, 433, 1, 0, 0, 0, 433, 435, 1, 0, 0, 0, 434, 436, 3, 78, 39, 0, 435, 434, 1, 0, 0, 0, 435, 436, 1, 0, 0, 0, 436, 51, 1, 0, 0, 0, 437, 438, 5, 105, 0, 0, 438, 439, 3, 126, 63, 0, 439, 53, 1, 0, 0, 0, 440, 441, 5, 91, 0, 0, 441, 444, 5, 111, 0, 0, 442, 443, 5, 105, 0, 0, 443, 445, 5, 88, 0, 0, 444, 442, 1, 0, 0, 0, 444, 445, 1, 0, 0, 0, 445, 55, 1, 0, 0, 0, 446, 447, 5, 35, 0, 0, 447, 448, 3, 80, 40, 0, 448, 57, 1, 0, 0, 0, 449, 451, 7, 2, 0, 0, 450, 449, 1, 0, 0, 0, 450, 451, 1, 0, 0, 0, 451, 452, 1, 0, 0, 0, 452, 453, 5, 5, 0, 0, 453, 454, 5, 50, 0, 0, 454, 455, 3, 116, 58, 0, 455, 59, 1, 0, 0, 0, 456, 457, 5, 104, 0, 0, 457, 458, 3, 158, 79, 0, 458, 459, 5, 6, 0, 0, 459, 460, 5, 133, 0, 0, 460, 461, 3, 100, 50, 0, 461, 471, 5, 152, 0, 0, 462, 463, 5, 119, 0, 0, 463, 464, 3, 158, 79, 0, 464, 465, 5, 6, 0, 0, 465, 466, 5, 133, 0, 0, 466, 467, 3, 100, 50, 0, 467, 468, 5, 152, 0, 0, 468, 470, 1, 0, 0, 0, 469, 462, 1, 0, 0, 0, 470, 473, 1, 0, 0, 0, 471, 469, 1, 0, 0, 0, 471, 472, 1, 0, 0, 0, 472, 61, 1, 0, 0, 0, 473, 471, 1, 0, 0, 0, 474, 475, 5, 72, 0, 0, 475, 476, 3, 118, 59, 0, 476, 63, 1, 0, 0, 0, 477, 478, 5, 102, 0, 0, 478, 479, 3, 118, 59, 0, 479, 65, 1, 0, 0, 0, 480, 481, 5, 38, 0, 0, 481, 488, 5, 11, 0, 0, 482, 483, 7, 1, 0, 0, 483, 484, 5, 133, 0, 0, 484, 485, 3, 116, 58, 0, 485, 486, 5, 152, 0, 0, 486, 489, 1, 0, 0, 0, 487, 489, 3, 116, 58, 0, 488, 482, 1, 0, 0, 0, 488, 487, 1, 0, 0, 0, 489, 67, 1, 0, 0, 0, 490, 491, 5, 39, 0, 0, 491, 492, 3, 118, 59, 0, 492, 69, 1, 0, 0, 0, 493, 494, 5, 67, 0, 0, 494, 495, 5, 11, 0, 0, 495, 496, 3, 90, 45, 0, 496, 71, 1, 0, 0, 0, 497, 498, 5, 67, 0, 0, 498, 499, 5, 11, 0, 0, 499, 500, 3, 116, 58, 0, 500, 73, 1, 0, 0, 0, 501, 502, 5, 57, 0, 0, 502, 505, 3, 118, 59, 0, 503, 504, 5, 119, 0, 0, 504, 506, 3, 118, 59, 0, 505, 503, 1, 0, 0, 0, 505, 506, 1, 0, 0, 0, 506, 511, 1, 0, 0, 0, 507, 508, 5, 105, 0, 0, 508, 512, 5, 88, 0, 0, 509, 510, 5, 11, 0, 0, 510, 512, 3, 116, 58, 0, 511, 507, 1, 0, 0, 0, 511, 509, 1, 0, 0, 0, 511, 512, 1, 0, 0, 0, 512, 531, 1, 0, 0, 0, 513, 514, 5, 57, 0, 0, 514, 517, 3, 118, 59, 0, 515, 516, 5, 105, 0, 0, 516, 518, 5, 88, 0, 0, 517, 515, 1, 0, 0, 0, 517, 518, 1, 0, 0, 0, 518, 519, 1, 0, 0, 0, 519, 520, 5, 64, 0, 0, 520, 521, 3, 118, 59, 0, 521, 531, 1, 0, 0, 0, 522, 523, 5, 57, 0, 0, 523, 524, 3, 118, 59, 0, 524, 525, 5, 64, 0, 0, 525, 528, 3, 118, 59, 0, 526, 527, 5, 11, 0, 0, 527, 529, 3, 116, 58, 0, 528, 526, 1, 0, 0, 0, 528, 529, 1, 0, 0, 0, 529, 531, 1, 0, 0, 0, 530, 501, 1, 0, 0, 0, 530, 513, 1, 0, 0, 0, 530, 522, 1, 0, 0, 0, 531, 75, 1, 0, 0, 0, 532, 533, 5, 64, 0, 0, 533, 534, 3, 118, 59, 0, 534, 77, 1, 0, 0, 0, 535, 536, 5, 84, 0, 0, 536, 537, 3, 96, 48, 0, 537, 79, 1, 0, 0, 0, 538, 539, 6, 40, -1, 0, 539, 541, 3, 134, 67, 0, 540, 542, 5, 29, 0, 0, 541, 540, 1, 0, 0, 0, 541, 542, 1, 0, 0, 0, 542, 544, 1, 0, 0, 0, 543, 545, 3, 88, 44, 0, 544, 543, 1, 0, 0, 0, 544, 545, 1, 0, 0, 0, 545, 551, 1, 0, 0, 0, 546, 547, 5, 133, 0, 0, 547, 548, 3, 80, 40, 0, 548, 549, 5, 152, 0, 0, 549, 551, 1, 0, 0, 0, 550, 538, 1, 0, 0, 0, 550, 546, 1, 0, 0, 0, 551, 566, 1, 0, 0, 0, 552, 553, 10, 3, 0, 0, 553, 554, 3, 84, 42, 0, 554, 555, 3, 80, 40, 4, 555, 565, 1, 0, 0, 0, 556, 558, 10, 4, 0, 0, 557, 559, 3, 82, 41, 0, 558, 557, 1, 0, 0, 0, 558, 559, 1, 0, 0, 0, 559, 560, 1, 0, 0, 0, 560, 561, 5, 50, 0, 0, 561, 562, 3, 80, 40, 0, 562, 563, 3, 86, 43, 0, 563, 565, 1, 0, 0, 0, 564, 552, 1, 0, 0, 0, 564, 556, 1, 0, 0, 0, 565, 568, 1, 0, 0, 0, 566, 564, 1, 0, 0, 0, 566, 567, 1, 0, 0, 0, 567, 81, 1, 0, 0, 0, 568, 566, 1, 0, 0, 0, 569, 571, 7, 3, 0, 0, 570, 569, 1, 0, 0, 0, 570, 571, 1, 0, 0, 0, 571, 572, 1, 0, 0, 0, 572, 579, 5, 46, 0, 0, 573, 575, 5, 46, 0, 0, 574, 576, 7, 3, 0, 0, 575, 574, 1, 0, 0, 0, 575, 576, 1, 0, 0, 0, 576, 579, 1, 0, 0, 0, 577, 579, 7, 3, 0, 0, 578, 570, 1, 0, 0, 0, 578, 573, 1, 0, 0, 0, 578, 577, 1, 0, 0, 0, 579, 613, 1, 0, 0, 0, 580, 582, 7, 4, 0, 0, 581, 580, 1, 0, 0, 0, 581, 582, 1, 0, 0, 0, 582, 583, 1, 0, 0, 0, 583, 585, 7, 5, 0, 0, 584, 586, 5, 68, 0, 0, 585, 584, 1, 0, 0, 0, 585, 586, 1, 0, 0, 0, 586, 595, 1, 0, 0, 0, 587, 589, 7, 5, 0, 0, 588, 590, 5, 68, 0, 0, 589, 588, 1, 0, 0, 0, 589, 590, 1, 0, 0, 0, 590, 592, 1, 0, 0, 0, 591, 593, 7, 4, 0, 0, 592, 591, 1, 0, 0, 0, 592, 593, 1, 0, 0, 0, 593, 595, 1, 0, 0, 0, 594, 581, 1, 0, 0, 0, 594, 587, 1, 0, 0, 0, 595, 613, 1, 0, 0, 0, 596, 598, 7, 6, 0, 0, 597, 596, 1, 0, 0, 0, 597, 598, 1, 0, 0, 0, 598, 599, 1, 0, 0, 0, 599, 601, 5, 36, 0, 0, 600, 602, 5, 68, 0, 0, 601, 600, 1, 0, 0, 0, 601, 602, 1, 0, 0, 0, 602, 611, 1, 0, 0, 0, 603, 605, 5, 36, 0, 0, 604, 606, 5, 68, 0, 0, 605, 604, 1, 0, 0, 0, 605, 606, 1, 0, 0, 0, 606, 608, 1, 0, 0, 0, 607, 609, 7, 6, 0, 0, 608, 607, 1, 0, 0, 0, 608, 609, 1, 0, 0, 0, 609, 611, 1, 0, 0, 0, 610, 597, 1, 0, 0, 0, 610, 603, 1, 0, 0, 0, 611, 613, 1, 0, 0, 0, 612, 578, 1, 0, 0, 0, 612, 594, 1, 0, 0, 0, 612, 610, 1, 0, 0, 0, 613, 83, 1, 0, 0, 0, 614, 615, 5, 17, 0, 0, 615, 618, 5, 50, 0, 0, 616, 618, 5, 119, 0, 0, 617, 614, 1, 0, 0, 0, 617, 616, 1, 0, 0, 0, 618, 85, 1, 0, 0, 0, 619, 620, 5, 65, 0, 0, 620, 629, 3, 116, 58, 0, 621, 622, 5, 99, 0, 0, 622, 623, 5, 133, 0, 0, 623, 624, 3, 116, 58, 0, 624, 625, 5, 152, 0, 0, 625, 629, 1, 0, 0, 0, 626, 627, 5, 99, 0, 0, 627, 629, 3, 116, 58, 0, 628, 619, 1, 0, 0, 0, 628, 621, 1, 0, 0, 0, 628, 626, 1, 0, 0, 0, 629, 87, 1, 0, 0, 0, 630, 631, 5, 80, 0, 0, 631, 634, 3, 94, 47, 0, 632, 633, 5, 64, 0, 0, 633, 635, 3, 94, 47, 0, 634, 632, 1, 0, 0, 0, 634, 635, 1, 0, 0, 0, 635, 89, 1, 0, 0, 0, 636, 641, 3, 92, 46, 0, 637, 638, 5, 119, 0, 0, 638, 640, 3, 92, 46, 0, 639, 637, 1, 0, 0, 0, 640, 643, 1, 0, 0, 0, 641, 639, 1, 0, 0, 0, 641, 642, 1, 0, 0, 0, 642, 91, 1, 0, 0, 0, 643, 641, 1, 0, 0, 0, 644, 646, 3, 118, 59, 0, 645, 647, 7, 7, 0, 0, 646, 645, 1, 0, 0, 0, 646, 647, 1, 0, 0, 0, 647, 650, 1, 0, 0, 0, 648, 649, 5, 63, 0, 0, 649, 651, 7, 8, 0, 0, 650, 648, 1, 0, 0, 0, 650, 651, 1, 0, 0, 0, 651, 654, 1, 0, 0, 0, 652, 653, 5, 16, 0, 0, 653, 655, 5, 113, 0, 0, 654, 652, 1, 0, 0, 0, 654, 655, 1, 0, 0, 0, 655, 93, 1, 0, 0, 0, 656, 663, 3, 162, 81, 0, 657, 660, 3, 146, 73, 0, 658, 659, 5, 154, 0, 0, 659, 661, 3, 146, 73, 0, 660, 658, 1, 0, 0, 0, 660, 661, 1, 0, 0, 0, 661, 663, 1, 0, 0, 0, 662, 656, 1, 0, 0, 0, 662, 657, 1, 0, 0, 0, 663, 95, 1, 0, 0, 0, 664, 669, 3, 98, 49, 0, 665, 666, 5, 119, 0, 0, 666, 668, 3, 98, 49, 0, 667, 665, 1, 0, 0, 0, 668, 671, 1, 0, 0, 0, 669, 667, 1, 0, 0, 0, 669, 670, 1, 0, 0, 0, 670, 97, 1, 0, 0, 0, 671, 669, 1, 0, 0, 0, 672, 673, 3, 158, 79, 0, 673, 674, 5, 125, 0, 0, 674, 675, 3, 148, 74, 0, 675, 99, 1, 0, 0, 0, 676, 678, 3, 102, 51, 0, 677, 676, 1, 0, 0, 0, 677, 678, 1, 0, 0, 0, 678, 680, 1, 0, 0, 0, 679, 681, 3, 104, 52, 0, 680, 679, 1, 0, 0, 0, 680, 681, 1, 0, 0, 0, 681, 683, 1, 0, 0, 0, 682, 684, 3, 106, 53, 0, 683, 682, 1, 0, 0, 0, 683, 684, 1, 0, 0, 0, 684, 101, 1, 0, 0, 0, 685, 686, 5, 70, 0, 0, 686, 687, 5, 11, 0, 0, 687, 688, 3, 116, 58, 0, 688, 103, 1, 0, 0, 0, 689, 690, 5, 67, 0, 0, 690, 691, 5, 11, 0, 0, 691, 692, 3, 90, 45, 0, 692, 105, 1, 0, 0, 0, 693, 694, 7, 9, 0, 0, 694, 695, 3, 108, 54, 0, 695, 107, 1, 0, 0, 0, 696, 703, 3, 110, 55, 0, 697, 698, 5, 9, 0, 0, 698, 699, 3, 110, 55, 0, 699, 700, 5, 2, 0, 0, 700, 701, 3, 110, 55, 0, 701, 703, 1, 0, 0, 0, 702, 696, 1, 0, 0, 0, 702, 697, 1, 0, 0, 0, 703, 109, 1, 0, 0, 0, 704, 705, 5, 19, 0, 0, 705, 717, 5, 78, 0, 0, 706, 707, 5, 97, 0, 0, 707, 717, 5, 71, 0, 0, 708, 709, 5, 97, 0, 0, 709, 717, 5, 33, 0, 0, 710, 711, 3, 146, 73, 0, 711, 712, 5, 71, 0, 0, 712, 717, 1, 0, 0, 0, 713, 714, 3, 146, 73, 0, 714, 715, 5, 33, 0, 0, 715, 717, 1, 0, 0, 0, 716, 704, 1, 0, 0, 0, 716, 706, 1, 0, 0, 0, 716, 708, 1, 0, 0, 0, 716, 710, 1, 0, 0, 0, 716, 713, 1, 0, 0, 0, 717, 111, 1, 0, 0, 0, 718, 719, 3, 118, 59, 0, 719, 720, 5, 0, 0, 1, 720, 113, 1, 0, 0, 0, 721, 778, 3, 158, 79, 0, 722, 723, 3, 158, 79, 0, 723, 724, 5, 133, 0, 0, 724, 725, 3, 158, 79, 0, 725, 732, 3, 114, 57, 0, 726, 727, 5, 119, 0, 0, 727, 728, 3, 158, 79, 0, 728, 729, 3, 114, 57, 0, 729, 731, 1, 0, 0, 0, 730, 726, 1, 0, 0, 0, 731, 734, 1, 0, 0, 0, 732, 730, 1, 0, 0, 0, 732, 733, 1, 0, 0, 0, 733, 736, 1, 0, 0, 0, 734, 732, 1, 0, 0, 0, 735, 737, 5, 119, 0, 0, 736, 735, 1, 0, 0, 0, 736, 737, 1, 0, 0, 0, 737, 738, 1, 0, 0, 0, 738, 739, 5, 152, 0, 0, 739, 778, 1, 0, 0, 0, 740, 741, 3, 158, 79, 0, 741, 742, 5, 133, 0, 0, 742, 747, 3, 160, 80, 0, 743, 744, 5, 119, 0, 0, 744, 746, 3, 160, 80, 0, 745, 743, 1, 0, 0, 0, 746, 749, 1, 0, 0, 0, 747, 745, 1, 0, 0, 0, 747, 748, 1, 0, 0, 0, 748, 751, 1, 0, 0, 0, 749, 747, 1, 0, 0, 0, 750, 752, 5, 119, 0, 0, 751, 750, 1, 0, 0, 0, 751, 752, 1, 0, 0, 0, 752, 753, 1, 0, 0, 0, 753, 754, 5, 152, 0, 0, 754, 778, 1, 0, 0, 0, 755, 756, 3, 158, 79, 0, 756, 757, 5, 133, 0, 0, 757, 762, 3, 114, 57, 0, 758, 759, 5, 119, 0, 0, 759, 761, 3, 114, 57, 0, 760, 758, 1, 0, 0, 0, 761, 764, 1, 0, 0, 0, 762, 760, 1, 0, 0, 0, 762, 763, 1, 0, 0, 0, 763, 766, 1, 0, 0, 0, 764, 762, 1, 0, 0, 0, 765, 767, 5, 119, 0, 0, 766, 765, 1, 0, 0, 0, 766, 767, 1, 0, 0, 0, 767, 768, 1, 0, 0, 0, 768, 769, 5, 152, 0, 0, 769, 778, 1, 0, 0, 0, 770, 771, 3, 158, 79, 0, 771, 773, 5, 133, 0, 0, 772, 774, 3, 116, 58, 0, 773, 772, 1, 0, 0, 0, 773, 774, 1, 0, 0, 0, 774, 775, 1, 0, 0, 0, 775, 776, 5, 152, 0, 0, 776, 778, 1, 0, 0, 0, 777, 721, 1, 0, 0, 0, 777, 722, 1, 0, 0, 0, 777, 740, 1, 0, 0, 0, 777, 755, 1, 0, 0, 0, 777, 770, 1, 0, 0, 0, 778, 115, 1, 0, 0, 0, 779, 784, 3, 118, 59, 0, 780, 781, 5, 119, 0, 0, 781, 783, 3, 118, 59, 0, 782, 780, 1, 0, 0, 0, 783, 786, 1, 0, 0, 0, 784, 782, 1, 0, 0, 0, 784, 785, 1, 0, 0, 0, 785, 788, 1, 0, 0, 0, 786, 784, 1, 0, 0, 0, 787, 789, 5, 119, 0, 0, 788, 787, 1, 0, 0, 0, 788, 789, 1, 0, 0, 0, 789, 117, 1, 0, 0, 0, 790, 791, 6, 59, -1, 0, 791, 793, 5, 12, 0, 0, 792, 794, 3, 118, 59, 0, 793, 792, 1, 0, 0, 0, 793, 794, 1, 0, 0, 0, 794, 800, 1, 0, 0, 0, 795, 796, 5, 101, 0, 0, 796, 797, 3, 118, 59, 0, 797, 798, 5, 86, 0, 0, 798, 799, 3, 118, 59, 0, 799, 801, 1, 0, 0, 0, 800, 795, 1, 0, 0, 0, 801, 802, 1, 0, 0, 0, 802, 800, 1, 0, 0, 0, 802, 803, 1, 0, 0, 0, 803, 806, 1, 0, 0, 0, 804, 805, 5, 25, 0, 0, 805, 807, 3, 118, 59, 0, 806, 804, 1, 0, 0, 0, 806, 807, 1, 0, 0, 0, 807, 808, 1, 0, 0, 0, 808, 809, 5, 26, 0, 0, 809, 941, 1, 0, 0, 0, 810, 811, 5, 13, 0, 0, 811, 812, 5, 133, 0, 0, 812, 813, 3, 118, 59, 0, 813, 814, 5, 6, 0, 0, 814, 815, 3, 114, 57, 0, 815, 816, 5, 152, 0, 0, 816, 941, 1, 0, 0, 0, 817, 818, 5, 20, 0, 0, 818, 941, 5, 113, 0, 0, 819, 820, 5, 48, 0, 0, 820, 821, 3, 118, 59, 0, 821, 822, 3, 150, 75, 0, 822, 941, 1, 0, 0, 0, 823, 824, 5, 85, 0, 0, 824, 825, 5, 133, 0, 0, 825, 826, 3, 118, 59, 0, 826, 827, 5, 35, 0, 0, 827, 830, 3, 118, 59, 0, 828, 829, 5, 34, 0, 0, 829, 831, 3, 118, 59, 0, 830, 828, 1, 0, 0, 0, 830, 831, 1, 0, 0, 0, 831, 832, 1, 0, 0, 0, 832, 833, 5, 152, 0, 0, 833, 941, 1, 0, 0, 0, 834, 835, 5, 89, 0, 0, 835, 941, 5, 113, 0, 0, 836, 837, 5, 94, 0, 0, 837, 838, 5, 133, 0, 0, 838, 839, 7, 10, 0, 0, 839, 840, 3, 164, 82, 0, 840, 841, 5, 35, 0, 0, 841, 842, 3, 118, 59, 0, 842, 843, 5, 152, 0, 0, 843, 941, 1, 0, 0, 0, 844, 845, 3, 158, 79, 0, 845, 847, 5, 133, 0, 0, 846, 848, 3, 116, 58, 0, 847, 846, 1, 0, 0, 0, 847, 848, 1, 0, 0, 0, 848, 849, 1, 0, 0, 0, 849, 850, 5, 152, 0, 0, 850, 859, 1, 0, 0, 0, 851, 853, 5, 133, 0, 0, 852, 854, 5, 24, 0, 0, 853, 852, 1, 0, 0, 0, 853, 854, 1, 0, 0, 0, 854, 856, 1, 0, 0, 0, 855, 857, 3, 116, 58, 0, 856, 855, 1, 0, 0, 0, 856, 857, 1, 0, 0, 0, 857, 858, 1, 0, 0, 0, 858, 860, 5, 152, 0, 0, 859, 851, 1, 0, 0, 0, 859, 860, 1, 0, 0, 0, 860, 861, 1, 0, 0, 0, 861, 862, 5, 69, 0, 0, 862, 863, 5, 133, 0, 0, 863, 864, 3, 100, 50, 0, 864, 865, 5, 152, 0, 0, 865, 941, 1, 0, 0, 0, 866, 867, 3, 158, 79, 0, 867, 869, 5, 133, 0, 0, 868, 870, 3, 116, 58, 0, 869, 868, 1, 0, 0, 0, 869, 870, 1, 0, 0, 0, 870, 871, 1, 0, 0, 0, 871, 872, 5, 152, 0, 0, 872, 881, 1, 0, 0, 0, 873, 875, 5, 133, 0, 0, 874, 876, 5, 24, 0, 0, 875, 874, 1, 0, 0, 0, 875, 876, 1, 0, 0, 0, 876, 878, 1, 0, 0, 0, 877, 879, 3, 116, 58, 0, 878, 877, 1, 0, 0, 0, 878, 879, 1, 0, 0, 0, 879, 880, 1, 0, 0, 0, 880, 882, 5, 152, 0, 0, 881, 873, 1, 0, 0, 0, 881, 882, 1, 0, 0, 0, 882, 883, 1, 0, 0, 0, 883, 884, 5, 69, 0, 0, 884, 885, 3, 158, 79, 0, 885, 941, 1, 0, 0, 0, 886, 892, 3, 158, 79, 0, 887, 889, 5, 133, 0, 0, 888, 890, 3, 116, 58, 0, 889, 888, 1, 0, 0, 0, 889, 890, 1, 0, 0, 0, 890, 891, 1, 0, 0, 0, 891, 893, 5, 152, 0, 0, 892, 887, 1, 0, 0, 0, 892, 893, 1, 0, 0, 0, 893, 894, 1, 0, 0, 0, 894, 896, 5, 133, 0, 0, 895, 897, 5, 24, 0, 0, 896, 895, 1, 0, 0, 0, 896, 897, 1, 0, 0, 0, 897, 899, 1, 0, 0, 0, 898, 900, 3, 116, 58, 0, 899, 898, 1, 0, 0, 0, 899, 900, 1, 0, 0, 0, 900, 901, 1, 0, 0, 0, 901, 902, 5, 152, 0, 0, 902, 941, 1, 0, 0, 0, 903, 941, 3, 122, 61, 0, 904, 941, 3, 166, 83, 0, 905, 941, 3, 148, 74, 0, 906, 907, 5, 121, 0, 0, 907, 941, 3, 118, 59, 20, 908, 909, 5, 61, 0, 0, 909, 941, 3, 118, 59, 14, 910, 911, 3, 138, 69, 0, 911, 912, 5, 123, 0, 0, 912, 914, 1, 0, 0, 0, 913, 910, 1, 0, 0, 0, 913, 914, 1, 0, 0, 0, 914, 915, 1, 0, 0, 0, 915, 941, 5, 115, 0, 0, 916, 917, 5, 133, 0, 0, 917, 918, 3, 48, 24, 0, 918, 919, 5, 152, 0, 0, 919, 941, 1, 0, 0, 0, 920, 921, 5, 133, 0, 0, 921, 922, 3, 118, 59, 0, 922, 923, 5, 152, 0, 0, 923, 941, 1, 0, 0, 0, 924, 925, 5, 133, 0, 0, 925, 926, 3, 116, 58, 0, 926, 927, 5, 152, 0, 0, 927, 941, 1, 0, 0, 0, 928, 930, 5, 132, 0, 0, 929, 931, 3, 116, 58, 0, 930, 929, 1, 0, 0, 0, 930, 931, 1, 0, 0, 0, 931, 932, 1, 0, 0, 0, 932, 941, 5, 151, 0, 0, 933, 935, 5, 131, 0, 0, 934, 936, 3, 40, 20, 0, 935, 934, 1, 0, 0, 0, 935, 936, 1, 0, 0, 0, 936, 937, 1, 0, 0, 0, 937, 941, 5, 150, 0, 0, 938, 941, 3, 120, 60, 0, 939, 941, 3, 130, 65, 0, 940, 790, 1, 0, 0, 0, 940, 810, 1, 0, 0, 0, 940, 817, 1, 0, 0, 0, 940, 819, 1, 0, 0, 0, 940, 823, 1, 0, 0, 0, 940, 834, 1, 0, 0, 0, 940, 836, 1, 0, 0, 0, 940, 844, 1, 0, 0, 0, 940, 866, 1, 0, 0, 0, 940, 886, 1, 0, 0, 0, 940, 903, 1, 0, 0, 0, 940, 904, 1, 0, 0, 0, 940, 905, 1, 0, 0, 0, 940, 906, 1, 0, 0, 0, 940, 908, 1, 0, 0, 0, 940, 913, 1, 0, 0, 0, 940, 916, 1, 0, 0, 0, 940, 920, 1, 0, 0, 0, 940, 924, 1, 0, 0, 0, 940, 928, 1, 0, 0, 0, 940, 933, 1, 0, 0, 0, 940, 938, 1, 0, 0, 0, 940, 939, 1, 0, 0, 0, 941, 1052, 1, 0, 0, 0, 942, 946, 10, 19, 0, 0, 943, 947, 5, 115, 0, 0, 944, 947, 5, 154, 0, 0, 945, 947, 5, 141, 0, 0, 946, 943, 1, 0, 0, 0, 946, 944, 1, 0, 0, 0, 946, 945, 1, 0, 0, 0, 947, 948, 1, 0, 0, 0, 948, 1051, 3, 118, 59, 20, 949, 953, 10, 18, 0, 0, 950, 954, 5, 142, 0, 0, 951, 954, 5, 121, 0, 0, 952, 954, 5, 120, 0, 0, 953, 950, 1, 0, 0, 0, 953, 951, 1, 0, 0, 0, 953, 952, 1, 0, 0, 0, 954, 955, 1, 0, 0, 0, 955, 1051, 3, 118, 59, 19, 956, 981, 10, 17, 0, 0, 957, 982, 5, 124, 0, 0, 958, 982, 5, 125, 0, 0, 959, 982, 5, 136, 0, 0, 960, 982, 5, 134, 0, 0, 961, 982, 5, 135, 0, 0, 962, 982, 5, 126, 0, 0, 963, 982, 5, 127, 0, 0, 964, 966, 5, 61, 0, 0, 965, 964, 1, 0, 0, 0, 965, 966, 1, 0, 0, 0, 966, 967, 1, 0, 0, 0, 967, 969, 5, 44, 0, 0, 968, 970, 5, 15, 0, 0, 969, 968, 1, 0, 0, 0, 969, 970, 1, 0, 0, 0, 970, 982, 1, 0, 0, 0, 971, 973, 5, 61, 0, 0, 972, 971, 1, 0, 0, 0, 972, 973, 1, 0, 0, 0, 973, 974, 1, 0, 0, 0, 974, 982, 7, 11, 0, 0, 975, 982, 5, 148, 0, 0, 976, 982, 5, 149, 0, 0, 977, 982, 5, 138, 0, 0, 978, 982, 5, 129, 0, 0, 979, 982, 5, 130, 0, 0, 980, 982, 5, 137, 0, 0, 981, 957, 1, 0, 0, 0, 981, 958, 1, 0, 0, 0, 981, 959, 1, 0, 0, 0, 981, 960, 1, 0, 0, 0, 981, 961, 1, 0, 0, 0, 981, 962, 1, 0, 0, 0, 981, 963, 1, 0, 0, 0, 981, 965, 1, 0, 0, 0, 981, 972, 1, 0, 0, 0, 981, 975, 1, 0, 0, 0, 981, 976, 1, 0, 0, 0, 981, 977, 1, 0, 0, 0, 981, 978, 1, 0, 0, 0, 981, 979, 1, 0, 0, 0, 981, 980, 1, 0, 0, 0, 982, 983, 1, 0, 0, 0, 983, 1051, 3, 118, 59, 18, 984, 985, 10, 15, 0, 0, 985, 986, 5, 140, 0, 0, 986, 1051, 3, 118, 59, 16, 987, 988, 10, 13, 0, 0, 988, 989, 5, 2, 0, 0, 989, 1051, 3, 118, 59, 14, 990, 991, 10, 12, 0, 0, 991, 992, 5, 66, 0, 0, 992, 1051, 3, 118, 59, 13, 993, 995, 10, 11, 0, 0, 994, 996, 5, 61, 0, 0, 995, 994, 1, 0, 0, 0, 995, 996, 1, 0, 0, 0, 996, 997, 1, 0, 0, 0, 997, 998, 5, 9, 0, 0, 998, 999, 3, 118, 59, 0, 999, 1000, 5, 2, 0, 0, 1000, 1001, 3, 118, 59, 12, 1001, 1051, 1, 0, 0, 0, 1002, 1003, 10, 10, 0, 0, 1003, 1004, 5, 143, 0, 0, 1004, 1005, 3, 118, 59, 0, 1005, 1006, 5, 118, 0, 0, 1006, 1007, 3, 118, 59, 10, 1007, 1051, 1, 0, 0, 0, 1008, 1009, 10, 30, 0, 0, 1009, 1011, 5, 133, 0, 0, 1010, 1012, 3, 116, 58, 0, 1011, 1010, 1, 0, 0, 0, 1011, 1012, 1, 0, 0, 0, 1012, 1013, 1, 0, 0, 0, 1013, 1051, 5, 152, 0, 0, 1014, 1015, 10, 26, 0, 0, 1015, 1016, 5, 132, 0, 0, 1016, 1017, 3, 118, 59, 0, 1017, 1018, 5, 151, 0, 0, 1018, 1051, 1, 0, 0, 0, 1019, 1020, 10, 25, 0, 0, 1020, 1021, 5, 123, 0, 0, 1021, 1051, 5, 111, 0, 0, 1022, 1023, 10, 24, 0, 0, 1023, 1024, 5, 123, 0, 0, 1024, 1051, 3, 158, 79, 0, 1025, 1026, 10, 23, 0, 0, 1026, 1027, 5, 139, 0, 0, 1027, 1028, 5, 132, 0, 0, 1028, 1029, 3, 118, 59, 0, 1029, 1030, 5, 151, 0, 0, 1030, 1051, 1, 0, 0, 0, 1031, 1032, 10, 22, 0, 0, 1032, 1033, 5, 139, 0, 0, 1033, 1051, 5, 111, 0, 0, 1034, 1035, 10, 21, 0, 0, 1035, 1036, 5, 139, 0, 0, 1036, 1051, 3, 158, 79, 0, 1037, 1038, 10, 16, 0, 0, 1038, 1040, 5, 49, 0, 0, 1039, 1041, 5, 61, 0, 0, 1040, 1039, 1, 0, 0, 0, 1040, 1041, 1, 0, 0, 0, 1041, 1042, 1, 0, 0, 0, 1042, 1051, 5, 62, 0, 0, 1043, 1048, 10, 9, 0, 0, 1044, 1045, 5, 6, 0, 0, 1045, 1049, 3, 158, 79, 0, 1046, 1047, 5, 6, 0, 0, 1047, 1049, 5, 113, 0, 0, 1048, 1044, 1, 0, 0, 0, 1048, 1046, 1, 0, 0, 0, 1049, 1051, 1, 0, 0, 0, 1050, 942, 1, 0, 0, 0, 1050, 949, 1, 0, 0, 0, 1050, 956, 1, 0, 0, 0, 1050, 984, 1, 0, 0, 0, 1050, 987, 1, 0, 0, 0, 1050, 990, 1, 0, 0, 0, 1050, 993, 1, 0, 0, 0, 1050, 1002, 1, 0, 0, 0, 1050, 1008, 1, 0, 0, 0, 1050, 1014, 1, 0, 0, 0, 1050, 1019, 1, 0, 0, 0, 1050, 1022, 1, 0, 0, 0, 1050, 1025, 1, 0, 0, 0, 1050, 1031, 1, 0, 0, 0, 1050, 1034, 1, 0, 0, 0, 1050, 1037, 1, 0, 0, 0, 1050, 1043, 1, 0, 0, 0, 1051, 1054, 1, 0, 0, 0, 1052, 1050, 1, 0, 0, 0, 1052, 1053, 1, 0, 0, 0, 1053, 119, 1, 0, 0, 0, 1054, 1052, 1, 0, 0, 0, 1055, 1056, 5, 133, 0, 0, 1056, 1061, 3, 158, 79, 0, 1057, 1058, 5, 119, 0, 0, 1058, 1060, 3, 158, 79, 0, 1059, 1057, 1, 0, 0, 0, 1060, 1063, 1, 0, 0, 0, 1061, 1059, 1, 0, 0, 0, 1061, 1062, 1, 0, 0, 0, 1062, 1065, 1, 0, 0, 0, 1063, 1061, 1, 0, 0, 0, 1064, 1066, 5, 119, 0, 0, 1065, 1064, 1, 0, 0, 0, 1065, 1066, 1, 0, 0, 0, 1066, 1067, 1, 0, 0, 0, 1067, 1068, 5, 152, 0, 0, 1068, 1083, 1, 0, 0, 0, 1069, 1074, 3, 158, 79, 0, 1070, 1071, 5, 119, 0, 0, 1071, 1073, 3, 158, 79, 0, 1072, 1070, 1, 0, 0, 0, 1073, 1076, 1, 0, 0, 0, 1074, 1072, 1, 0, 0, 0, 1074, 1075, 1, 0, 0, 0, 1075, 1078, 1, 0, 0, 0, 1076, 1074, 1, 0, 0, 0, 1077, 1079, 5, 119, 0, 0, 1078, 1077, 1, 0, 0, 0, 1078, 1079, 1, 0, 0, 0, 1079, 1083, 1, 0, 0, 0, 1080, 1081, 5, 133, 0, 0, 1081, 1083, 5, 152, 0, 0, 1082, 1055, 1, 0, 0, 0, 1082, 1069, 1, 0, 0, 0, 1082, 1080, 1, 0, 0, 0, 1083, 1084, 1, 0, 0, 0, 1084, 1087, 5, 114, 0, 0, 1085, 1088, 3, 118, 59, 0, 1086, 1088, 3, 36, 18, 0, 1087, 1085, 1, 0, 0, 0, 1087, 1086, 1, 0, 0, 0, 1088, 121, 1, 0, 0, 0, 1089, 1090, 5, 135, 0, 0, 1090, 1094, 3, 158, 79, 0, 1091, 1093, 3, 124, 62, 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, 154, 0, 0, 1098, 1099, 5, 127, 0, 0, 1099, 1122, 1, 0, 0, 0, 1100, 1101, 5, 135, 0, 0, 1101, 1105, 3, 158, 79, 0, 1102, 1104, 3, 124, 62, 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, 127, 0, 0, 1109, 1115, 3, 122, 61, 0, 1110, 1111, 5, 131, 0, 0, 1111, 1112, 3, 118, 59, 0, 1112, 1113, 5, 150, 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, 135, 0, 0, 1117, 1118, 5, 154, 0, 0, 1118, 1119, 3, 158, 79, 0, 1119, 1120, 5, 127, 0, 0, 1120, 1122, 1, 0, 0, 0, 1121, 1089, 1, 0, 0, 0, 1121, 1100, 1, 0, 0, 0, 1122, 123, 1, 0, 0, 0, 1123, 1124, 3, 158, 79, 0, 1124, 1125, 5, 125, 0, 0, 1125, 1126, 3, 164, 82, 0, 1126, 1135, 1, 0, 0, 0, 1127, 1128, 3, 158, 79, 0, 1128, 1129, 5, 125, 0, 0, 1129, 1130, 5, 131, 0, 0, 1130, 1131, 3, 118, 59, 0, 1131, 1132, 5, 150, 0, 0, 1132, 1135, 1, 0, 0, 0, 1133, 1135, 3, 158, 79, 0, 1134, 1123, 1, 0, 0, 0, 1134, 1127, 1, 0, 0, 0, 1134, 1133, 1, 0, 0, 0, 1135, 125, 1, 0, 0, 0, 1136, 1141, 3, 128, 64, 0, 1137, 1138, 5, 119, 0, 0, 1138, 1140, 3, 128, 64, 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, 119, 0, 0, 1145, 1144, 1, 0, 0, 0, 1145, 1146, 1, 0, 0, 0, 1146, 127, 1, 0, 0, 0, 1147, 1148, 3, 158, 79, 0, 1148, 1149, 5, 6, 0, 0, 1149, 1150, 5, 133, 0, 0, 1150, 1151, 3, 48, 24, 0, 1151, 1152, 5, 152, 0, 0, 1152, 1158, 1, 0, 0, 0, 1153, 1154, 3, 118, 59, 0, 1154, 1155, 5, 6, 0, 0, 1155, 1156, 3, 158, 79, 0, 1156, 1158, 1, 0, 0, 0, 1157, 1147, 1, 0, 0, 0, 1157, 1153, 1, 0, 0, 0, 1158, 129, 1, 0, 0, 0, 1159, 1167, 3, 162, 81, 0, 1160, 1161, 3, 138, 69, 0, 1161, 1162, 5, 123, 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, 132, 66, 0, 1166, 1159, 1, 0, 0, 0, 1166, 1163, 1, 0, 0, 0, 1167, 131, 1, 0, 0, 0, 1168, 1173, 3, 158, 79, 0, 1169, 1170, 5, 123, 0, 0, 1170, 1172, 3, 158, 79, 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, 133, 1, 0, 0, 0, 1175, 1173, 1, 0, 0, 0, 1176, 1177, 6, 67, -1, 0, 1177, 1186, 3, 138, 69, 0, 1178, 1186, 3, 136, 68, 0, 1179, 1180, 5, 133, 0, 0, 1180, 1181, 3, 48, 24, 0, 1181, 1182, 5, 152, 0, 0, 1182, 1186, 1, 0, 0, 0, 1183, 1186, 3, 122, 61, 0, 1184, 1186, 3, 162, 81, 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, 156, 78, 0, 1189, 1190, 5, 6, 0, 0, 1190, 1192, 3, 158, 79, 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, 135, 1, 0, 0, 0, 1197, 1195, 1, 0, 0, 0, 1198, 1199, 3, 158, 79, 0, 1199, 1201, 5, 133, 0, 0, 1200, 1202, 3, 140, 70, 0, 1201, 1200, 1, 0, 0, 0, 1201, 1202, 1, 0, 0, 0, 1202, 1203, 1, 0, 0, 0, 1203, 1204, 5, 152, 0, 0, 1204, 137, 1, 0, 0, 0, 1205, 1206, 3, 142, 71, 0, 1206, 1207, 5, 123, 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, 158, 79, 0, 1211, 139, 1, 0, 0, 0, 1212, 1217, 3, 118, 59, 0, 1213, 1214, 5, 119, 0, 0, 1214, 1216, 3, 118, 59, 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, 119, 0, 0, 1221, 1220, 1, 0, 0, 0, 1221, 1222, 1, 0, 0, 0, 1222, 141, 1, 0, 0, 0, 1223, 1224, 3, 158, 79, 0, 1224, 143, 1, 0, 0, 0, 1225, 1234, 5, 109, 0, 0, 1226, 1227, 5, 123, 0, 0, 1227, 1234, 7, 12, 0, 0, 1228, 1229, 5, 111, 0, 0, 1229, 1231, 5, 123, 0, 0, 1230, 1232, 7, 12, 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, 145, 1, 0, 0, 0, 1235, 1237, 7, 13, 0, 0, 1236, 1235, 1, 0, 0, 0, 1236, 1237, 1, 0, 0, 0, 1237, 1244, 1, 0, 0, 0, 1238, 1245, 3, 144, 72, 0, 1239, 1245, 5, 110, 0, 0, 1240, 1245, 5, 111, 0, 0, 1241, 1245, 5, 112, 0, 0, 1242, 1245, 5, 45, 0, 0, 1243, 1245, 5, 60, 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, 147, 1, 0, 0, 0, 1246, 1250, 3, 146, 73, 0, 1247, 1250, 5, 113, 0, 0, 1248, 1250, 5, 62, 0, 0, 1249, 1246, 1, 0, 0, 0, 1249, 1247, 1, 0, 0, 0, 1249, 1248, 1, 0, 0, 0, 1250, 149, 1, 0, 0, 0, 1251, 1252, 7, 14, 0, 0, 1252, 151, 1, 0, 0, 0, 1253, 1254, 7, 15, 0, 0, 1254, 153, 1, 0, 0, 0, 1255, 1256, 7, 16, 0, 0, 1256, 155, 1, 0, 0, 0, 1257, 1260, 5, 108, 0, 0, 1258, 1260, 3, 154, 77, 0, 1259, 1257, 1, 0, 0, 0, 1259, 1258, 1, 0, 0, 0, 1260, 157, 1, 0, 0, 0, 1261, 1265, 5, 108, 0, 0, 1262, 1265, 3, 150, 75, 0, 1263, 1265, 3, 152, 76, 0, 1264, 1261, 1, 0, 0, 0, 1264, 1262, 1, 0, 0, 0, 1264, 1263, 1, 0, 0, 0, 1265, 159, 1, 0, 0, 0, 1266, 1267, 3, 164, 82, 0, 1267, 1268, 5, 125, 0, 0, 1268, 1269, 3, 146, 73, 0, 1269, 161, 1, 0, 0, 0, 1270, 1271, 5, 131, 0, 0, 1271, 1272, 3, 118, 59, 0, 1272, 1273, 5, 150, 0, 0, 1273, 163, 1, 0, 0, 0, 1274, 1277, 5, 113, 0, 0, 1275, 1277, 3, 166, 83, 0, 1276, 1274, 1, 0, 0, 0, 1276, 1275, 1, 0, 0, 0, 1277, 165, 1, 0, 0, 0, 1278, 1282, 5, 145, 0, 0, 1279, 1281, 3, 168, 84, 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, 147, 0, 0, 1286, 167, 1, 0, 0, 0, 1287, 1288, 5, 160, 0, 0, 1288, 1289, 3, 118, 59, 0, 1289, 1290, 5, 150, 0, 0, 1290, 1293, 1, 0, 0, 0, 1291, 1293, 5, 159, 0, 0, 1292, 1287, 1, 0, 0, 0, 1292, 1291, 1, 0, 0, 0, 1293, 169, 1, 0, 0, 0, 1294, 1298, 5, 146, 0, 0, 1295, 1297, 3, 172, 86, 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, 171, 1, 0, 0, 0, 1303, 1304, 5, 162, 0, 0, 1304, 1305, 3, 118, 59, 0, 1305, 1306, 5, 150, 0, 0, 1306, 1309, 1, 0, 0, 0, 1307, 1309, 5, 161, 0, 0, 1308, 1303, 1, 0, 0, 0, 1308, 1307, 1, 0, 0, 0, 1309, 173, 1, 0, 0, 0, 168, 177, 184, 193, 200, 204, 218, 222, 225, 229, 232, 239, 243, 252, 257, 266, 274, 281, 285, 291, 296, 304, 311, 317, 329, 337, 351, 355, 360, 370, 376, 384, 388, 392, 395, 399, 402, 405, 408, 411, 415, 419, 422, 425, 428, 432, 435, 444, 450, 471, 488, 505, 511, 517, 528, 530, 541, 544, 550, 558, 564, 566, 570, 575, 578, 581, 585, 589, 592, 594, 597, 601, 605, 608, 610, 612, 617, 628, 634, 641, 646, 650, 654, 660, 662, 669, 677, 680, 683, 702, 716, 732, 736, 747, 751, 762, 766, 773, 777, 784, 788, 793, 802, 806, 830, 847, 853, 856, 859, 869, 875, 878, 881, 889, 892, 896, 899, 913, 930, 935, 940, 946, 953, 965, 969, 972, 981, 995, 1011, 1040, 1048, 1050, 1052, 1061, 1065, 1074, 1078, 1082, 1087, 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 diff --git a/hogql_parser/HogQLParser.tokens b/hogql_parser/HogQLParser.tokens index 8658dc473b899..f370b819d5a0d 100644 --- a/hogql_parser/HogQLParser.tokens +++ b/hogql_parser/HogQLParser.tokens @@ -24,178 +24,180 @@ DESCENDING=23 DISTINCT=24 ELSE=25 END=26 -EXTRACT=27 -FINAL=28 -FINALLY=29 -FIRST=30 -FN=31 -FOLLOWING=32 -FOR=33 -FROM=34 -FULL=35 -FUN=36 -GROUP=37 -HAVING=38 -HOUR=39 -ID=40 -IF=41 -ILIKE=42 -IN=43 -INF=44 -INNER=45 -INTERVAL=46 -IS=47 -JOIN=48 -KEY=49 -LAST=50 -LEADING=51 -LEFT=52 -LET=53 -LIKE=54 -LIMIT=55 -MINUTE=56 -MONTH=57 -NAN_SQL=58 -NOT=59 -NULL_SQL=60 -NULLS=61 -OFFSET=62 -ON=63 -OR=64 -ORDER=65 -OUTER=66 -OVER=67 -PARTITION=68 -PRECEDING=69 -PREWHERE=70 -QUARTER=71 -RANGE=72 -RETURN=73 -RIGHT=74 -ROLLUP=75 -ROW=76 -ROWS=77 -SAMPLE=78 -SECOND=79 -SELECT=80 -SEMI=81 -SETTINGS=82 -SUBSTRING=83 -THEN=84 -THROW=85 -TIES=86 -TIMESTAMP=87 -TO=88 -TOP=89 -TOTALS=90 -TRAILING=91 -TRIM=92 -TRUNCATE=93 -TRY=94 -UNBOUNDED=95 -UNION=96 -USING=97 -WEEK=98 -WHEN=99 -WHERE=100 -WHILE=101 -WINDOW=102 -WITH=103 -YEAR=104 -ESCAPE_CHAR_COMMON=105 -IDENTIFIER=106 -FLOATING_LITERAL=107 -OCTAL_LITERAL=108 -DECIMAL_LITERAL=109 -HEXADECIMAL_LITERAL=110 -STRING_LITERAL=111 -ARROW=112 -ASTERISK=113 -BACKQUOTE=114 -BACKSLASH=115 -COLON=116 -COMMA=117 -CONCAT=118 -DASH=119 -DOLLAR=120 -DOT=121 -EQ_DOUBLE=122 -EQ_SINGLE=123 -GT_EQ=124 -GT=125 -HASH=126 -IREGEX_SINGLE=127 -IREGEX_DOUBLE=128 -LBRACE=129 -LBRACKET=130 -LPAREN=131 -LT_EQ=132 -LT=133 -NOT_EQ=134 -NOT_IREGEX=135 -NOT_REGEX=136 -NULL_PROPERTY=137 -NULLISH=138 -PERCENT=139 -PLUS=140 -QUERY=141 -QUOTE_DOUBLE=142 -QUOTE_SINGLE_TEMPLATE=143 -QUOTE_SINGLE_TEMPLATE_FULL=144 -QUOTE_SINGLE=145 -REGEX_SINGLE=146 -REGEX_DOUBLE=147 -RBRACE=148 -RBRACKET=149 -RPAREN=150 -SEMICOLON=151 -SLASH=152 -UNDERSCORE=153 -MULTI_LINE_COMMENT=154 -SINGLE_LINE_COMMENT=155 -WHITESPACE=156 -STRING_TEXT=157 -STRING_ESCAPE_TRIGGER=158 -FULL_STRING_TEXT=159 -FULL_STRING_ESCAPE_TRIGGER=160 -'->'=112 -'*'=113 -'`'=114 -'\\'=115 -':'=116 -','=117 -'||'=118 -'-'=119 -'$'=120 -'.'=121 -'=='=122 -'='=123 -'>='=124 -'>'=125 -'#'=126 -'~*'=127 -'=~*'=128 -'{'=129 -'['=130 -'('=131 -'<='=132 -'<'=133 -'!~*'=135 -'!~'=136 -'?.'=137 -'??'=138 -'%'=139 -'+'=140 -'?'=141 -'"'=142 -'f\''=143 -'F\''=144 -'\''=145 -'~'=146 -'=~'=147 -'}'=148 -']'=149 -')'=150 -';'=151 -'/'=152 -'_'=153 +EXCEPT=27 +EXTRACT=28 +FINAL=29 +FINALLY=30 +FIRST=31 +FN=32 +FOLLOWING=33 +FOR=34 +FROM=35 +FULL=36 +FUN=37 +GROUP=38 +HAVING=39 +HOUR=40 +ID=41 +IF=42 +ILIKE=43 +IN=44 +INF=45 +INNER=46 +INTERSECT=47 +INTERVAL=48 +IS=49 +JOIN=50 +KEY=51 +LAST=52 +LEADING=53 +LEFT=54 +LET=55 +LIKE=56 +LIMIT=57 +MINUTE=58 +MONTH=59 +NAN_SQL=60 +NOT=61 +NULL_SQL=62 +NULLS=63 +OFFSET=64 +ON=65 +OR=66 +ORDER=67 +OUTER=68 +OVER=69 +PARTITION=70 +PRECEDING=71 +PREWHERE=72 +QUARTER=73 +RANGE=74 +RETURN=75 +RIGHT=76 +ROLLUP=77 +ROW=78 +ROWS=79 +SAMPLE=80 +SECOND=81 +SELECT=82 +SEMI=83 +SETTINGS=84 +SUBSTRING=85 +THEN=86 +THROW=87 +TIES=88 +TIMESTAMP=89 +TO=90 +TOP=91 +TOTALS=92 +TRAILING=93 +TRIM=94 +TRUNCATE=95 +TRY=96 +UNBOUNDED=97 +UNION=98 +USING=99 +WEEK=100 +WHEN=101 +WHERE=102 +WHILE=103 +WINDOW=104 +WITH=105 +YEAR=106 +ESCAPE_CHAR_COMMON=107 +IDENTIFIER=108 +FLOATING_LITERAL=109 +OCTAL_LITERAL=110 +DECIMAL_LITERAL=111 +HEXADECIMAL_LITERAL=112 +STRING_LITERAL=113 +ARROW=114 +ASTERISK=115 +BACKQUOTE=116 +BACKSLASH=117 +COLON=118 +COMMA=119 +CONCAT=120 +DASH=121 +DOLLAR=122 +DOT=123 +EQ_DOUBLE=124 +EQ_SINGLE=125 +GT_EQ=126 +GT=127 +HASH=128 +IREGEX_SINGLE=129 +IREGEX_DOUBLE=130 +LBRACE=131 +LBRACKET=132 +LPAREN=133 +LT_EQ=134 +LT=135 +NOT_EQ=136 +NOT_IREGEX=137 +NOT_REGEX=138 +NULL_PROPERTY=139 +NULLISH=140 +PERCENT=141 +PLUS=142 +QUERY=143 +QUOTE_DOUBLE=144 +QUOTE_SINGLE_TEMPLATE=145 +QUOTE_SINGLE_TEMPLATE_FULL=146 +QUOTE_SINGLE=147 +REGEX_SINGLE=148 +REGEX_DOUBLE=149 +RBRACE=150 +RBRACKET=151 +RPAREN=152 +SEMICOLON=153 +SLASH=154 +UNDERSCORE=155 +MULTI_LINE_COMMENT=156 +SINGLE_LINE_COMMENT=157 +WHITESPACE=158 +STRING_TEXT=159 +STRING_ESCAPE_TRIGGER=160 +FULL_STRING_TEXT=161 +FULL_STRING_ESCAPE_TRIGGER=162 +'->'=114 +'*'=115 +'`'=116 +'\\'=117 +':'=118 +','=119 +'||'=120 +'-'=121 +'$'=122 +'.'=123 +'=='=124 +'='=125 +'>='=126 +'>'=127 +'#'=128 +'~*'=129 +'=~*'=130 +'{'=131 +'['=132 +'('=133 +'<='=134 +'<'=135 +'!~*'=137 +'!~'=138 +'?.'=139 +'??'=140 +'%'=141 +'+'=142 +'?'=143 +'"'=144 +'f\''=145 +'F\''=146 +'\''=147 +'~'=148 +'=~'=149 +'}'=150 +']'=151 +')'=152 +';'=153 +'/'=154 +'_'=155 diff --git a/hogql_parser/HogQLParserBaseVisitor.h b/hogql_parser/HogQLParserBaseVisitor.h index 80b4d5d487765..59f4a7883406e 100644 --- a/hogql_parser/HogQLParserBaseVisitor.h +++ b/hogql_parser/HogQLParserBaseVisitor.h @@ -103,11 +103,15 @@ class HogQLParserBaseVisitor : public HogQLParserVisitor { return visitChildren(ctx); } - virtual std::any visitSelectUnionStmt(HogQLParser::SelectUnionStmtContext *ctx) override { + virtual std::any visitSelectStmtWithParens(HogQLParser::SelectStmtWithParensContext *ctx) override { return visitChildren(ctx); } - virtual std::any visitSelectStmtWithParens(HogQLParser::SelectStmtWithParensContext *ctx) override { + virtual std::any visitSubsequentSelectSetClause(HogQLParser::SubsequentSelectSetClauseContext *ctx) override { + return visitChildren(ctx); + } + + virtual std::any visitSelectSetStmt(HogQLParser::SelectSetStmtContext *ctx) override { return visitChildren(ctx); } diff --git a/hogql_parser/HogQLParserVisitor.h b/hogql_parser/HogQLParserVisitor.h index 0b9e1797ad836..7e1728b26a1de 100644 --- a/hogql_parser/HogQLParserVisitor.h +++ b/hogql_parser/HogQLParserVisitor.h @@ -63,10 +63,12 @@ class HogQLParserVisitor : public antlr4::tree::AbstractParseTreeVisitor { virtual std::any visitSelect(HogQLParser::SelectContext *context) = 0; - virtual std::any visitSelectUnionStmt(HogQLParser::SelectUnionStmtContext *context) = 0; - virtual std::any visitSelectStmtWithParens(HogQLParser::SelectStmtWithParensContext *context) = 0; + virtual std::any visitSubsequentSelectSetClause(HogQLParser::SubsequentSelectSetClauseContext *context) = 0; + + virtual std::any visitSelectSetStmt(HogQLParser::SelectSetStmtContext *context) = 0; + virtual std::any visitSelectStmt(HogQLParser::SelectStmtContext *context) = 0; virtual std::any visitWithClause(HogQLParser::WithClauseContext *context) = 0; diff --git a/hogql_parser/__init__.pyi b/hogql_parser/__init__.pyi index 69734c92cc41f..e36c09e629fba 100644 --- a/hogql_parser/__init__.pyi +++ b/hogql_parser/__init__.pyi @@ -1,4 +1,4 @@ -from posthog.hogql.ast import SelectQuery, SelectUnionQuery, Program +from posthog.hogql.ast import SelectQuery, SelectSetQuery, Program from posthog.hogql.base import AST def parse_expr(expr: str, /, *, is_internal: bool = False) -> AST: @@ -15,7 +15,7 @@ def parse_order_expr(expr: str, /, *, is_internal: bool = False) -> AST: """ ... -def parse_select(expr: str, /, *, is_internal: bool = False) -> SelectQuery | SelectUnionQuery: +def parse_select(expr: str, /, *, is_internal: bool = False) -> SelectQuery | SelectSetQuery: """Parse the HogQL SELECT statement string into an AST. If the expr `is_internal`, spans and notices won't be included in the AST. diff --git a/hogql_parser/parser.cpp b/hogql_parser/parser.cpp index 128f7006db93b..177b4ec72b4b0 100644 --- a/hogql_parser/parser.cpp +++ b/hogql_parser/parser.cpp @@ -827,9 +827,9 @@ class HogQLParseTreeConverter : public HogQLParserBaseVisitor { // HogQL rules VISIT(Select) { - auto select_union_stmt_ctx = ctx->selectUnionStmt(); - if (select_union_stmt_ctx) { - return visit(select_union_stmt_ctx); + auto select_set_stmt_ctx = ctx->selectSetStmt(); + if (select_set_stmt_ctx) { + return visit(select_set_stmt_ctx); } auto select_stmt_ctx = ctx->selectStmt(); @@ -851,68 +851,48 @@ class HogQLParseTreeConverter : public HogQLParserBaseVisitor { return visitAsPyObject(placeholder_ctx); } - return visit(ctx->selectUnionStmt()); + return visit(ctx->selectSetStmt()); } - VISIT(SelectUnionStmt) { - // Using a vector of PyObjects atypically here, because this is a precursor of flattened_queries - vector select_queries; - auto select_stmt_with_parens_ctxs = ctx->selectStmtWithParens(); - select_queries.reserve(select_stmt_with_parens_ctxs.size()); - for (auto select_stmt_with_parens_ctx : select_stmt_with_parens_ctxs) { - try { - select_queries.push_back(visitAsPyObject(select_stmt_with_parens_ctx)); - } catch (...) { - X_Py_DECREF_ALL(select_queries); - throw; - } - } - PyObject* flattened_queries = PyList_New(0); - if (!flattened_queries) { - X_Py_DECREF_ALL(select_queries); + VISIT(SelectSetStmt) { + PyObject* initial_query = visitAsPyObject(ctx->selectStmtWithParens()); + PyObject* select_query = NULL; + PyObject* select_queries = PyList_New(0); + if (!select_queries) { throw PyInternalError(); } - for (auto query : select_queries) { - int is_select_query = is_ast_node_instance(query, "SelectQuery"); - if (is_select_query == -1) goto select_queries_loop_py_error; - if (is_ast_node_instance(query, "SelectQuery")) { - int append_code = PyList_Append(flattened_queries, query); - if (append_code == -1) goto select_queries_loop_py_error; - } else if (is_ast_node_instance(query, "SelectUnionQuery")) { - // Extend flattened_queries with sub_select_queries - PyObject* sub_select_queries = PyObject_GetAttrString(query, "select_queries"); - if (!sub_select_queries) goto select_queries_loop_py_error; - int extend_code = X_PyList_Extend(flattened_queries, sub_select_queries); - if (extend_code == -1) goto select_queries_loop_py_error; - Py_DECREF(sub_select_queries); - } else if (is_ast_node_instance(query, "Placeholder")) { - int append_code = PyList_Append(flattened_queries, query); - if (append_code == -1) goto select_queries_loop_py_error; - } else { - Py_DECREF(flattened_queries); - X_Py_DECREF_ALL(select_queries); - throw ParsingError("Unexpected query node type: " + string(Py_TYPE(query)->tp_name)); + + try { + for (auto subsequent : ctx->subsequentSelectSetClause()) { + char* set_operator; + if (subsequent->UNION() && subsequent->ALL()) { + set_operator = "UNION ALL"; + } else if (subsequent->INTERSECT()) { + set_operator = "INTERSECT"; + } else if (subsequent->EXCEPT()) { + set_operator = "EXCEPT"; + } else { + throw SyntaxError("Set operator must be one of UNION ALL, INTERSECT, and EXCEPT"); + } + select_query = visitAsPyObject(subsequent->selectStmtWithParens()); + PyObject* query = build_ast_node("SelectSetNode", "{s:N,s:N}", "select_query", select_query, "set_operator", PyUnicode_FromString(set_operator)); + if (!query) { + throw PyInternalError(); + } + PyList_Append(select_queries, query); } + } catch (...) { + Py_DECREF(select_queries); + Py_DECREF(initial_query); + throw; } - goto select_queries_loop_success; - select_queries_loop_py_error: - X_Py_DECREF_ALL(select_queries); - Py_DECREF(flattened_queries); - throw PyInternalError(); - select_queries_loop_success: - X_Py_DECREF_ALL(select_queries); - Py_ssize_t flattened_queries_size = PyList_Size(flattened_queries); - if (flattened_queries_size == -1) { - Py_DECREF(flattened_queries); - throw PyInternalError(); - } - if (flattened_queries_size == 1) { - PyObject* query = PyList_GET_ITEM(flattened_queries, 0); - Py_INCREF(query); - Py_DECREF(flattened_queries); - return query; + + if (PyList_Size(select_queries) == 0) { + Py_DECREF(select_queries); + return initial_query; } - RETURN_NEW_AST_NODE("SelectUnionQuery", "{s:N}", "select_queries", flattened_queries); + + RETURN_NEW_AST_NODE("SelectSetQuery", "{s:N, s:N}", "initial_select_query", initial_query, "subsequent_select_queries", select_queries); } VISIT(SelectStmt) { @@ -1632,7 +1612,7 @@ class HogQLParseTreeConverter : public HogQLParserBaseVisitor { RETURN_NEW_AST_NODE("ArithmeticOperation", "{s:N,s:N,s:N}", "left", left, "right", right, "op", op); } - VISIT(ColumnExprSubquery) { return visit(ctx->selectUnionStmt()); } + VISIT(ColumnExprSubquery) { return visit(ctx->selectSetStmt()); } VISIT(ColumnExprArray) { RETURN_NEW_AST_NODE("Array", "{s:N}", "exprs", visitAsPyObjectOrEmptyList(ctx->columnExprList())); @@ -2286,7 +2266,7 @@ class HogQLParseTreeConverter : public HogQLParserBaseVisitor { VISIT(WithExprSubquery) { string name = visitAsString(ctx->identifier()); RETURN_NEW_AST_NODE( - "CTE", "{s:s#,s:N,s:s}", "name", name.data(), name.size(), "expr", visitAsPyObject(ctx->selectUnionStmt()), + "CTE", "{s:s#,s:N,s:s}", "name", name.data(), name.size(), "expr", visitAsPyObject(ctx->selectSetStmt()), "cte_type", "subquery" ); } @@ -2332,7 +2312,7 @@ class HogQLParseTreeConverter : public HogQLParserBaseVisitor { RETURN_NEW_AST_NODE("Field", "{s:N}", "chain", X_PyList_FromStrings(chain)); } - VISIT(TableExprSubquery) { return visit(ctx->selectUnionStmt()); } + VISIT(TableExprSubquery) { return visit(ctx->selectSetStmt()); } VISIT(TableExprPlaceholder) { return visitAsPyObject(ctx->placeholder()); } diff --git a/hogql_parser/setup.py b/hogql_parser/setup.py index bd336c6fa6654..dd38c3371fb47 100644 --- a/hogql_parser/setup.py +++ b/hogql_parser/setup.py @@ -32,7 +32,7 @@ setup( name="hogql_parser", - version="1.0.45", + version="1.0.46", url="https://github.com/PostHog/posthog/tree/master/hogql_parser", author="PostHog Inc.", author_email="hey@posthog.com", diff --git a/mypy-baseline.txt b/mypy-baseline.txt index 57a7e095f6298..86c1857ca8e31 100644 --- a/mypy-baseline.txt +++ b/mypy-baseline.txt @@ -88,10 +88,10 @@ posthog/hogql/visitor.py:0: error: Incompatible types in assignment (expression posthog/hogql/visitor.py:0: error: Incompatible types in assignment (expression has type "OrderExpr", variable has type "CTE") [assignment] posthog/hogql/visitor.py:0: error: Incompatible types in assignment (expression has type "Expr", variable has type "CTE") [assignment] posthog/hogql/visitor.py:0: error: Incompatible types in assignment (expression has type "WindowExpr", variable has type "CTE") [assignment] -posthog/hogql/visitor.py:0: error: Incompatible types in assignment (expression has type "FieldAliasType", variable has type "BaseTableType | SelectUnionQueryType | SelectQueryType | SelectQueryAliasType | SelectViewType") [assignment] -posthog/hogql/visitor.py:0: error: Incompatible types in assignment (expression has type "Type", variable has type "BaseTableType | SelectUnionQueryType | SelectQueryType | SelectQueryAliasType | SelectViewType") [assignment] +posthog/hogql/visitor.py:0: error: Incompatible types in assignment (expression has type "FieldAliasType", variable has type "BaseTableType | SelectSetQueryType | SelectQueryType | SelectQueryAliasType | SelectViewType") [assignment] +posthog/hogql/visitor.py:0: error: Incompatible types in assignment (expression has type "Type", variable has type "BaseTableType | SelectSetQueryType | SelectQueryType | SelectQueryAliasType | SelectViewType") [assignment] posthog/models/filters/mixins/simplify.py:0: error: Incompatible type for lookup 'pk': (got "str | int | list[str]", expected "str | int") [misc] -posthog/hogql/resolver_utils.py:0: error: Argument 1 to "lookup_field_by_name" has incompatible type "SelectQueryType | SelectUnionQueryType"; expected "SelectQueryType" [arg-type] +posthog/hogql/resolver_utils.py:0: error: Argument 1 to "lookup_field_by_name" has incompatible type "SelectQueryType | SelectSetQueryType"; expected "SelectQueryType" [arg-type] posthog/helpers/dashboard_templates.py:0: error: Incompatible types in assignment (expression has type "str | None", variable has type "str | Combinable") [assignment] posthog/hogql/parser.py:0: error: Item "None" of "list[Expr] | None" has no attribute "__iter__" (not iterable) [union-attr] posthog/hogql/parser.py:0: error: "None" has no attribute "text" [attr-defined] @@ -161,23 +161,22 @@ 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: List comprehension has incompatible type List[SelectQueryType | None]; expected List[SelectQueryType] [misc] 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: 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: Incompatible types in assignment (expression has type "Expr", variable has type "SelectQuery | SelectSetQuery | 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 "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: Argument 1 to "clone_expr" has incompatible type "SelectQuery | SelectSetQuery | Field | None"; expected "Expr" [arg-type] 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: 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: Argument "select_query_type" to "SelectViewType" has incompatible type "SelectQueryType | None"; expected "SelectQueryType | SelectSetQueryType" [arg-type] +posthog/hogql/resolver.py:0: error: Item "None" of "SelectQuery | SelectSetQuery | 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 | SelectSetQueryType" [arg-type] +posthog/hogql/resolver.py:0: error: Item "None" of "SelectQuery | SelectSetQuery | 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 | SelectSetQueryType | SelectQueryType | SelectQueryAliasType | SelectViewType | None") [assignment] +posthog/hogql/resolver.py:0: error: Argument 1 to "append" of "list" has incompatible type "BaseTableType | SelectSetQueryType | SelectQueryType | SelectQueryAliasType | SelectViewType | None"; expected "SelectQueryType | SelectSetQueryType" [arg-type] 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] @@ -193,12 +192,12 @@ posthog/hogql_queries/insights/trends/aggregation_operations.py:0: note: "List" posthog/hogql_queries/insights/trends/aggregation_operations.py:0: note: Consider using "Sequence" instead, which is covariant posthog/hogql_queries/insights/trends/aggregation_operations.py:0: error: List item 1 has incompatible type "str | None"; expected "str" [list-item] posthog/hogql_queries/insights/trends/aggregation_operations.py:0: error: Argument "chain" to "Field" has incompatible type "list[str | int] | list[str]"; expected "list[str | int]" [arg-type] -posthog/hogql_queries/insights/trends/aggregation_operations.py:0: error: Item "SelectUnionQuery" of "SelectQuery | SelectUnionQuery" has no attribute "select" [union-attr] -posthog/hogql_queries/insights/trends/aggregation_operations.py:0: error: Item "SelectUnionQuery" of "SelectQuery | SelectUnionQuery" has no attribute "select" [union-attr] -posthog/hogql_queries/insights/trends/aggregation_operations.py:0: error: Item "SelectUnionQuery" of "SelectQuery | SelectUnionQuery" has no attribute "group_by" [union-attr] +posthog/hogql_queries/insights/trends/aggregation_operations.py:0: error: Item "SelectSetQuery" of "SelectQuery | SelectSetQuery" has no attribute "select" [union-attr] +posthog/hogql_queries/insights/trends/aggregation_operations.py:0: error: Item "SelectSetQuery" of "SelectQuery | SelectSetQuery" has no attribute "select" [union-attr] +posthog/hogql_queries/insights/trends/aggregation_operations.py:0: error: Item "SelectSetQuery" of "SelectQuery | SelectSetQuery" has no attribute "group_by" [union-attr] posthog/hogql_queries/insights/trends/aggregation_operations.py:0: error: Item "None" of "list[Expr] | None" has no attribute "append" [union-attr] -posthog/hogql_queries/insights/trends/aggregation_operations.py:0: error: Item "SelectUnionQuery" of "SelectQuery | SelectUnionQuery" has no attribute "select" [union-attr] -posthog/hogql_queries/insights/trends/aggregation_operations.py:0: error: Item "SelectUnionQuery" of "SelectQuery | SelectUnionQuery" has no attribute "group_by" [union-attr] +posthog/hogql_queries/insights/trends/aggregation_operations.py:0: error: Item "SelectSetQuery" of "SelectQuery | SelectSetQuery" has no attribute "select" [union-attr] +posthog/hogql_queries/insights/trends/aggregation_operations.py:0: error: Item "SelectSetQuery" of "SelectQuery | SelectSetQuery" has no attribute "group_by" [union-attr] posthog/hogql_queries/insights/trends/aggregation_operations.py:0: error: Item "None" of "list[Expr] | Any | None" has no attribute "append" [union-attr] posthog/hogql/transforms/lazy_tables.py:0: error: Incompatible types in assignment (expression has type "dict[Never, Never]", variable has type "list[ConstraintOverride]") [assignment] posthog/hogql/transforms/lazy_tables.py:0: error: Non-overlapping equality check (left operand type: "TableType", right operand type: "LazyTableType") [comparison-overlap] @@ -206,7 +205,7 @@ posthog/hogql/transforms/lazy_tables.py:0: error: Non-overlapping equality check posthog/hogql/transforms/lazy_tables.py:0: error: Name "chain" already defined on line 0 [no-redef] posthog/hogql/transforms/lazy_tables.py:0: error: Subclass of "TableType" and "LazyTableType" cannot exist: would have incompatible method signatures [unreachable] posthog/hogql/transforms/lazy_tables.py:0: error: Statement is unreachable [unreachable] -posthog/hogql/transforms/lazy_tables.py:0: error: Incompatible types in assignment (expression has type "BaseTableType | SelectUnionQueryType | SelectQueryType | SelectQueryAliasType | SelectViewType", variable has type "SelectQueryAliasType | None") [assignment] +posthog/hogql/transforms/lazy_tables.py:0: error: Incompatible types in assignment (expression has type "BaseTableType | SelectSetQueryType | SelectQueryType | SelectQueryAliasType | SelectViewType", variable has type "SelectQueryAliasType | None") [assignment] posthog/hogql/transforms/in_cohort.py:0: error: Incompatible default for argument "context" (default has type "None", argument has type "HogQLContext") [assignment] posthog/hogql/transforms/in_cohort.py:0: note: PEP 484 prohibits implicit Optional. Accordingly, mypy has changed its default to no_implicit_optional=True posthog/hogql/transforms/in_cohort.py:0: note: Use https://github.com/hauntsaninja/no_implicit_optional to automatically upgrade your codebase @@ -217,7 +216,7 @@ posthog/hogql/transforms/in_cohort.py:0: note: PEP 484 prohibits implicit Option posthog/hogql/transforms/in_cohort.py:0: note: Use https://github.com/hauntsaninja/no_implicit_optional to automatically upgrade your codebase posthog/hogql/transforms/in_cohort.py:0: error: Incompatible type for lookup 'team_id': (got "int | None", expected "str | int") [misc] posthog/hogql/transforms/in_cohort.py:0: error: Incompatible type for lookup 'team_id': (got "int | None", expected "str | int") [misc] -posthog/hogql/transforms/in_cohort.py:0: error: Argument "table" to "JoinExpr" has incompatible type "Expr"; expected "SelectQuery | SelectUnionQuery | Field | None" [arg-type] +posthog/hogql/transforms/in_cohort.py:0: error: Argument "table" to "JoinExpr" has incompatible type "Expr"; expected "SelectQuery | SelectSetQuery | Field | None" [arg-type] posthog/hogql/transforms/in_cohort.py:0: error: List item 0 has incompatible type "SelectQueryType | None"; expected "SelectQueryType" [list-item] posthog/hogql/transforms/in_cohort.py:0: error: Item "None" of "JoinConstraint | None" has no attribute "expr" [union-attr] posthog/hogql/transforms/in_cohort.py:0: error: Item "Expr" of "Expr | Any" has no attribute "left" [union-attr] @@ -332,17 +331,16 @@ posthog/hogql/filters.py:0: error: Incompatible default for argument "team" (def 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: Incompatible types in assignment (expression has type "None", variable has type "str | SelectQuery | SelectSetQuery") [assignment] +posthog/hogql/query.py:0: error: Incompatible types in assignment (expression has type "Expr", variable has type "SelectQuery | SelectSetQuery") [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/hogql/query.py:0: error: Subclass of "SelectQuery" and "SelectSetQuery" cannot exist: would have incompatible method signatures [unreachable] posthog/queries/person_query.py:0: error: Incompatible type for lookup 'pk': (got "str | int | list[str]", expected "str | int") [misc] posthog/api/action.py:0: error: Argument 1 to has incompatible type "*tuple[str, ...]"; expected "type[BaseRenderer]" [arg-type] 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] posthog/hogql_queries/hogql_query_runner.py:0: error: Statement is unreachable [unreachable] -posthog/hogql_queries/hogql_query_runner.py:0: error: Incompatible return value type (got "SelectQuery | SelectUnionQuery", expected "SelectQuery") [return-value] +posthog/hogql_queries/hogql_query_runner.py:0: error: Incompatible return value type (got "SelectQuery | SelectSetQuery", expected "SelectQuery") [return-value] posthog/hogql_queries/events_query_runner.py:0: error: Statement is unreachable [unreachable] posthog/queries/breakdown_props.py:0: error: Argument 1 to "translate_hogql" has incompatible type "str | int"; expected "str" [arg-type] posthog/queries/breakdown_props.py:0: error: Incompatible type for lookup 'pk': (got "str | None", expected "str | int") [misc] @@ -386,15 +384,15 @@ posthog/hogql_queries/insights/stickiness_query_runner.py:0: error: Module "djan posthog/hogql_queries/insights/retention_query_runner.py:0: error: Item "None" of "JoinExpr | None" has no attribute "sample" [union-attr] posthog/hogql_queries/insights/retention_query_runner.py:0: error: Unsupported operand types for - ("int" and "None") [operator] posthog/hogql_queries/insights/retention_query_runner.py:0: note: Right operand is of type "int | None" -posthog/hogql_queries/insights/retention_query_runner.py:0: error: Item "SelectUnionQuery" of "SelectQuery | SelectUnionQuery" has no attribute "select" [union-attr] -posthog/hogql_queries/insights/retention_query_runner.py:0: error: Incompatible return value type (got "SelectQuery | SelectUnionQuery", expected "SelectQuery") [return-value] +posthog/hogql_queries/insights/retention_query_runner.py:0: error: Item "SelectSetQuery" of "SelectQuery | SelectSetQuery" has no attribute "select" [union-attr] +posthog/hogql_queries/insights/retention_query_runner.py:0: error: Incompatible return value type (got "SelectQuery | SelectSetQuery", expected "SelectQuery") [return-value] posthog/hogql_queries/insights/lifecycle_query_runner.py:0: error: Module "django.utils.timezone" does not explicitly export attribute "datetime" [attr-defined] posthog/hogql_queries/insights/lifecycle_query_runner.py:0: error: Incompatible types in assignment (expression has type "Expr", variable has type "Constant") [assignment] posthog/hogql_queries/insights/lifecycle_query_runner.py:0: error: Incompatible types in assignment (expression has type "Expr", variable has type "Constant") [assignment] posthog/hogql_queries/insights/lifecycle_query_runner.py:0: error: Argument "exprs" to "And" has incompatible type "list[CompareOperation]"; expected "list[Expr]" [arg-type] posthog/hogql_queries/insights/lifecycle_query_runner.py:0: note: "List" is invariant -- see https://mypy.readthedocs.io/en/stable/common_issues.html#variance posthog/hogql_queries/insights/lifecycle_query_runner.py:0: note: Consider using "Sequence" instead, which is covariant -posthog/hogql_queries/insights/lifecycle_query_runner.py:0: error: Item "SelectUnionQuery" of "SelectQuery | SelectUnionQuery" has no attribute "select_from" [union-attr] +posthog/hogql_queries/insights/lifecycle_query_runner.py:0: error: Item "SelectSetQuery" of "SelectQuery | SelectSetQuery" has no attribute "select_from" [union-attr] posthog/hogql_queries/insights/lifecycle_query_runner.py:0: error: Item "None" of "JoinExpr | Any | None" has no attribute "sample" [union-attr] posthog/hogql_queries/insights/funnels/funnels_query_runner.py:0: error: Module "django.utils.timezone" does not explicitly export attribute "datetime" [attr-defined] posthog/api/survey.py:0: error: Incompatible types in assignment (expression has type "Any | Sequence[Any] | None", variable has type "Survey | None") [assignment] @@ -503,19 +501,19 @@ posthog/hogql/test/test_resolver.py:0: error: Item "None" of "JoinConstraint | A posthog/hogql/test/test_resolver.py:0: error: Item "None" of "JoinExpr | None" has no attribute "next_join" [union-attr] posthog/hogql/test/test_resolver.py:0: error: Item "None" of "JoinExpr | Any | None" has no attribute "constraint" [union-attr] posthog/hogql/test/test_resolver.py:0: error: Item "None" of "JoinConstraint | Any | None" has no attribute "constraint_type" [union-attr] -posthog/hogql/test/test_resolver.py:0: error: Item "SelectUnionQueryType" of "SelectQueryType | SelectUnionQueryType | None" has no attribute "columns" [union-attr] -posthog/hogql/test/test_resolver.py:0: error: Item "None" of "SelectQueryType | SelectUnionQueryType | None" has no attribute "columns" [union-attr] +posthog/hogql/test/test_resolver.py:0: error: Item "SelectSetQueryType" of "SelectQueryType | SelectSetQueryType | None" has no attribute "columns" [union-attr] +posthog/hogql/test/test_resolver.py:0: error: Item "None" of "SelectQueryType | SelectSetQueryType | None" has no attribute "columns" [union-attr] posthog/hogql/test/test_resolver.py:0: error: "FieldOrTable" has no attribute "fields" [attr-defined] posthog/hogql/test/test_resolver.py:0: error: "FieldOrTable" has no attribute "fields" [attr-defined] posthog/hogql/test/test_resolver.py:0: error: "FieldOrTable" has no attribute "fields" [attr-defined] posthog/hogql/test/test_resolver.py:0: error: Item "None" of "JoinExpr | None" has no attribute "table" [union-attr] -posthog/hogql/test/test_resolver.py:0: error: Argument 1 to "clone_expr" has incompatible type "SelectQuery | SelectUnionQuery | Field | Any | None"; expected "Expr" [arg-type] +posthog/hogql/test/test_resolver.py:0: error: Argument 1 to "clone_expr" has incompatible type "SelectQuery | SelectSetQuery | Field | Any | None"; expected "Expr" [arg-type] posthog/hogql/test/test_resolver.py:0: error: Item "None" of "JoinExpr | None" has no attribute "alias" [union-attr] posthog/hogql/test/test_property.py:0: error: Argument 1 to "_property_to_expr" of "TestProperty" has incompatible type "HogQLPropertyFilter"; expected "PropertyGroup | Property | dict[Any, Any] | list[Any]" [arg-type] posthog/hogql/test/test_printer.py:0: error: Argument 2 to "Database" has incompatible type "int"; expected "WeekStartDay | None" [arg-type] posthog/hogql/test/test_printer.py:0: error: Argument 2 to "Database" has incompatible type "int"; expected "WeekStartDay | None" [arg-type] -posthog/hogql/test/test_printer.py:0: error: Item "SelectUnionQuery" of "SelectQuery | SelectUnionQuery" has no attribute "settings" [union-attr] -posthog/hogql/test/test_printer.py:0: error: Item "SelectUnionQuery" of "SelectQuery | SelectUnionQuery" has no attribute "settings" [union-attr] +posthog/hogql/test/test_printer.py:0: error: Item "SelectSetQuery" of "SelectQuery | SelectSetQuery" has no attribute "settings" [union-attr] +posthog/hogql/test/test_printer.py:0: error: Item "SelectSetQuery" of "SelectQuery | SelectSetQuery" has no attribute "settings" [union-attr] posthog/hogql/test/test_printer.py:0: error: "TestPrinter" has no attribute "snapshot" [attr-defined] posthog/hogql/test/test_modifiers.py:0: error: Unsupported right operand type for in ("str | None") [operator] posthog/hogql/test/test_modifiers.py:0: error: Unsupported right operand type for in ("str | None") [operator] @@ -531,7 +529,7 @@ posthog/hogql/test/test_modifiers.py:0: error: Unsupported right operand type fo posthog/hogql/test/test_modifiers.py:0: error: Unsupported right operand type for in ("str | None") [operator] posthog/hogql/test/test_modifiers.py:0: error: Unsupported right operand type for in ("str | None") [operator] posthog/hogql/test/_test_parser.py:0: error: Invalid base class [misc] -posthog/hogql/test/_test_parser.py:0: error: Argument "table" to "JoinExpr" has incompatible type "Placeholder"; expected "SelectQuery | SelectUnionQuery | Field | None" [arg-type] +posthog/hogql/test/_test_parser.py:0: error: Argument "table" to "JoinExpr" has incompatible type "Placeholder"; expected "SelectQuery | SelectSetQuery | Field | None" [arg-type] posthog/hogql/test/_test_parser.py:0: error: Item "None" of "JoinExpr | None" has no attribute "table" [union-attr] posthog/hogql/test/_test_parser.py:0: error: Item "None" of "JoinExpr | None" has no attribute "table" [union-attr] posthog/hogql/test/_test_parser.py:0: error: Item "None" of "JoinExpr | None" has no attribute "table" [union-attr] diff --git a/posthog/api/test/test_plugin.py b/posthog/api/test/test_plugin.py index f92350045a38c..10967d63bb873 100644 --- a/posthog/api/test/test_plugin.py +++ b/posthog/api/test/test_plugin.py @@ -371,35 +371,36 @@ def test_update_plugin_auth(self, mock_sync_from_plugin_archive, mock_get, mock_ self.assertEqual(response.status_code, 403) self.assertEqual(mock_sync_from_plugin_archive.call_count, 2) # Not extracted on auth failure - @freeze_time("2021-08-25T22:09:14.252Z") def test_delete_plugin_auth(self, mock_get, mock_reload): - repo_url = "https://github.com/PostHog/helloworldplugin" - response = self.client.post("/api/organizations/@current/plugins/", {"url": repo_url}) - self.assertEqual(response.status_code, 201) + with freeze_time("2021-08-25T22:09:14.252Z"): + repo_url = "https://github.com/PostHog/helloworldplugin" + response = self.client.post("/api/organizations/@current/plugins/", {"url": repo_url}) + self.assertEqual(response.status_code, 201) - plugin_id = response.json()["id"] + with freeze_time("2021-08-25T22:09:14.253Z"): + plugin_id = response.json()["id"] - api_url = "/api/organizations/@current/plugins/{}".format(response.json()["id"]) + api_url = "/api/organizations/@current/plugins/{}".format(response.json()["id"]) - for level in ( - Organization.PluginsAccessLevel.NONE, - Organization.PluginsAccessLevel.CONFIG, - ): - self.organization.plugins_access_level = level + for level in ( + Organization.PluginsAccessLevel.NONE, + Organization.PluginsAccessLevel.CONFIG, + ): + self.organization.plugins_access_level = level + self.organization.save() + response = self.client.delete(api_url) + self.assertEqual(response.status_code, 403) + + self.organization.plugins_access_level = Organization.PluginsAccessLevel.INSTALL self.organization.save() response = self.client.delete(api_url) - self.assertEqual(response.status_code, 403) - - self.organization.plugins_access_level = Organization.PluginsAccessLevel.INSTALL - self.organization.save() - response = self.client.delete(api_url) self.assertEqual(response.status_code, 204) self.assert_plugin_activity( [ { "user": {"first_name": "", "email": "user1@posthog.com"}, - "activity": "installed", - "created_at": "2021-08-25T22:09:14.252000Z", + "activity": "uninstalled", + "created_at": "2021-08-25T22:09:14.253000Z", "scope": "Plugin", "item_id": str(plugin_id), "detail": { @@ -412,7 +413,7 @@ def test_delete_plugin_auth(self, mock_get, mock_reload): }, { "user": {"first_name": "", "email": "user1@posthog.com"}, - "activity": "uninstalled", + "activity": "installed", "created_at": "2021-08-25T22:09:14.252000Z", "scope": "Plugin", "item_id": str(plugin_id), diff --git a/posthog/batch_exports/http.py b/posthog/batch_exports/http.py index 5d2589065345a..72bc94adf03bd 100644 --- a/posthog/batch_exports/http.py +++ b/posthog/batch_exports/http.py @@ -183,7 +183,7 @@ def to_representation(self, instance: BatchExportDestination) -> dict: class HogQLSelectQueryField(serializers.Field): - def to_internal_value(self, data: str) -> ast.SelectQuery | ast.SelectUnionQuery: + def to_internal_value(self, data: str) -> ast.SelectQuery | ast.SelectSetQuery: """Parse a HogQL SelectQuery from a string query.""" try: parsed_query = parse_select(data) @@ -329,7 +329,7 @@ def serialize_hogql_query_to_batch_export_schema(self, hogql_query: ast.SelectQu return batch_export_schema - def validate_hogql_query(self, hogql_query: ast.SelectQuery | ast.SelectUnionQuery) -> ast.SelectQuery: + def validate_hogql_query(self, hogql_query: ast.SelectQuery | ast.SelectSetQuery) -> ast.SelectQuery: """Validate a HogQLQuery being used for batch exports. This method essentially checks that a query is supported by batch exports: @@ -338,7 +338,7 @@ def validate_hogql_query(self, hogql_query: ast.SelectQuery | ast.SelectUnionQue 3. Query must SELECT FROM events, and only from events. """ - if isinstance(hogql_query, ast.SelectUnionQuery): + if isinstance(hogql_query, ast.SelectSetQuery): raise serializers.ValidationError("UNIONs are not supported") parsed = cast(ast.SelectQuery, hogql_query) diff --git a/posthog/hogql/ast.py b/posthog/hogql/ast.py index c5aef314244ed..11c7f001c50b9 100644 --- a/posthog/hogql/ast.py +++ b/posthog/hogql/ast.py @@ -1,5 +1,6 @@ from enum import StrEnum -from typing import Any, Literal, Optional, Union +from typing import Any, Literal, Optional, Union, get_args +from collections.abc import Sequence from dataclasses import dataclass, field from posthog.hogql.base import Type, Expr, CTE, ConstantType, UnknownType, AST @@ -173,7 +174,7 @@ def get_child(self, name: str, context: HogQLContext) -> Type: TableOrSelectType = Union[ - BaseTableType, "SelectUnionQueryType", "SelectQueryType", "SelectQueryAliasType", "SelectViewType" + BaseTableType, "SelectSetQueryType", "SelectQueryType", "SelectQueryAliasType", "SelectViewType" ] @@ -243,9 +244,9 @@ class SelectQueryType(Type): tables: dict[str, TableOrSelectType] = field(default_factory=dict) ctes: dict[str, CTE] = field(default_factory=dict) # all from and join subqueries without aliases - anonymous_tables: list[Union["SelectQueryType", "SelectUnionQueryType"]] = field(default_factory=list) + anonymous_tables: list[Union["SelectQueryType", "SelectSetQueryType"]] = field(default_factory=list) # the parent select query, if this is a lambda - parent: Optional[Union["SelectQueryType", "SelectUnionQueryType"]] = None + parent: Optional[Union["SelectQueryType", "SelectSetQueryType"]] = None def get_alias_for_table_type(self, table_type: TableOrSelectType) -> Optional[str]: for key, value in self.tables.items(): @@ -276,8 +277,8 @@ def resolve_constant_type(self, context: HogQLContext) -> "ConstantType": @dataclass(kw_only=True) -class SelectUnionQueryType(Type): - types: list[SelectQueryType] +class SelectSetQueryType(Type): + types: list[Union[SelectQueryType, "SelectSetQueryType"]] def get_alias_for_table_type(self, table_type: TableOrSelectType) -> Optional[str]: return self.types[0].get_alias_for_table_type(table_type) @@ -296,7 +297,7 @@ def resolve_column_constant_type(self, name: str, context: HogQLContext) -> "Con class SelectViewType(Type): view_name: str alias: str - select_query_type: SelectQueryType | SelectUnionQueryType + select_query_type: SelectQueryType | SelectSetQueryType def get_child(self, name: str, context: HogQLContext) -> Type: if name == "*": @@ -343,7 +344,7 @@ def resolve_column_constant_type(self, name: str, context: HogQLContext) -> "Con @dataclass(kw_only=True) class SelectQueryAliasType(Type): alias: str - select_query_type: SelectQueryType | SelectUnionQueryType + select_query_type: SelectQueryType | SelectSetQueryType def get_child(self, name: str, context: HogQLContext) -> Type: if name == "*": @@ -763,7 +764,7 @@ class JoinExpr(Expr): type: Optional[TableOrSelectType] = None join_type: Optional[str] = None - table: Optional[Union["SelectQuery", "SelectUnionQuery", Field]] = None + table: Optional[Union["SelectQuery", "SelectSetQuery", Field]] = None table_args: Optional[list[Expr]] = None alias: Optional[str] = None table_final: Optional[bool] = None @@ -820,10 +821,35 @@ class SelectQuery(Expr): view_name: Optional[str] = None +SetOperator = Literal["UNION ALL", "INTERSECT", "EXCEPT"] + + +@dataclass(kw_only=True) +class SelectSetNode: + select_query: Union[SelectQuery, "SelectSetQuery"] + set_operator: SetOperator + + def __post_init__(self): + if self.set_operator not in get_args(SetOperator): + raise ValueError("Invalid Set Operator") + + @dataclass(kw_only=True) -class SelectUnionQuery(Expr): - type: Optional[SelectUnionQueryType] = None - select_queries: list[SelectQuery] +class SelectSetQuery(Expr): + type: Optional[SelectSetQueryType] = None + initial_select_query: Union[SelectQuery, "SelectSetQuery"] + subsequent_select_queries: list[SelectSetNode] + + @classmethod + def create_from_queries( + cls, queries: Sequence[Union[SelectQuery, "SelectSetQuery"]], set_operator: SetOperator + ) -> "SelectSetQuery": + return SelectSetQuery( + initial_select_query=queries[0], + subsequent_select_queries=[ + SelectSetNode(select_query=query, set_operator=set_operator) for query in queries[1:] + ], + ) @dataclass(kw_only=True) diff --git a/posthog/hogql/autocomplete.py b/posthog/hogql/autocomplete.py index 433cdce356382..09b5af34be0b9 100644 --- a/posthog/hogql/autocomplete.py +++ b/posthog/hogql/autocomplete.py @@ -28,6 +28,7 @@ from posthog.hogql.timings import HogQLTimings from posthog.hogql.visitor import TraversingVisitor, clone_expr from posthog.hogql_queries.query_runner import get_query_runner +from posthog.hogql.resolver_utils import extract_select_queries from posthog.models.insight_variable import InsightVariable from posthog.models.property_definition import PropertyDefinition from posthog.models.team.team import Team @@ -475,8 +476,8 @@ def get_hogql_autocomplete( if isinstance(select_ast, ast.SelectQuery): ctes = select_ast.ctes - elif isinstance(select_ast, ast.SelectUnionQuery): - ctes = select_ast.select_queries[0].ctes + elif isinstance(select_ast, ast.SelectSetQuery): + ctes = next(extract_select_queries(select_ast)).ctes nearest_select = find_node.nearest_select_query or select_ast table_has_alias = ( diff --git a/posthog/hogql/database/schema/util/test/test_person_where_clause_extractor.py b/posthog/hogql/database/schema/util/test/test_person_where_clause_extractor.py index 3243f977415a4..73459b375879e 100644 --- a/posthog/hogql/database/schema/util/test/test_person_where_clause_extractor.py +++ b/posthog/hogql/database/schema/util/test/test_person_where_clause_extractor.py @@ -24,7 +24,7 @@ def _expr(s: Union[str, ast.Expr, None], placeholders: Optional[dict[str, ast.Ex def _select( s: str, placeholders: Optional[dict[str, ast.Expr]] = None, -) -> ast.SelectQuery | ast.SelectUnionQuery: +) -> ast.SelectQuery | ast.SelectSetQuery: parsed = parse_select(s, placeholders=placeholders) return parsed diff --git a/posthog/hogql/database/schema/util/test/test_session_v2_where_clause_extractor.py b/posthog/hogql/database/schema/util/test/test_session_v2_where_clause_extractor.py index b1076a60aeb4f..dc789e80d7458 100644 --- a/posthog/hogql/database/schema/util/test/test_session_v2_where_clause_extractor.py +++ b/posthog/hogql/database/schema/util/test/test_session_v2_where_clause_extractor.py @@ -26,7 +26,7 @@ def f(s: Union[str, ast.Expr, None], placeholders: Optional[dict[str, ast.Expr]] def parse( s: str, placeholders: Optional[dict[str, ast.Expr]] = None, -) -> ast.SelectQuery | ast.SelectUnionQuery: +) -> ast.SelectQuery | ast.SelectSetQuery: parsed = parse_select(s, placeholders=placeholders) return parsed @@ -363,7 +363,8 @@ def print_query(self, query: str) -> str: def test_select_with_timestamp(self): actual = self.print_query("SELECT session_id FROM sessions WHERE $start_timestamp > '2021-01-01'") - assert self.generalize_sql(actual) == snapshot("""\ + assert self.generalize_sql(actual) == snapshot( + """\ SELECT sessions.session_id AS session_id FROM @@ -381,7 +382,8 @@ def test_select_with_timestamp(self): WHERE ifNull(greater(sessions.`$start_timestamp`, %(hogql_val_2)s), 0) LIMIT 50000\ -""") +""" + ) def test_join_with_events(self): actual = self.print_query( @@ -396,7 +398,8 @@ def test_join_with_events(self): GROUP BY sessions.session_id """ ) - assert self.generalize_sql(actual) == snapshot("""\ + assert self.generalize_sql(actual) == snapshot( + """\ SELECT sessions.session_id AS session_id, uniq(events.uuid) @@ -417,7 +420,8 @@ def test_join_with_events(self): GROUP BY sessions.session_id LIMIT 50000\ -""") +""" + ) def test_union(self): actual = self.print_query( @@ -429,7 +433,8 @@ def test_union(self): WHERE events.timestamp < today() """ ) - assert self.generalize_sql(actual) == snapshot("""\ + assert self.generalize_sql(actual) == snapshot( + """\ SELECT 0 AS duration LIMIT 50000 @@ -451,7 +456,8 @@ def test_union(self): WHERE and(equals(events.team_id, ), less(toTimeZone(events.timestamp, %(hogql_val_4)s), today())) LIMIT 50000\ -""") +""" + ) def test_session_breakdown(self): actual = self.print_query( @@ -495,7 +501,8 @@ def test_session_breakdown(self): GROUP BY day_start, breakdown_value""" ) - assert self.generalize_sql(actual) == snapshot("""\ + assert self.generalize_sql(actual) == snapshot( + """\ SELECT count(DISTINCT e.`$session_id`) AS total, toStartOfDay(toTimeZone(e.timestamp, %(hogql_val_8)s)) AS day_start, @@ -535,7 +542,8 @@ def test_session_breakdown(self): day_start, breakdown_value LIMIT 50000\ -""") +""" + ) def test_session_replay_query(self): actual = self.print_query( @@ -548,7 +556,8 @@ def test_session_replay_query(self): GROUP BY session_id """ ) - assert self.generalize_sql(actual) == snapshot("""\ + assert self.generalize_sql(actual) == snapshot( + """\ SELECT s.session_id AS session_id, min(toTimeZone(s.min_first_timestamp, %(hogql_val_5)s)) AS start_time @@ -569,7 +578,8 @@ def test_session_replay_query(self): GROUP BY s.session_id LIMIT 50000\ -""") +""" + ) def test_urls_in_sessions_in_timestamp_query(self): actual = self.print_query( @@ -582,7 +592,8 @@ def test_urls_in_sessions_in_timestamp_query(self): where `$start_timestamp` >= now() - toIntervalDay(7) """ ) - assert self.generalize_sql(actual) == snapshot("""\ + assert self.generalize_sql(actual) == snapshot( + """\ SELECT sessions.session_id AS session_id, sessions.`$urls` AS `$urls`, @@ -603,4 +614,5 @@ def test_urls_in_sessions_in_timestamp_query(self): WHERE ifNull(greaterOrEquals(sessions.`$start_timestamp`, minus(now64(6, %(hogql_val_2)s), toIntervalDay(7))), 0) LIMIT 50000\ -""") +""" + ) diff --git a/posthog/hogql/database/schema/util/test/test_session_where_clause_extractor.py b/posthog/hogql/database/schema/util/test/test_session_where_clause_extractor.py index b1304fc53510b..a514af84ae8a7 100644 --- a/posthog/hogql/database/schema/util/test/test_session_where_clause_extractor.py +++ b/posthog/hogql/database/schema/util/test/test_session_where_clause_extractor.py @@ -26,7 +26,7 @@ def f(s: Union[str, ast.Expr, None], placeholders: Optional[dict[str, ast.Expr]] def parse( s: str, placeholders: Optional[dict[str, ast.Expr]] = None, -) -> ast.SelectQuery | ast.SelectUnionQuery: +) -> ast.SelectQuery | ast.SelectSetQuery: parsed = parse_select(s, placeholders=placeholders) return parsed diff --git a/posthog/hogql/grammar/HogQLLexer.g4 b/posthog/hogql/grammar/HogQLLexer.g4 index 6241425a64f2c..f4caeaf8df056 100644 --- a/posthog/hogql/grammar/HogQLLexer.g4 +++ b/posthog/hogql/grammar/HogQLLexer.g4 @@ -30,6 +30,7 @@ DESCENDING: D E S C E N D I N G; DISTINCT: D I S T I N C T; ELSE: E L S E; END: E N D; +EXCEPT: E X C E P T; EXTRACT: E X T R A C T; FINAL: F I N A L; FINALLY: F I N A L L Y; @@ -49,6 +50,7 @@ ILIKE: I L I K E; IN: I N; INF: I N F | I N F I N I T Y; INNER: I N N E R; +INTERSECT: I N T E R S E C T; INTERVAL: I N T E R V A L; IS: I S; JOIN: J O I N; diff --git a/posthog/hogql/grammar/HogQLLexer.interp b/posthog/hogql/grammar/HogQLLexer.interp index dc4c26657342d..f461a8e011b30 100644 --- a/posthog/hogql/grammar/HogQLLexer.interp +++ b/posthog/hogql/grammar/HogQLLexer.interp @@ -111,6 +111,8 @@ null null null null +null +null '->' '*' '`' @@ -189,6 +191,7 @@ DESCENDING DISTINCT ELSE END +EXCEPT EXTRACT FINAL FINALLY @@ -208,6 +211,7 @@ ILIKE IN INF INNER +INTERSECT INTERVAL IS JOIN @@ -351,6 +355,7 @@ DESCENDING DISTINCT ELSE END +EXCEPT EXTRACT FINAL FINALLY @@ -370,6 +375,7 @@ ILIKE IN INF INNER +INTERSECT INTERVAL IS JOIN @@ -527,4 +533,4 @@ IN_TEMPLATE_STRING IN_FULL_TEMPLATE_STRING atn: -[4, 0, 160, 1455, 6, -1, 6, -1, 6, -1, 2, 0, 7, 0, 2, 1, 7, 1, 2, 2, 7, 2, 2, 3, 7, 3, 2, 4, 7, 4, 2, 5, 7, 5, 2, 6, 7, 6, 2, 7, 7, 7, 2, 8, 7, 8, 2, 9, 7, 9, 2, 10, 7, 10, 2, 11, 7, 11, 2, 12, 7, 12, 2, 13, 7, 13, 2, 14, 7, 14, 2, 15, 7, 15, 2, 16, 7, 16, 2, 17, 7, 17, 2, 18, 7, 18, 2, 19, 7, 19, 2, 20, 7, 20, 2, 21, 7, 21, 2, 22, 7, 22, 2, 23, 7, 23, 2, 24, 7, 24, 2, 25, 7, 25, 2, 26, 7, 26, 2, 27, 7, 27, 2, 28, 7, 28, 2, 29, 7, 29, 2, 30, 7, 30, 2, 31, 7, 31, 2, 32, 7, 32, 2, 33, 7, 33, 2, 34, 7, 34, 2, 35, 7, 35, 2, 36, 7, 36, 2, 37, 7, 37, 2, 38, 7, 38, 2, 39, 7, 39, 2, 40, 7, 40, 2, 41, 7, 41, 2, 42, 7, 42, 2, 43, 7, 43, 2, 44, 7, 44, 2, 45, 7, 45, 2, 46, 7, 46, 2, 47, 7, 47, 2, 48, 7, 48, 2, 49, 7, 49, 2, 50, 7, 50, 2, 51, 7, 51, 2, 52, 7, 52, 2, 53, 7, 53, 2, 54, 7, 54, 2, 55, 7, 55, 2, 56, 7, 56, 2, 57, 7, 57, 2, 58, 7, 58, 2, 59, 7, 59, 2, 60, 7, 60, 2, 61, 7, 61, 2, 62, 7, 62, 2, 63, 7, 63, 2, 64, 7, 64, 2, 65, 7, 65, 2, 66, 7, 66, 2, 67, 7, 67, 2, 68, 7, 68, 2, 69, 7, 69, 2, 70, 7, 70, 2, 71, 7, 71, 2, 72, 7, 72, 2, 73, 7, 73, 2, 74, 7, 74, 2, 75, 7, 75, 2, 76, 7, 76, 2, 77, 7, 77, 2, 78, 7, 78, 2, 79, 7, 79, 2, 80, 7, 80, 2, 81, 7, 81, 2, 82, 7, 82, 2, 83, 7, 83, 2, 84, 7, 84, 2, 85, 7, 85, 2, 86, 7, 86, 2, 87, 7, 87, 2, 88, 7, 88, 2, 89, 7, 89, 2, 90, 7, 90, 2, 91, 7, 91, 2, 92, 7, 92, 2, 93, 7, 93, 2, 94, 7, 94, 2, 95, 7, 95, 2, 96, 7, 96, 2, 97, 7, 97, 2, 98, 7, 98, 2, 99, 7, 99, 2, 100, 7, 100, 2, 101, 7, 101, 2, 102, 7, 102, 2, 103, 7, 103, 2, 104, 7, 104, 2, 105, 7, 105, 2, 106, 7, 106, 2, 107, 7, 107, 2, 108, 7, 108, 2, 109, 7, 109, 2, 110, 7, 110, 2, 111, 7, 111, 2, 112, 7, 112, 2, 113, 7, 113, 2, 114, 7, 114, 2, 115, 7, 115, 2, 116, 7, 116, 2, 117, 7, 117, 2, 118, 7, 118, 2, 119, 7, 119, 2, 120, 7, 120, 2, 121, 7, 121, 2, 122, 7, 122, 2, 123, 7, 123, 2, 124, 7, 124, 2, 125, 7, 125, 2, 126, 7, 126, 2, 127, 7, 127, 2, 128, 7, 128, 2, 129, 7, 129, 2, 130, 7, 130, 2, 131, 7, 131, 2, 132, 7, 132, 2, 133, 7, 133, 2, 134, 7, 134, 2, 135, 7, 135, 2, 136, 7, 136, 2, 137, 7, 137, 2, 138, 7, 138, 2, 139, 7, 139, 2, 140, 7, 140, 2, 141, 7, 141, 2, 142, 7, 142, 2, 143, 7, 143, 2, 144, 7, 144, 2, 145, 7, 145, 2, 146, 7, 146, 2, 147, 7, 147, 2, 148, 7, 148, 2, 149, 7, 149, 2, 150, 7, 150, 2, 151, 7, 151, 2, 152, 7, 152, 2, 153, 7, 153, 2, 154, 7, 154, 2, 155, 7, 155, 2, 156, 7, 156, 2, 157, 7, 157, 2, 158, 7, 158, 2, 159, 7, 159, 2, 160, 7, 160, 2, 161, 7, 161, 2, 162, 7, 162, 2, 163, 7, 163, 2, 164, 7, 164, 2, 165, 7, 165, 2, 166, 7, 166, 2, 167, 7, 167, 2, 168, 7, 168, 2, 169, 7, 169, 2, 170, 7, 170, 2, 171, 7, 171, 2, 172, 7, 172, 2, 173, 7, 173, 2, 174, 7, 174, 2, 175, 7, 175, 2, 176, 7, 176, 2, 177, 7, 177, 2, 178, 7, 178, 2, 179, 7, 179, 2, 180, 7, 180, 2, 181, 7, 181, 2, 182, 7, 182, 2, 183, 7, 183, 2, 184, 7, 184, 2, 185, 7, 185, 2, 186, 7, 186, 2, 187, 7, 187, 2, 188, 7, 188, 2, 189, 7, 189, 2, 190, 7, 190, 1, 0, 1, 0, 1, 0, 1, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 2, 1, 2, 1, 2, 1, 2, 1, 2, 1, 3, 1, 3, 1, 3, 1, 3, 1, 4, 1, 4, 1, 4, 1, 4, 1, 4, 1, 4, 1, 5, 1, 5, 1, 5, 1, 6, 1, 6, 1, 6, 1, 6, 1, 6, 1, 6, 1, 6, 1, 6, 1, 6, 1, 6, 1, 6, 1, 6, 1, 6, 1, 6, 3, 6, 426, 8, 6, 1, 7, 1, 7, 1, 7, 1, 7, 1, 7, 1, 8, 1, 8, 1, 8, 1, 8, 1, 8, 1, 8, 1, 8, 1, 8, 1, 9, 1, 9, 1, 9, 1, 9, 1, 9, 1, 10, 1, 10, 1, 10, 1, 11, 1, 11, 1, 11, 1, 11, 1, 11, 1, 12, 1, 12, 1, 12, 1, 12, 1, 12, 1, 13, 1, 13, 1, 13, 1, 13, 1, 13, 1, 13, 1, 14, 1, 14, 1, 14, 1, 14, 1, 14, 1, 14, 1, 14, 1, 15, 1, 15, 1, 15, 1, 15, 1, 15, 1, 15, 1, 15, 1, 15, 1, 16, 1, 16, 1, 16, 1, 16, 1, 16, 1, 16, 1, 17, 1, 17, 1, 17, 1, 17, 1, 17, 1, 18, 1, 18, 1, 18, 1, 18, 1, 18, 1, 18, 1, 18, 1, 18, 1, 19, 1, 19, 1, 19, 1, 19, 1, 19, 1, 20, 1, 20, 1, 20, 1, 20, 1, 21, 1, 21, 1, 21, 1, 21, 1, 21, 1, 22, 1, 22, 1, 22, 1, 22, 1, 22, 1, 22, 1, 22, 1, 22, 1, 22, 1, 22, 1, 22, 1, 23, 1, 23, 1, 23, 1, 23, 1, 23, 1, 23, 1, 23, 1, 23, 1, 23, 1, 24, 1, 24, 1, 24, 1, 24, 1, 24, 1, 25, 1, 25, 1, 25, 1, 25, 1, 26, 1, 26, 1, 26, 1, 26, 1, 26, 1, 26, 1, 26, 1, 26, 1, 27, 1, 27, 1, 27, 1, 27, 1, 27, 1, 27, 1, 28, 1, 28, 1, 28, 1, 28, 1, 28, 1, 28, 1, 28, 1, 28, 1, 29, 1, 29, 1, 29, 1, 29, 1, 29, 1, 29, 1, 30, 1, 30, 1, 30, 1, 31, 1, 31, 1, 31, 1, 31, 1, 31, 1, 31, 1, 31, 1, 31, 1, 31, 1, 31, 1, 32, 1, 32, 1, 32, 1, 32, 1, 33, 1, 33, 1, 33, 1, 33, 1, 33, 1, 34, 1, 34, 1, 34, 1, 34, 1, 34, 1, 35, 1, 35, 1, 35, 1, 35, 1, 36, 1, 36, 1, 36, 1, 36, 1, 36, 1, 36, 1, 37, 1, 37, 1, 37, 1, 37, 1, 37, 1, 37, 1, 37, 1, 38, 1, 38, 1, 38, 1, 38, 1, 38, 1, 39, 1, 39, 1, 39, 1, 40, 1, 40, 1, 40, 1, 41, 1, 41, 1, 41, 1, 41, 1, 41, 1, 41, 1, 42, 1, 42, 1, 42, 1, 43, 1, 43, 1, 43, 1, 43, 1, 43, 1, 43, 1, 43, 1, 43, 1, 43, 1, 43, 1, 43, 1, 43, 1, 43, 3, 43, 647, 8, 43, 1, 44, 1, 44, 1, 44, 1, 44, 1, 44, 1, 44, 1, 45, 1, 45, 1, 45, 1, 45, 1, 45, 1, 45, 1, 45, 1, 45, 1, 45, 1, 46, 1, 46, 1, 46, 1, 47, 1, 47, 1, 47, 1, 47, 1, 47, 1, 48, 1, 48, 1, 48, 1, 48, 1, 49, 1, 49, 1, 49, 1, 49, 1, 49, 1, 50, 1, 50, 1, 50, 1, 50, 1, 50, 1, 50, 1, 50, 1, 50, 1, 51, 1, 51, 1, 51, 1, 51, 1, 51, 1, 52, 1, 52, 1, 52, 1, 52, 1, 53, 1, 53, 1, 53, 1, 53, 1, 53, 1, 54, 1, 54, 1, 54, 1, 54, 1, 54, 1, 54, 1, 55, 1, 55, 1, 55, 1, 55, 1, 55, 1, 55, 1, 55, 1, 56, 1, 56, 1, 56, 1, 56, 1, 56, 1, 56, 1, 57, 1, 57, 1, 57, 1, 57, 1, 58, 1, 58, 1, 58, 1, 58, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 60, 1, 60, 1, 60, 1, 60, 1, 60, 1, 60, 1, 61, 1, 61, 1, 61, 1, 61, 1, 61, 1, 61, 1, 61, 1, 62, 1, 62, 1, 62, 1, 63, 1, 63, 1, 63, 1, 64, 1, 64, 1, 64, 1, 64, 1, 64, 1, 64, 1, 65, 1, 65, 1, 65, 1, 65, 1, 65, 1, 65, 1, 66, 1, 66, 1, 66, 1, 66, 1, 66, 1, 67, 1, 67, 1, 67, 1, 67, 1, 67, 1, 67, 1, 67, 1, 67, 1, 67, 1, 67, 1, 68, 1, 68, 1, 68, 1, 68, 1, 68, 1, 68, 1, 68, 1, 68, 1, 68, 1, 68, 1, 69, 1, 69, 1, 69, 1, 69, 1, 69, 1, 69, 1, 69, 1, 69, 1, 69, 1, 70, 1, 70, 1, 70, 1, 70, 1, 70, 1, 70, 1, 70, 1, 70, 1, 71, 1, 71, 1, 71, 1, 71, 1, 71, 1, 71, 1, 72, 1, 72, 1, 72, 1, 72, 1, 72, 1, 72, 1, 72, 1, 73, 1, 73, 1, 73, 1, 73, 1, 73, 1, 73, 1, 74, 1, 74, 1, 74, 1, 74, 1, 74, 1, 74, 1, 74, 1, 75, 1, 75, 1, 75, 1, 75, 1, 76, 1, 76, 1, 76, 1, 76, 1, 76, 1, 77, 1, 77, 1, 77, 1, 77, 1, 77, 1, 77, 1, 77, 1, 78, 1, 78, 1, 78, 1, 78, 1, 78, 1, 78, 1, 78, 1, 79, 1, 79, 1, 79, 1, 79, 1, 79, 1, 79, 1, 79, 1, 80, 1, 80, 1, 80, 1, 80, 1, 80, 1, 81, 1, 81, 1, 81, 1, 81, 1, 81, 1, 81, 1, 81, 1, 81, 1, 81, 1, 82, 1, 82, 1, 82, 1, 82, 1, 82, 1, 82, 1, 82, 1, 82, 1, 82, 1, 82, 1, 83, 1, 83, 1, 83, 1, 83, 1, 83, 1, 84, 1, 84, 1, 84, 1, 84, 1, 84, 1, 84, 1, 85, 1, 85, 1, 85, 1, 85, 1, 85, 1, 86, 1, 86, 1, 86, 1, 86, 1, 86, 1, 86, 1, 86, 1, 86, 1, 86, 1, 86, 1, 87, 1, 87, 1, 87, 1, 88, 1, 88, 1, 88, 1, 88, 1, 89, 1, 89, 1, 89, 1, 89, 1, 89, 1, 89, 1, 89, 1, 90, 1, 90, 1, 90, 1, 90, 1, 90, 1, 90, 1, 90, 1, 90, 1, 90, 1, 91, 1, 91, 1, 91, 1, 91, 1, 91, 1, 92, 1, 92, 1, 92, 1, 92, 1, 92, 1, 92, 1, 92, 1, 92, 1, 92, 1, 93, 1, 93, 1, 93, 1, 93, 1, 94, 1, 94, 1, 94, 1, 94, 1, 94, 1, 94, 1, 94, 1, 94, 1, 94, 1, 94, 1, 95, 1, 95, 1, 95, 1, 95, 1, 95, 1, 95, 1, 96, 1, 96, 1, 96, 1, 96, 1, 96, 1, 96, 1, 97, 1, 97, 1, 97, 1, 97, 1, 97, 1, 98, 1, 98, 1, 98, 1, 98, 1, 98, 1, 99, 1, 99, 1, 99, 1, 99, 1, 99, 1, 99, 1, 100, 1, 100, 1, 100, 1, 100, 1, 100, 1, 100, 1, 101, 1, 101, 1, 101, 1, 101, 1, 101, 1, 101, 1, 101, 1, 102, 1, 102, 1, 102, 1, 102, 1, 102, 1, 103, 1, 103, 1, 103, 1, 103, 1, 103, 1, 103, 1, 103, 1, 103, 1, 103, 1, 103, 3, 103, 1021, 8, 103, 1, 104, 1, 104, 1, 104, 1, 104, 1, 104, 1, 104, 1, 104, 1, 104, 1, 104, 1, 104, 1, 104, 1, 104, 1, 104, 1, 104, 1, 104, 1, 104, 1, 104, 1, 104, 1, 104, 1, 104, 1, 104, 1, 104, 1, 104, 1, 104, 1, 104, 1, 104, 1, 104, 3, 104, 1050, 8, 104, 1, 105, 1, 105, 1, 105, 3, 105, 1055, 8, 105, 1, 105, 1, 105, 1, 105, 1, 105, 5, 105, 1061, 8, 105, 10, 105, 12, 105, 1064, 9, 105, 1, 105, 1, 105, 1, 105, 1, 105, 1, 105, 1, 105, 1, 105, 1, 105, 1, 105, 5, 105, 1075, 8, 105, 10, 105, 12, 105, 1078, 9, 105, 1, 105, 1, 105, 1, 105, 1, 105, 1, 105, 1, 105, 1, 105, 1, 105, 1, 105, 1, 105, 1, 105, 5, 105, 1091, 8, 105, 10, 105, 12, 105, 1094, 9, 105, 1, 105, 1, 105, 3, 105, 1098, 8, 105, 1, 106, 1, 106, 1, 106, 5, 106, 1103, 8, 106, 10, 106, 12, 106, 1106, 9, 106, 1, 106, 1, 106, 3, 106, 1110, 8, 106, 1, 106, 1, 106, 3, 106, 1114, 8, 106, 1, 106, 4, 106, 1117, 8, 106, 11, 106, 12, 106, 1118, 1, 106, 1, 106, 1, 106, 3, 106, 1124, 8, 106, 1, 106, 1, 106, 3, 106, 1128, 8, 106, 1, 106, 4, 106, 1131, 8, 106, 11, 106, 12, 106, 1132, 1, 106, 1, 106, 1, 106, 5, 106, 1138, 8, 106, 10, 106, 12, 106, 1141, 9, 106, 1, 106, 1, 106, 1, 106, 3, 106, 1146, 8, 106, 1, 106, 4, 106, 1149, 8, 106, 11, 106, 12, 106, 1150, 1, 106, 1, 106, 1, 106, 1, 106, 1, 106, 3, 106, 1158, 8, 106, 1, 106, 4, 106, 1161, 8, 106, 11, 106, 12, 106, 1162, 1, 106, 1, 106, 1, 106, 1, 106, 3, 106, 1169, 8, 106, 1, 106, 4, 106, 1172, 8, 106, 11, 106, 12, 106, 1173, 3, 106, 1176, 8, 106, 1, 107, 1, 107, 4, 107, 1180, 8, 107, 11, 107, 12, 107, 1181, 1, 108, 4, 108, 1185, 8, 108, 11, 108, 12, 108, 1186, 1, 109, 1, 109, 1, 109, 4, 109, 1192, 8, 109, 11, 109, 12, 109, 1193, 1, 110, 1, 110, 1, 110, 1, 110, 1, 110, 1, 110, 1, 110, 1, 110, 1, 110, 5, 110, 1205, 8, 110, 10, 110, 12, 110, 1208, 9, 110, 1, 110, 1, 110, 1, 111, 1, 111, 1, 112, 1, 112, 1, 113, 1, 113, 1, 114, 1, 114, 1, 115, 1, 115, 1, 116, 1, 116, 1, 117, 1, 117, 1, 118, 1, 118, 1, 119, 1, 119, 1, 120, 1, 120, 1, 121, 1, 121, 1, 122, 1, 122, 1, 123, 1, 123, 1, 124, 1, 124, 1, 125, 1, 125, 1, 126, 1, 126, 1, 127, 1, 127, 1, 128, 1, 128, 1, 129, 1, 129, 1, 130, 1, 130, 1, 131, 1, 131, 1, 132, 1, 132, 1, 133, 1, 133, 1, 134, 1, 134, 1, 135, 1, 135, 1, 136, 1, 136, 1, 137, 1, 137, 1, 138, 1, 138, 1, 139, 1, 139, 1, 140, 1, 140, 1, 141, 1, 141, 1, 141, 1, 142, 1, 142, 1, 143, 1, 143, 1, 144, 1, 144, 1, 145, 1, 145, 1, 146, 1, 146, 1, 147, 1, 147, 1, 147, 1, 148, 1, 148, 1, 149, 1, 149, 1, 150, 1, 150, 1, 151, 1, 151, 1, 151, 1, 152, 1, 152, 1, 153, 1, 153, 1, 153, 1, 154, 1, 154, 1, 155, 1, 155, 1, 156, 1, 156, 1, 156, 1, 157, 1, 157, 1, 157, 1, 157, 1, 158, 1, 158, 1, 158, 1, 158, 1, 159, 1, 159, 1, 160, 1, 160, 1, 161, 1, 161, 1, 161, 1, 162, 1, 162, 1, 163, 1, 163, 1, 163, 1, 163, 3, 163, 1330, 8, 163, 1, 164, 1, 164, 1, 164, 1, 164, 1, 165, 1, 165, 1, 165, 1, 166, 1, 166, 1, 166, 1, 167, 1, 167, 1, 167, 1, 168, 1, 168, 1, 169, 1, 169, 1, 170, 1, 170, 1, 171, 1, 171, 1, 172, 1, 172, 1, 172, 1, 172, 1, 172, 1, 173, 1, 173, 1, 173, 1, 173, 1, 173, 1, 174, 1, 174, 1, 175, 1, 175, 1, 176, 1, 176, 1, 176, 1, 177, 1, 177, 1, 177, 1, 177, 1, 178, 1, 178, 1, 179, 1, 179, 1, 180, 1, 180, 1, 181, 1, 181, 1, 182, 1, 182, 1, 183, 1, 183, 1, 183, 1, 183, 5, 183, 1388, 8, 183, 10, 183, 12, 183, 1391, 9, 183, 1, 183, 1, 183, 1, 183, 1, 183, 1, 183, 1, 184, 1, 184, 1, 184, 1, 184, 3, 184, 1402, 8, 184, 1, 184, 5, 184, 1405, 8, 184, 10, 184, 12, 184, 1408, 9, 184, 1, 184, 3, 184, 1411, 8, 184, 1, 184, 1, 184, 1, 185, 1, 185, 1, 185, 1, 185, 1, 186, 1, 186, 1, 186, 1, 186, 1, 186, 1, 186, 1, 186, 1, 186, 1, 186, 1, 186, 1, 186, 4, 186, 1430, 8, 186, 11, 186, 12, 186, 1431, 1, 187, 1, 187, 1, 187, 1, 187, 1, 188, 1, 188, 1, 188, 1, 188, 1, 188, 1, 189, 1, 189, 1, 189, 1, 189, 1, 189, 4, 189, 1448, 8, 189, 11, 189, 12, 189, 1449, 1, 190, 1, 190, 1, 190, 1, 190, 1, 1389, 0, 191, 3, 1, 5, 2, 7, 3, 9, 4, 11, 5, 13, 6, 15, 7, 17, 8, 19, 9, 21, 10, 23, 11, 25, 12, 27, 13, 29, 14, 31, 15, 33, 16, 35, 17, 37, 18, 39, 19, 41, 20, 43, 21, 45, 22, 47, 23, 49, 24, 51, 25, 53, 26, 55, 27, 57, 28, 59, 29, 61, 30, 63, 31, 65, 32, 67, 33, 69, 34, 71, 35, 73, 36, 75, 37, 77, 38, 79, 39, 81, 40, 83, 41, 85, 42, 87, 43, 89, 44, 91, 45, 93, 46, 95, 47, 97, 48, 99, 49, 101, 50, 103, 51, 105, 52, 107, 53, 109, 54, 111, 55, 113, 56, 115, 57, 117, 58, 119, 59, 121, 60, 123, 61, 125, 62, 127, 63, 129, 64, 131, 65, 133, 66, 135, 67, 137, 68, 139, 69, 141, 70, 143, 71, 145, 72, 147, 73, 149, 74, 151, 75, 153, 76, 155, 77, 157, 78, 159, 79, 161, 80, 163, 81, 165, 82, 167, 83, 169, 84, 171, 85, 173, 86, 175, 87, 177, 88, 179, 89, 181, 90, 183, 91, 185, 92, 187, 93, 189, 94, 191, 95, 193, 96, 195, 97, 197, 98, 199, 99, 201, 100, 203, 101, 205, 102, 207, 103, 209, 104, 211, 105, 213, 106, 215, 107, 217, 108, 219, 109, 221, 110, 223, 111, 225, 0, 227, 0, 229, 0, 231, 0, 233, 0, 235, 0, 237, 0, 239, 0, 241, 0, 243, 0, 245, 0, 247, 0, 249, 0, 251, 0, 253, 0, 255, 0, 257, 0, 259, 0, 261, 0, 263, 0, 265, 0, 267, 0, 269, 0, 271, 0, 273, 0, 275, 0, 277, 0, 279, 0, 281, 0, 283, 0, 285, 112, 287, 113, 289, 114, 291, 115, 293, 116, 295, 117, 297, 118, 299, 119, 301, 120, 303, 121, 305, 122, 307, 123, 309, 124, 311, 125, 313, 126, 315, 127, 317, 128, 319, 129, 321, 130, 323, 131, 325, 132, 327, 133, 329, 134, 331, 135, 333, 136, 335, 137, 337, 138, 339, 139, 341, 140, 343, 141, 345, 142, 347, 143, 349, 144, 351, 145, 353, 146, 355, 147, 357, 148, 359, 149, 361, 150, 363, 151, 365, 152, 367, 153, 369, 154, 371, 155, 373, 156, 375, 157, 377, 158, 379, 0, 381, 159, 383, 160, 3, 0, 1, 2, 38, 2, 0, 92, 92, 96, 96, 2, 0, 34, 34, 92, 92, 2, 0, 39, 39, 92, 92, 2, 0, 65, 65, 97, 97, 2, 0, 66, 66, 98, 98, 2, 0, 67, 67, 99, 99, 2, 0, 68, 68, 100, 100, 2, 0, 69, 69, 101, 101, 2, 0, 70, 70, 102, 102, 2, 0, 71, 71, 103, 103, 2, 0, 72, 72, 104, 104, 2, 0, 73, 73, 105, 105, 2, 0, 74, 74, 106, 106, 2, 0, 75, 75, 107, 107, 2, 0, 76, 76, 108, 108, 2, 0, 77, 77, 109, 109, 2, 0, 78, 78, 110, 110, 2, 0, 79, 79, 111, 111, 2, 0, 80, 80, 112, 112, 2, 0, 81, 81, 113, 113, 2, 0, 82, 82, 114, 114, 2, 0, 83, 83, 115, 115, 2, 0, 84, 84, 116, 116, 2, 0, 85, 85, 117, 117, 2, 0, 86, 86, 118, 118, 2, 0, 87, 87, 119, 119, 2, 0, 88, 88, 120, 120, 2, 0, 89, 89, 121, 121, 2, 0, 90, 90, 122, 122, 2, 0, 65, 90, 97, 122, 1, 0, 48, 55, 1, 0, 48, 57, 3, 0, 48, 57, 65, 70, 97, 102, 2, 0, 10, 10, 13, 13, 2, 1, 10, 10, 13, 13, 2, 0, 9, 13, 32, 32, 3, 0, 39, 39, 92, 92, 123, 123, 1, 0, 123, 123, 1491, 0, 3, 1, 0, 0, 0, 0, 5, 1, 0, 0, 0, 0, 7, 1, 0, 0, 0, 0, 9, 1, 0, 0, 0, 0, 11, 1, 0, 0, 0, 0, 13, 1, 0, 0, 0, 0, 15, 1, 0, 0, 0, 0, 17, 1, 0, 0, 0, 0, 19, 1, 0, 0, 0, 0, 21, 1, 0, 0, 0, 0, 23, 1, 0, 0, 0, 0, 25, 1, 0, 0, 0, 0, 27, 1, 0, 0, 0, 0, 29, 1, 0, 0, 0, 0, 31, 1, 0, 0, 0, 0, 33, 1, 0, 0, 0, 0, 35, 1, 0, 0, 0, 0, 37, 1, 0, 0, 0, 0, 39, 1, 0, 0, 0, 0, 41, 1, 0, 0, 0, 0, 43, 1, 0, 0, 0, 0, 45, 1, 0, 0, 0, 0, 47, 1, 0, 0, 0, 0, 49, 1, 0, 0, 0, 0, 51, 1, 0, 0, 0, 0, 53, 1, 0, 0, 0, 0, 55, 1, 0, 0, 0, 0, 57, 1, 0, 0, 0, 0, 59, 1, 0, 0, 0, 0, 61, 1, 0, 0, 0, 0, 63, 1, 0, 0, 0, 0, 65, 1, 0, 0, 0, 0, 67, 1, 0, 0, 0, 0, 69, 1, 0, 0, 0, 0, 71, 1, 0, 0, 0, 0, 73, 1, 0, 0, 0, 0, 75, 1, 0, 0, 0, 0, 77, 1, 0, 0, 0, 0, 79, 1, 0, 0, 0, 0, 81, 1, 0, 0, 0, 0, 83, 1, 0, 0, 0, 0, 85, 1, 0, 0, 0, 0, 87, 1, 0, 0, 0, 0, 89, 1, 0, 0, 0, 0, 91, 1, 0, 0, 0, 0, 93, 1, 0, 0, 0, 0, 95, 1, 0, 0, 0, 0, 97, 1, 0, 0, 0, 0, 99, 1, 0, 0, 0, 0, 101, 1, 0, 0, 0, 0, 103, 1, 0, 0, 0, 0, 105, 1, 0, 0, 0, 0, 107, 1, 0, 0, 0, 0, 109, 1, 0, 0, 0, 0, 111, 1, 0, 0, 0, 0, 113, 1, 0, 0, 0, 0, 115, 1, 0, 0, 0, 0, 117, 1, 0, 0, 0, 0, 119, 1, 0, 0, 0, 0, 121, 1, 0, 0, 0, 0, 123, 1, 0, 0, 0, 0, 125, 1, 0, 0, 0, 0, 127, 1, 0, 0, 0, 0, 129, 1, 0, 0, 0, 0, 131, 1, 0, 0, 0, 0, 133, 1, 0, 0, 0, 0, 135, 1, 0, 0, 0, 0, 137, 1, 0, 0, 0, 0, 139, 1, 0, 0, 0, 0, 141, 1, 0, 0, 0, 0, 143, 1, 0, 0, 0, 0, 145, 1, 0, 0, 0, 0, 147, 1, 0, 0, 0, 0, 149, 1, 0, 0, 0, 0, 151, 1, 0, 0, 0, 0, 153, 1, 0, 0, 0, 0, 155, 1, 0, 0, 0, 0, 157, 1, 0, 0, 0, 0, 159, 1, 0, 0, 0, 0, 161, 1, 0, 0, 0, 0, 163, 1, 0, 0, 0, 0, 165, 1, 0, 0, 0, 0, 167, 1, 0, 0, 0, 0, 169, 1, 0, 0, 0, 0, 171, 1, 0, 0, 0, 0, 173, 1, 0, 0, 0, 0, 175, 1, 0, 0, 0, 0, 177, 1, 0, 0, 0, 0, 179, 1, 0, 0, 0, 0, 181, 1, 0, 0, 0, 0, 183, 1, 0, 0, 0, 0, 185, 1, 0, 0, 0, 0, 187, 1, 0, 0, 0, 0, 189, 1, 0, 0, 0, 0, 191, 1, 0, 0, 0, 0, 193, 1, 0, 0, 0, 0, 195, 1, 0, 0, 0, 0, 197, 1, 0, 0, 0, 0, 199, 1, 0, 0, 0, 0, 201, 1, 0, 0, 0, 0, 203, 1, 0, 0, 0, 0, 205, 1, 0, 0, 0, 0, 207, 1, 0, 0, 0, 0, 209, 1, 0, 0, 0, 0, 211, 1, 0, 0, 0, 0, 213, 1, 0, 0, 0, 0, 215, 1, 0, 0, 0, 0, 217, 1, 0, 0, 0, 0, 219, 1, 0, 0, 0, 0, 221, 1, 0, 0, 0, 0, 223, 1, 0, 0, 0, 0, 285, 1, 0, 0, 0, 0, 287, 1, 0, 0, 0, 0, 289, 1, 0, 0, 0, 0, 291, 1, 0, 0, 0, 0, 293, 1, 0, 0, 0, 0, 295, 1, 0, 0, 0, 0, 297, 1, 0, 0, 0, 0, 299, 1, 0, 0, 0, 0, 301, 1, 0, 0, 0, 0, 303, 1, 0, 0, 0, 0, 305, 1, 0, 0, 0, 0, 307, 1, 0, 0, 0, 0, 309, 1, 0, 0, 0, 0, 311, 1, 0, 0, 0, 0, 313, 1, 0, 0, 0, 0, 315, 1, 0, 0, 0, 0, 317, 1, 0, 0, 0, 0, 319, 1, 0, 0, 0, 0, 321, 1, 0, 0, 0, 0, 323, 1, 0, 0, 0, 0, 325, 1, 0, 0, 0, 0, 327, 1, 0, 0, 0, 0, 329, 1, 0, 0, 0, 0, 331, 1, 0, 0, 0, 0, 333, 1, 0, 0, 0, 0, 335, 1, 0, 0, 0, 0, 337, 1, 0, 0, 0, 0, 339, 1, 0, 0, 0, 0, 341, 1, 0, 0, 0, 0, 343, 1, 0, 0, 0, 0, 345, 1, 0, 0, 0, 0, 347, 1, 0, 0, 0, 0, 349, 1, 0, 0, 0, 0, 351, 1, 0, 0, 0, 0, 353, 1, 0, 0, 0, 0, 355, 1, 0, 0, 0, 0, 357, 1, 0, 0, 0, 0, 359, 1, 0, 0, 0, 0, 361, 1, 0, 0, 0, 0, 363, 1, 0, 0, 0, 0, 365, 1, 0, 0, 0, 0, 367, 1, 0, 0, 0, 0, 369, 1, 0, 0, 0, 0, 371, 1, 0, 0, 0, 0, 373, 1, 0, 0, 0, 1, 375, 1, 0, 0, 0, 1, 377, 1, 0, 0, 0, 1, 379, 1, 0, 0, 0, 2, 381, 1, 0, 0, 0, 2, 383, 1, 0, 0, 0, 3, 385, 1, 0, 0, 0, 5, 389, 1, 0, 0, 0, 7, 393, 1, 0, 0, 0, 9, 398, 1, 0, 0, 0, 11, 402, 1, 0, 0, 0, 13, 408, 1, 0, 0, 0, 15, 425, 1, 0, 0, 0, 17, 427, 1, 0, 0, 0, 19, 432, 1, 0, 0, 0, 21, 440, 1, 0, 0, 0, 23, 445, 1, 0, 0, 0, 25, 448, 1, 0, 0, 0, 27, 453, 1, 0, 0, 0, 29, 458, 1, 0, 0, 0, 31, 464, 1, 0, 0, 0, 33, 471, 1, 0, 0, 0, 35, 479, 1, 0, 0, 0, 37, 485, 1, 0, 0, 0, 39, 490, 1, 0, 0, 0, 41, 498, 1, 0, 0, 0, 43, 503, 1, 0, 0, 0, 45, 507, 1, 0, 0, 0, 47, 512, 1, 0, 0, 0, 49, 523, 1, 0, 0, 0, 51, 532, 1, 0, 0, 0, 53, 537, 1, 0, 0, 0, 55, 541, 1, 0, 0, 0, 57, 549, 1, 0, 0, 0, 59, 555, 1, 0, 0, 0, 61, 563, 1, 0, 0, 0, 63, 569, 1, 0, 0, 0, 65, 572, 1, 0, 0, 0, 67, 582, 1, 0, 0, 0, 69, 586, 1, 0, 0, 0, 71, 591, 1, 0, 0, 0, 73, 596, 1, 0, 0, 0, 75, 600, 1, 0, 0, 0, 77, 606, 1, 0, 0, 0, 79, 613, 1, 0, 0, 0, 81, 618, 1, 0, 0, 0, 83, 621, 1, 0, 0, 0, 85, 624, 1, 0, 0, 0, 87, 630, 1, 0, 0, 0, 89, 646, 1, 0, 0, 0, 91, 648, 1, 0, 0, 0, 93, 654, 1, 0, 0, 0, 95, 663, 1, 0, 0, 0, 97, 666, 1, 0, 0, 0, 99, 671, 1, 0, 0, 0, 101, 675, 1, 0, 0, 0, 103, 680, 1, 0, 0, 0, 105, 688, 1, 0, 0, 0, 107, 693, 1, 0, 0, 0, 109, 697, 1, 0, 0, 0, 111, 702, 1, 0, 0, 0, 113, 708, 1, 0, 0, 0, 115, 715, 1, 0, 0, 0, 117, 721, 1, 0, 0, 0, 119, 725, 1, 0, 0, 0, 121, 729, 1, 0, 0, 0, 123, 734, 1, 0, 0, 0, 125, 740, 1, 0, 0, 0, 127, 747, 1, 0, 0, 0, 129, 750, 1, 0, 0, 0, 131, 753, 1, 0, 0, 0, 133, 759, 1, 0, 0, 0, 135, 765, 1, 0, 0, 0, 137, 770, 1, 0, 0, 0, 139, 780, 1, 0, 0, 0, 141, 790, 1, 0, 0, 0, 143, 799, 1, 0, 0, 0, 145, 807, 1, 0, 0, 0, 147, 813, 1, 0, 0, 0, 149, 820, 1, 0, 0, 0, 151, 826, 1, 0, 0, 0, 153, 833, 1, 0, 0, 0, 155, 837, 1, 0, 0, 0, 157, 842, 1, 0, 0, 0, 159, 849, 1, 0, 0, 0, 161, 856, 1, 0, 0, 0, 163, 863, 1, 0, 0, 0, 165, 868, 1, 0, 0, 0, 167, 877, 1, 0, 0, 0, 169, 887, 1, 0, 0, 0, 171, 892, 1, 0, 0, 0, 173, 898, 1, 0, 0, 0, 175, 903, 1, 0, 0, 0, 177, 913, 1, 0, 0, 0, 179, 916, 1, 0, 0, 0, 181, 920, 1, 0, 0, 0, 183, 927, 1, 0, 0, 0, 185, 936, 1, 0, 0, 0, 187, 941, 1, 0, 0, 0, 189, 950, 1, 0, 0, 0, 191, 954, 1, 0, 0, 0, 193, 964, 1, 0, 0, 0, 195, 970, 1, 0, 0, 0, 197, 976, 1, 0, 0, 0, 199, 981, 1, 0, 0, 0, 201, 986, 1, 0, 0, 0, 203, 992, 1, 0, 0, 0, 205, 998, 1, 0, 0, 0, 207, 1005, 1, 0, 0, 0, 209, 1020, 1, 0, 0, 0, 211, 1049, 1, 0, 0, 0, 213, 1097, 1, 0, 0, 0, 215, 1175, 1, 0, 0, 0, 217, 1177, 1, 0, 0, 0, 219, 1184, 1, 0, 0, 0, 221, 1188, 1, 0, 0, 0, 223, 1195, 1, 0, 0, 0, 225, 1211, 1, 0, 0, 0, 227, 1213, 1, 0, 0, 0, 229, 1215, 1, 0, 0, 0, 231, 1217, 1, 0, 0, 0, 233, 1219, 1, 0, 0, 0, 235, 1221, 1, 0, 0, 0, 237, 1223, 1, 0, 0, 0, 239, 1225, 1, 0, 0, 0, 241, 1227, 1, 0, 0, 0, 243, 1229, 1, 0, 0, 0, 245, 1231, 1, 0, 0, 0, 247, 1233, 1, 0, 0, 0, 249, 1235, 1, 0, 0, 0, 251, 1237, 1, 0, 0, 0, 253, 1239, 1, 0, 0, 0, 255, 1241, 1, 0, 0, 0, 257, 1243, 1, 0, 0, 0, 259, 1245, 1, 0, 0, 0, 261, 1247, 1, 0, 0, 0, 263, 1249, 1, 0, 0, 0, 265, 1251, 1, 0, 0, 0, 267, 1253, 1, 0, 0, 0, 269, 1255, 1, 0, 0, 0, 271, 1257, 1, 0, 0, 0, 273, 1259, 1, 0, 0, 0, 275, 1261, 1, 0, 0, 0, 277, 1263, 1, 0, 0, 0, 279, 1265, 1, 0, 0, 0, 281, 1267, 1, 0, 0, 0, 283, 1269, 1, 0, 0, 0, 285, 1271, 1, 0, 0, 0, 287, 1274, 1, 0, 0, 0, 289, 1276, 1, 0, 0, 0, 291, 1278, 1, 0, 0, 0, 293, 1280, 1, 0, 0, 0, 295, 1282, 1, 0, 0, 0, 297, 1284, 1, 0, 0, 0, 299, 1287, 1, 0, 0, 0, 301, 1289, 1, 0, 0, 0, 303, 1291, 1, 0, 0, 0, 305, 1293, 1, 0, 0, 0, 307, 1296, 1, 0, 0, 0, 309, 1298, 1, 0, 0, 0, 311, 1301, 1, 0, 0, 0, 313, 1303, 1, 0, 0, 0, 315, 1305, 1, 0, 0, 0, 317, 1308, 1, 0, 0, 0, 319, 1312, 1, 0, 0, 0, 321, 1316, 1, 0, 0, 0, 323, 1318, 1, 0, 0, 0, 325, 1320, 1, 0, 0, 0, 327, 1323, 1, 0, 0, 0, 329, 1329, 1, 0, 0, 0, 331, 1331, 1, 0, 0, 0, 333, 1335, 1, 0, 0, 0, 335, 1338, 1, 0, 0, 0, 337, 1341, 1, 0, 0, 0, 339, 1344, 1, 0, 0, 0, 341, 1346, 1, 0, 0, 0, 343, 1348, 1, 0, 0, 0, 345, 1350, 1, 0, 0, 0, 347, 1352, 1, 0, 0, 0, 349, 1357, 1, 0, 0, 0, 351, 1362, 1, 0, 0, 0, 353, 1364, 1, 0, 0, 0, 355, 1366, 1, 0, 0, 0, 357, 1369, 1, 0, 0, 0, 359, 1373, 1, 0, 0, 0, 361, 1375, 1, 0, 0, 0, 363, 1377, 1, 0, 0, 0, 365, 1379, 1, 0, 0, 0, 367, 1381, 1, 0, 0, 0, 369, 1383, 1, 0, 0, 0, 371, 1401, 1, 0, 0, 0, 373, 1414, 1, 0, 0, 0, 375, 1429, 1, 0, 0, 0, 377, 1433, 1, 0, 0, 0, 379, 1437, 1, 0, 0, 0, 381, 1447, 1, 0, 0, 0, 383, 1451, 1, 0, 0, 0, 385, 386, 3, 225, 111, 0, 386, 387, 3, 247, 122, 0, 387, 388, 3, 247, 122, 0, 388, 4, 1, 0, 0, 0, 389, 390, 3, 225, 111, 0, 390, 391, 3, 251, 124, 0, 391, 392, 3, 231, 114, 0, 392, 6, 1, 0, 0, 0, 393, 394, 3, 225, 111, 0, 394, 395, 3, 251, 124, 0, 395, 396, 3, 263, 130, 0, 396, 397, 3, 241, 119, 0, 397, 8, 1, 0, 0, 0, 398, 399, 3, 225, 111, 0, 399, 400, 3, 251, 124, 0, 400, 401, 3, 273, 135, 0, 401, 10, 1, 0, 0, 0, 402, 403, 3, 225, 111, 0, 403, 404, 3, 259, 128, 0, 404, 405, 3, 259, 128, 0, 405, 406, 3, 225, 111, 0, 406, 407, 3, 273, 135, 0, 407, 12, 1, 0, 0, 0, 408, 409, 3, 225, 111, 0, 409, 410, 3, 261, 129, 0, 410, 14, 1, 0, 0, 0, 411, 412, 3, 225, 111, 0, 412, 413, 3, 261, 129, 0, 413, 414, 3, 229, 113, 0, 414, 426, 1, 0, 0, 0, 415, 416, 3, 225, 111, 0, 416, 417, 3, 261, 129, 0, 417, 418, 3, 229, 113, 0, 418, 419, 3, 233, 115, 0, 419, 420, 3, 251, 124, 0, 420, 421, 3, 231, 114, 0, 421, 422, 3, 241, 119, 0, 422, 423, 3, 251, 124, 0, 423, 424, 3, 237, 117, 0, 424, 426, 1, 0, 0, 0, 425, 411, 1, 0, 0, 0, 425, 415, 1, 0, 0, 0, 426, 16, 1, 0, 0, 0, 427, 428, 3, 225, 111, 0, 428, 429, 3, 261, 129, 0, 429, 430, 3, 253, 125, 0, 430, 431, 3, 235, 116, 0, 431, 18, 1, 0, 0, 0, 432, 433, 3, 227, 112, 0, 433, 434, 3, 233, 115, 0, 434, 435, 3, 263, 130, 0, 435, 436, 3, 269, 133, 0, 436, 437, 3, 233, 115, 0, 437, 438, 3, 233, 115, 0, 438, 439, 3, 251, 124, 0, 439, 20, 1, 0, 0, 0, 440, 441, 3, 227, 112, 0, 441, 442, 3, 253, 125, 0, 442, 443, 3, 263, 130, 0, 443, 444, 3, 239, 118, 0, 444, 22, 1, 0, 0, 0, 445, 446, 3, 227, 112, 0, 446, 447, 3, 273, 135, 0, 447, 24, 1, 0, 0, 0, 448, 449, 3, 229, 113, 0, 449, 450, 3, 225, 111, 0, 450, 451, 3, 261, 129, 0, 451, 452, 3, 233, 115, 0, 452, 26, 1, 0, 0, 0, 453, 454, 3, 229, 113, 0, 454, 455, 3, 225, 111, 0, 455, 456, 3, 261, 129, 0, 456, 457, 3, 263, 130, 0, 457, 28, 1, 0, 0, 0, 458, 459, 3, 229, 113, 0, 459, 460, 3, 225, 111, 0, 460, 461, 3, 263, 130, 0, 461, 462, 3, 229, 113, 0, 462, 463, 3, 239, 118, 0, 463, 30, 1, 0, 0, 0, 464, 465, 3, 229, 113, 0, 465, 466, 3, 253, 125, 0, 466, 467, 3, 239, 118, 0, 467, 468, 3, 253, 125, 0, 468, 469, 3, 259, 128, 0, 469, 470, 3, 263, 130, 0, 470, 32, 1, 0, 0, 0, 471, 472, 3, 229, 113, 0, 472, 473, 3, 253, 125, 0, 473, 474, 3, 247, 122, 0, 474, 475, 3, 247, 122, 0, 475, 476, 3, 225, 111, 0, 476, 477, 3, 263, 130, 0, 477, 478, 3, 233, 115, 0, 478, 34, 1, 0, 0, 0, 479, 480, 3, 229, 113, 0, 480, 481, 3, 259, 128, 0, 481, 482, 3, 253, 125, 0, 482, 483, 3, 261, 129, 0, 483, 484, 3, 261, 129, 0, 484, 36, 1, 0, 0, 0, 485, 486, 3, 229, 113, 0, 486, 487, 3, 265, 131, 0, 487, 488, 3, 227, 112, 0, 488, 489, 3, 233, 115, 0, 489, 38, 1, 0, 0, 0, 490, 491, 3, 229, 113, 0, 491, 492, 3, 265, 131, 0, 492, 493, 3, 259, 128, 0, 493, 494, 3, 259, 128, 0, 494, 495, 3, 233, 115, 0, 495, 496, 3, 251, 124, 0, 496, 497, 3, 263, 130, 0, 497, 40, 1, 0, 0, 0, 498, 499, 3, 231, 114, 0, 499, 500, 3, 225, 111, 0, 500, 501, 3, 263, 130, 0, 501, 502, 3, 233, 115, 0, 502, 42, 1, 0, 0, 0, 503, 504, 3, 231, 114, 0, 504, 505, 3, 225, 111, 0, 505, 506, 3, 273, 135, 0, 506, 44, 1, 0, 0, 0, 507, 508, 3, 231, 114, 0, 508, 509, 3, 233, 115, 0, 509, 510, 3, 261, 129, 0, 510, 511, 3, 229, 113, 0, 511, 46, 1, 0, 0, 0, 512, 513, 3, 231, 114, 0, 513, 514, 3, 233, 115, 0, 514, 515, 3, 261, 129, 0, 515, 516, 3, 229, 113, 0, 516, 517, 3, 233, 115, 0, 517, 518, 3, 251, 124, 0, 518, 519, 3, 231, 114, 0, 519, 520, 3, 241, 119, 0, 520, 521, 3, 251, 124, 0, 521, 522, 3, 237, 117, 0, 522, 48, 1, 0, 0, 0, 523, 524, 3, 231, 114, 0, 524, 525, 3, 241, 119, 0, 525, 526, 3, 261, 129, 0, 526, 527, 3, 263, 130, 0, 527, 528, 3, 241, 119, 0, 528, 529, 3, 251, 124, 0, 529, 530, 3, 229, 113, 0, 530, 531, 3, 263, 130, 0, 531, 50, 1, 0, 0, 0, 532, 533, 3, 233, 115, 0, 533, 534, 3, 247, 122, 0, 534, 535, 3, 261, 129, 0, 535, 536, 3, 233, 115, 0, 536, 52, 1, 0, 0, 0, 537, 538, 3, 233, 115, 0, 538, 539, 3, 251, 124, 0, 539, 540, 3, 231, 114, 0, 540, 54, 1, 0, 0, 0, 541, 542, 3, 233, 115, 0, 542, 543, 3, 271, 134, 0, 543, 544, 3, 263, 130, 0, 544, 545, 3, 259, 128, 0, 545, 546, 3, 225, 111, 0, 546, 547, 3, 229, 113, 0, 547, 548, 3, 263, 130, 0, 548, 56, 1, 0, 0, 0, 549, 550, 3, 235, 116, 0, 550, 551, 3, 241, 119, 0, 551, 552, 3, 251, 124, 0, 552, 553, 3, 225, 111, 0, 553, 554, 3, 247, 122, 0, 554, 58, 1, 0, 0, 0, 555, 556, 3, 235, 116, 0, 556, 557, 3, 241, 119, 0, 557, 558, 3, 251, 124, 0, 558, 559, 3, 225, 111, 0, 559, 560, 3, 247, 122, 0, 560, 561, 3, 247, 122, 0, 561, 562, 3, 273, 135, 0, 562, 60, 1, 0, 0, 0, 563, 564, 3, 235, 116, 0, 564, 565, 3, 241, 119, 0, 565, 566, 3, 259, 128, 0, 566, 567, 3, 261, 129, 0, 567, 568, 3, 263, 130, 0, 568, 62, 1, 0, 0, 0, 569, 570, 3, 235, 116, 0, 570, 571, 3, 251, 124, 0, 571, 64, 1, 0, 0, 0, 572, 573, 3, 235, 116, 0, 573, 574, 3, 253, 125, 0, 574, 575, 3, 247, 122, 0, 575, 576, 3, 247, 122, 0, 576, 577, 3, 253, 125, 0, 577, 578, 3, 269, 133, 0, 578, 579, 3, 241, 119, 0, 579, 580, 3, 251, 124, 0, 580, 581, 3, 237, 117, 0, 581, 66, 1, 0, 0, 0, 582, 583, 3, 235, 116, 0, 583, 584, 3, 253, 125, 0, 584, 585, 3, 259, 128, 0, 585, 68, 1, 0, 0, 0, 586, 587, 3, 235, 116, 0, 587, 588, 3, 259, 128, 0, 588, 589, 3, 253, 125, 0, 589, 590, 3, 249, 123, 0, 590, 70, 1, 0, 0, 0, 591, 592, 3, 235, 116, 0, 592, 593, 3, 265, 131, 0, 593, 594, 3, 247, 122, 0, 594, 595, 3, 247, 122, 0, 595, 72, 1, 0, 0, 0, 596, 597, 3, 235, 116, 0, 597, 598, 3, 265, 131, 0, 598, 599, 3, 251, 124, 0, 599, 74, 1, 0, 0, 0, 600, 601, 3, 237, 117, 0, 601, 602, 3, 259, 128, 0, 602, 603, 3, 253, 125, 0, 603, 604, 3, 265, 131, 0, 604, 605, 3, 255, 126, 0, 605, 76, 1, 0, 0, 0, 606, 607, 3, 239, 118, 0, 607, 608, 3, 225, 111, 0, 608, 609, 3, 267, 132, 0, 609, 610, 3, 241, 119, 0, 610, 611, 3, 251, 124, 0, 611, 612, 3, 237, 117, 0, 612, 78, 1, 0, 0, 0, 613, 614, 3, 239, 118, 0, 614, 615, 3, 253, 125, 0, 615, 616, 3, 265, 131, 0, 616, 617, 3, 259, 128, 0, 617, 80, 1, 0, 0, 0, 618, 619, 3, 241, 119, 0, 619, 620, 3, 231, 114, 0, 620, 82, 1, 0, 0, 0, 621, 622, 3, 241, 119, 0, 622, 623, 3, 235, 116, 0, 623, 84, 1, 0, 0, 0, 624, 625, 3, 241, 119, 0, 625, 626, 3, 247, 122, 0, 626, 627, 3, 241, 119, 0, 627, 628, 3, 245, 121, 0, 628, 629, 3, 233, 115, 0, 629, 86, 1, 0, 0, 0, 630, 631, 3, 241, 119, 0, 631, 632, 3, 251, 124, 0, 632, 88, 1, 0, 0, 0, 633, 634, 3, 241, 119, 0, 634, 635, 3, 251, 124, 0, 635, 636, 3, 235, 116, 0, 636, 647, 1, 0, 0, 0, 637, 638, 3, 241, 119, 0, 638, 639, 3, 251, 124, 0, 639, 640, 3, 235, 116, 0, 640, 641, 3, 241, 119, 0, 641, 642, 3, 251, 124, 0, 642, 643, 3, 241, 119, 0, 643, 644, 3, 263, 130, 0, 644, 645, 3, 273, 135, 0, 645, 647, 1, 0, 0, 0, 646, 633, 1, 0, 0, 0, 646, 637, 1, 0, 0, 0, 647, 90, 1, 0, 0, 0, 648, 649, 3, 241, 119, 0, 649, 650, 3, 251, 124, 0, 650, 651, 3, 251, 124, 0, 651, 652, 3, 233, 115, 0, 652, 653, 3, 259, 128, 0, 653, 92, 1, 0, 0, 0, 654, 655, 3, 241, 119, 0, 655, 656, 3, 251, 124, 0, 656, 657, 3, 263, 130, 0, 657, 658, 3, 233, 115, 0, 658, 659, 3, 259, 128, 0, 659, 660, 3, 267, 132, 0, 660, 661, 3, 225, 111, 0, 661, 662, 3, 247, 122, 0, 662, 94, 1, 0, 0, 0, 663, 664, 3, 241, 119, 0, 664, 665, 3, 261, 129, 0, 665, 96, 1, 0, 0, 0, 666, 667, 3, 243, 120, 0, 667, 668, 3, 253, 125, 0, 668, 669, 3, 241, 119, 0, 669, 670, 3, 251, 124, 0, 670, 98, 1, 0, 0, 0, 671, 672, 3, 245, 121, 0, 672, 673, 3, 233, 115, 0, 673, 674, 3, 273, 135, 0, 674, 100, 1, 0, 0, 0, 675, 676, 3, 247, 122, 0, 676, 677, 3, 225, 111, 0, 677, 678, 3, 261, 129, 0, 678, 679, 3, 263, 130, 0, 679, 102, 1, 0, 0, 0, 680, 681, 3, 247, 122, 0, 681, 682, 3, 233, 115, 0, 682, 683, 3, 225, 111, 0, 683, 684, 3, 231, 114, 0, 684, 685, 3, 241, 119, 0, 685, 686, 3, 251, 124, 0, 686, 687, 3, 237, 117, 0, 687, 104, 1, 0, 0, 0, 688, 689, 3, 247, 122, 0, 689, 690, 3, 233, 115, 0, 690, 691, 3, 235, 116, 0, 691, 692, 3, 263, 130, 0, 692, 106, 1, 0, 0, 0, 693, 694, 3, 247, 122, 0, 694, 695, 3, 233, 115, 0, 695, 696, 3, 263, 130, 0, 696, 108, 1, 0, 0, 0, 697, 698, 3, 247, 122, 0, 698, 699, 3, 241, 119, 0, 699, 700, 3, 245, 121, 0, 700, 701, 3, 233, 115, 0, 701, 110, 1, 0, 0, 0, 702, 703, 3, 247, 122, 0, 703, 704, 3, 241, 119, 0, 704, 705, 3, 249, 123, 0, 705, 706, 3, 241, 119, 0, 706, 707, 3, 263, 130, 0, 707, 112, 1, 0, 0, 0, 708, 709, 3, 249, 123, 0, 709, 710, 3, 241, 119, 0, 710, 711, 3, 251, 124, 0, 711, 712, 3, 265, 131, 0, 712, 713, 3, 263, 130, 0, 713, 714, 3, 233, 115, 0, 714, 114, 1, 0, 0, 0, 715, 716, 3, 249, 123, 0, 716, 717, 3, 253, 125, 0, 717, 718, 3, 251, 124, 0, 718, 719, 3, 263, 130, 0, 719, 720, 3, 239, 118, 0, 720, 116, 1, 0, 0, 0, 721, 722, 3, 251, 124, 0, 722, 723, 3, 225, 111, 0, 723, 724, 3, 251, 124, 0, 724, 118, 1, 0, 0, 0, 725, 726, 3, 251, 124, 0, 726, 727, 3, 253, 125, 0, 727, 728, 3, 263, 130, 0, 728, 120, 1, 0, 0, 0, 729, 730, 3, 251, 124, 0, 730, 731, 3, 265, 131, 0, 731, 732, 3, 247, 122, 0, 732, 733, 3, 247, 122, 0, 733, 122, 1, 0, 0, 0, 734, 735, 3, 251, 124, 0, 735, 736, 3, 265, 131, 0, 736, 737, 3, 247, 122, 0, 737, 738, 3, 247, 122, 0, 738, 739, 3, 261, 129, 0, 739, 124, 1, 0, 0, 0, 740, 741, 3, 253, 125, 0, 741, 742, 3, 235, 116, 0, 742, 743, 3, 235, 116, 0, 743, 744, 3, 261, 129, 0, 744, 745, 3, 233, 115, 0, 745, 746, 3, 263, 130, 0, 746, 126, 1, 0, 0, 0, 747, 748, 3, 253, 125, 0, 748, 749, 3, 251, 124, 0, 749, 128, 1, 0, 0, 0, 750, 751, 3, 253, 125, 0, 751, 752, 3, 259, 128, 0, 752, 130, 1, 0, 0, 0, 753, 754, 3, 253, 125, 0, 754, 755, 3, 259, 128, 0, 755, 756, 3, 231, 114, 0, 756, 757, 3, 233, 115, 0, 757, 758, 3, 259, 128, 0, 758, 132, 1, 0, 0, 0, 759, 760, 3, 253, 125, 0, 760, 761, 3, 265, 131, 0, 761, 762, 3, 263, 130, 0, 762, 763, 3, 233, 115, 0, 763, 764, 3, 259, 128, 0, 764, 134, 1, 0, 0, 0, 765, 766, 3, 253, 125, 0, 766, 767, 3, 267, 132, 0, 767, 768, 3, 233, 115, 0, 768, 769, 3, 259, 128, 0, 769, 136, 1, 0, 0, 0, 770, 771, 3, 255, 126, 0, 771, 772, 3, 225, 111, 0, 772, 773, 3, 259, 128, 0, 773, 774, 3, 263, 130, 0, 774, 775, 3, 241, 119, 0, 775, 776, 3, 263, 130, 0, 776, 777, 3, 241, 119, 0, 777, 778, 3, 253, 125, 0, 778, 779, 3, 251, 124, 0, 779, 138, 1, 0, 0, 0, 780, 781, 3, 255, 126, 0, 781, 782, 3, 259, 128, 0, 782, 783, 3, 233, 115, 0, 783, 784, 3, 229, 113, 0, 784, 785, 3, 233, 115, 0, 785, 786, 3, 231, 114, 0, 786, 787, 3, 241, 119, 0, 787, 788, 3, 251, 124, 0, 788, 789, 3, 237, 117, 0, 789, 140, 1, 0, 0, 0, 790, 791, 3, 255, 126, 0, 791, 792, 3, 259, 128, 0, 792, 793, 3, 233, 115, 0, 793, 794, 3, 269, 133, 0, 794, 795, 3, 239, 118, 0, 795, 796, 3, 233, 115, 0, 796, 797, 3, 259, 128, 0, 797, 798, 3, 233, 115, 0, 798, 142, 1, 0, 0, 0, 799, 800, 3, 257, 127, 0, 800, 801, 3, 265, 131, 0, 801, 802, 3, 225, 111, 0, 802, 803, 3, 259, 128, 0, 803, 804, 3, 263, 130, 0, 804, 805, 3, 233, 115, 0, 805, 806, 3, 259, 128, 0, 806, 144, 1, 0, 0, 0, 807, 808, 3, 259, 128, 0, 808, 809, 3, 225, 111, 0, 809, 810, 3, 251, 124, 0, 810, 811, 3, 237, 117, 0, 811, 812, 3, 233, 115, 0, 812, 146, 1, 0, 0, 0, 813, 814, 3, 259, 128, 0, 814, 815, 3, 233, 115, 0, 815, 816, 3, 263, 130, 0, 816, 817, 3, 265, 131, 0, 817, 818, 3, 259, 128, 0, 818, 819, 3, 251, 124, 0, 819, 148, 1, 0, 0, 0, 820, 821, 3, 259, 128, 0, 821, 822, 3, 241, 119, 0, 822, 823, 3, 237, 117, 0, 823, 824, 3, 239, 118, 0, 824, 825, 3, 263, 130, 0, 825, 150, 1, 0, 0, 0, 826, 827, 3, 259, 128, 0, 827, 828, 3, 253, 125, 0, 828, 829, 3, 247, 122, 0, 829, 830, 3, 247, 122, 0, 830, 831, 3, 265, 131, 0, 831, 832, 3, 255, 126, 0, 832, 152, 1, 0, 0, 0, 833, 834, 3, 259, 128, 0, 834, 835, 3, 253, 125, 0, 835, 836, 3, 269, 133, 0, 836, 154, 1, 0, 0, 0, 837, 838, 3, 259, 128, 0, 838, 839, 3, 253, 125, 0, 839, 840, 3, 269, 133, 0, 840, 841, 3, 261, 129, 0, 841, 156, 1, 0, 0, 0, 842, 843, 3, 261, 129, 0, 843, 844, 3, 225, 111, 0, 844, 845, 3, 249, 123, 0, 845, 846, 3, 255, 126, 0, 846, 847, 3, 247, 122, 0, 847, 848, 3, 233, 115, 0, 848, 158, 1, 0, 0, 0, 849, 850, 3, 261, 129, 0, 850, 851, 3, 233, 115, 0, 851, 852, 3, 229, 113, 0, 852, 853, 3, 253, 125, 0, 853, 854, 3, 251, 124, 0, 854, 855, 3, 231, 114, 0, 855, 160, 1, 0, 0, 0, 856, 857, 3, 261, 129, 0, 857, 858, 3, 233, 115, 0, 858, 859, 3, 247, 122, 0, 859, 860, 3, 233, 115, 0, 860, 861, 3, 229, 113, 0, 861, 862, 3, 263, 130, 0, 862, 162, 1, 0, 0, 0, 863, 864, 3, 261, 129, 0, 864, 865, 3, 233, 115, 0, 865, 866, 3, 249, 123, 0, 866, 867, 3, 241, 119, 0, 867, 164, 1, 0, 0, 0, 868, 869, 3, 261, 129, 0, 869, 870, 3, 233, 115, 0, 870, 871, 3, 263, 130, 0, 871, 872, 3, 263, 130, 0, 872, 873, 3, 241, 119, 0, 873, 874, 3, 251, 124, 0, 874, 875, 3, 237, 117, 0, 875, 876, 3, 261, 129, 0, 876, 166, 1, 0, 0, 0, 877, 878, 3, 261, 129, 0, 878, 879, 3, 265, 131, 0, 879, 880, 3, 227, 112, 0, 880, 881, 3, 261, 129, 0, 881, 882, 3, 263, 130, 0, 882, 883, 3, 259, 128, 0, 883, 884, 3, 241, 119, 0, 884, 885, 3, 251, 124, 0, 885, 886, 3, 237, 117, 0, 886, 168, 1, 0, 0, 0, 887, 888, 3, 263, 130, 0, 888, 889, 3, 239, 118, 0, 889, 890, 3, 233, 115, 0, 890, 891, 3, 251, 124, 0, 891, 170, 1, 0, 0, 0, 892, 893, 3, 263, 130, 0, 893, 894, 3, 239, 118, 0, 894, 895, 3, 259, 128, 0, 895, 896, 3, 253, 125, 0, 896, 897, 3, 269, 133, 0, 897, 172, 1, 0, 0, 0, 898, 899, 3, 263, 130, 0, 899, 900, 3, 241, 119, 0, 900, 901, 3, 233, 115, 0, 901, 902, 3, 261, 129, 0, 902, 174, 1, 0, 0, 0, 903, 904, 3, 263, 130, 0, 904, 905, 3, 241, 119, 0, 905, 906, 3, 249, 123, 0, 906, 907, 3, 233, 115, 0, 907, 908, 3, 261, 129, 0, 908, 909, 3, 263, 130, 0, 909, 910, 3, 225, 111, 0, 910, 911, 3, 249, 123, 0, 911, 912, 3, 255, 126, 0, 912, 176, 1, 0, 0, 0, 913, 914, 3, 263, 130, 0, 914, 915, 3, 253, 125, 0, 915, 178, 1, 0, 0, 0, 916, 917, 3, 263, 130, 0, 917, 918, 3, 253, 125, 0, 918, 919, 3, 255, 126, 0, 919, 180, 1, 0, 0, 0, 920, 921, 3, 263, 130, 0, 921, 922, 3, 253, 125, 0, 922, 923, 3, 263, 130, 0, 923, 924, 3, 225, 111, 0, 924, 925, 3, 247, 122, 0, 925, 926, 3, 261, 129, 0, 926, 182, 1, 0, 0, 0, 927, 928, 3, 263, 130, 0, 928, 929, 3, 259, 128, 0, 929, 930, 3, 225, 111, 0, 930, 931, 3, 241, 119, 0, 931, 932, 3, 247, 122, 0, 932, 933, 3, 241, 119, 0, 933, 934, 3, 251, 124, 0, 934, 935, 3, 237, 117, 0, 935, 184, 1, 0, 0, 0, 936, 937, 3, 263, 130, 0, 937, 938, 3, 259, 128, 0, 938, 939, 3, 241, 119, 0, 939, 940, 3, 249, 123, 0, 940, 186, 1, 0, 0, 0, 941, 942, 3, 263, 130, 0, 942, 943, 3, 259, 128, 0, 943, 944, 3, 265, 131, 0, 944, 945, 3, 251, 124, 0, 945, 946, 3, 229, 113, 0, 946, 947, 3, 225, 111, 0, 947, 948, 3, 263, 130, 0, 948, 949, 3, 233, 115, 0, 949, 188, 1, 0, 0, 0, 950, 951, 3, 263, 130, 0, 951, 952, 3, 259, 128, 0, 952, 953, 3, 273, 135, 0, 953, 190, 1, 0, 0, 0, 954, 955, 3, 265, 131, 0, 955, 956, 3, 251, 124, 0, 956, 957, 3, 227, 112, 0, 957, 958, 3, 253, 125, 0, 958, 959, 3, 265, 131, 0, 959, 960, 3, 251, 124, 0, 960, 961, 3, 231, 114, 0, 961, 962, 3, 233, 115, 0, 962, 963, 3, 231, 114, 0, 963, 192, 1, 0, 0, 0, 964, 965, 3, 265, 131, 0, 965, 966, 3, 251, 124, 0, 966, 967, 3, 241, 119, 0, 967, 968, 3, 253, 125, 0, 968, 969, 3, 251, 124, 0, 969, 194, 1, 0, 0, 0, 970, 971, 3, 265, 131, 0, 971, 972, 3, 261, 129, 0, 972, 973, 3, 241, 119, 0, 973, 974, 3, 251, 124, 0, 974, 975, 3, 237, 117, 0, 975, 196, 1, 0, 0, 0, 976, 977, 3, 269, 133, 0, 977, 978, 3, 233, 115, 0, 978, 979, 3, 233, 115, 0, 979, 980, 3, 245, 121, 0, 980, 198, 1, 0, 0, 0, 981, 982, 3, 269, 133, 0, 982, 983, 3, 239, 118, 0, 983, 984, 3, 233, 115, 0, 984, 985, 3, 251, 124, 0, 985, 200, 1, 0, 0, 0, 986, 987, 3, 269, 133, 0, 987, 988, 3, 239, 118, 0, 988, 989, 3, 233, 115, 0, 989, 990, 3, 259, 128, 0, 990, 991, 3, 233, 115, 0, 991, 202, 1, 0, 0, 0, 992, 993, 3, 269, 133, 0, 993, 994, 3, 239, 118, 0, 994, 995, 3, 241, 119, 0, 995, 996, 3, 247, 122, 0, 996, 997, 3, 233, 115, 0, 997, 204, 1, 0, 0, 0, 998, 999, 3, 269, 133, 0, 999, 1000, 3, 241, 119, 0, 1000, 1001, 3, 251, 124, 0, 1001, 1002, 3, 231, 114, 0, 1002, 1003, 3, 253, 125, 0, 1003, 1004, 3, 269, 133, 0, 1004, 206, 1, 0, 0, 0, 1005, 1006, 3, 269, 133, 0, 1006, 1007, 3, 241, 119, 0, 1007, 1008, 3, 263, 130, 0, 1008, 1009, 3, 239, 118, 0, 1009, 208, 1, 0, 0, 0, 1010, 1011, 3, 273, 135, 0, 1011, 1012, 3, 233, 115, 0, 1012, 1013, 3, 225, 111, 0, 1013, 1014, 3, 259, 128, 0, 1014, 1021, 1, 0, 0, 0, 1015, 1016, 3, 273, 135, 0, 1016, 1017, 3, 273, 135, 0, 1017, 1018, 3, 273, 135, 0, 1018, 1019, 3, 273, 135, 0, 1019, 1021, 1, 0, 0, 0, 1020, 1010, 1, 0, 0, 0, 1020, 1015, 1, 0, 0, 0, 1021, 210, 1, 0, 0, 0, 1022, 1023, 3, 291, 144, 0, 1023, 1024, 3, 227, 112, 0, 1024, 1050, 1, 0, 0, 0, 1025, 1026, 3, 291, 144, 0, 1026, 1027, 3, 235, 116, 0, 1027, 1050, 1, 0, 0, 0, 1028, 1029, 3, 291, 144, 0, 1029, 1030, 3, 259, 128, 0, 1030, 1050, 1, 0, 0, 0, 1031, 1032, 3, 291, 144, 0, 1032, 1033, 3, 251, 124, 0, 1033, 1050, 1, 0, 0, 0, 1034, 1035, 3, 291, 144, 0, 1035, 1036, 3, 263, 130, 0, 1036, 1050, 1, 0, 0, 0, 1037, 1038, 3, 291, 144, 0, 1038, 1039, 5, 48, 0, 0, 1039, 1050, 1, 0, 0, 0, 1040, 1041, 3, 291, 144, 0, 1041, 1042, 3, 225, 111, 0, 1042, 1050, 1, 0, 0, 0, 1043, 1044, 3, 291, 144, 0, 1044, 1045, 3, 267, 132, 0, 1045, 1050, 1, 0, 0, 0, 1046, 1047, 3, 291, 144, 0, 1047, 1048, 3, 291, 144, 0, 1048, 1050, 1, 0, 0, 0, 1049, 1022, 1, 0, 0, 0, 1049, 1025, 1, 0, 0, 0, 1049, 1028, 1, 0, 0, 0, 1049, 1031, 1, 0, 0, 0, 1049, 1034, 1, 0, 0, 0, 1049, 1037, 1, 0, 0, 0, 1049, 1040, 1, 0, 0, 0, 1049, 1043, 1, 0, 0, 0, 1049, 1046, 1, 0, 0, 0, 1050, 212, 1, 0, 0, 0, 1051, 1055, 3, 277, 137, 0, 1052, 1055, 3, 367, 182, 0, 1053, 1055, 3, 301, 149, 0, 1054, 1051, 1, 0, 0, 0, 1054, 1052, 1, 0, 0, 0, 1054, 1053, 1, 0, 0, 0, 1055, 1062, 1, 0, 0, 0, 1056, 1061, 3, 277, 137, 0, 1057, 1061, 3, 367, 182, 0, 1058, 1061, 3, 281, 139, 0, 1059, 1061, 3, 301, 149, 0, 1060, 1056, 1, 0, 0, 0, 1060, 1057, 1, 0, 0, 0, 1060, 1058, 1, 0, 0, 0, 1060, 1059, 1, 0, 0, 0, 1061, 1064, 1, 0, 0, 0, 1062, 1060, 1, 0, 0, 0, 1062, 1063, 1, 0, 0, 0, 1063, 1098, 1, 0, 0, 0, 1064, 1062, 1, 0, 0, 0, 1065, 1076, 3, 289, 143, 0, 1066, 1075, 8, 0, 0, 0, 1067, 1075, 3, 211, 104, 0, 1068, 1069, 3, 291, 144, 0, 1069, 1070, 3, 351, 174, 0, 1070, 1075, 1, 0, 0, 0, 1071, 1072, 3, 289, 143, 0, 1072, 1073, 3, 289, 143, 0, 1073, 1075, 1, 0, 0, 0, 1074, 1066, 1, 0, 0, 0, 1074, 1067, 1, 0, 0, 0, 1074, 1068, 1, 0, 0, 0, 1074, 1071, 1, 0, 0, 0, 1075, 1078, 1, 0, 0, 0, 1076, 1074, 1, 0, 0, 0, 1076, 1077, 1, 0, 0, 0, 1077, 1079, 1, 0, 0, 0, 1078, 1076, 1, 0, 0, 0, 1079, 1080, 3, 289, 143, 0, 1080, 1098, 1, 0, 0, 0, 1081, 1092, 3, 345, 171, 0, 1082, 1091, 8, 1, 0, 0, 1083, 1091, 3, 211, 104, 0, 1084, 1085, 3, 291, 144, 0, 1085, 1086, 3, 345, 171, 0, 1086, 1091, 1, 0, 0, 0, 1087, 1088, 3, 345, 171, 0, 1088, 1089, 3, 345, 171, 0, 1089, 1091, 1, 0, 0, 0, 1090, 1082, 1, 0, 0, 0, 1090, 1083, 1, 0, 0, 0, 1090, 1084, 1, 0, 0, 0, 1090, 1087, 1, 0, 0, 0, 1091, 1094, 1, 0, 0, 0, 1092, 1090, 1, 0, 0, 0, 1092, 1093, 1, 0, 0, 0, 1093, 1095, 1, 0, 0, 0, 1094, 1092, 1, 0, 0, 0, 1095, 1096, 3, 345, 171, 0, 1096, 1098, 1, 0, 0, 0, 1097, 1054, 1, 0, 0, 0, 1097, 1065, 1, 0, 0, 0, 1097, 1081, 1, 0, 0, 0, 1098, 214, 1, 0, 0, 0, 1099, 1100, 3, 221, 109, 0, 1100, 1104, 3, 303, 150, 0, 1101, 1103, 3, 283, 140, 0, 1102, 1101, 1, 0, 0, 0, 1103, 1106, 1, 0, 0, 0, 1104, 1102, 1, 0, 0, 0, 1104, 1105, 1, 0, 0, 0, 1105, 1109, 1, 0, 0, 0, 1106, 1104, 1, 0, 0, 0, 1107, 1110, 3, 255, 126, 0, 1108, 1110, 3, 233, 115, 0, 1109, 1107, 1, 0, 0, 0, 1109, 1108, 1, 0, 0, 0, 1110, 1113, 1, 0, 0, 0, 1111, 1114, 3, 341, 169, 0, 1112, 1114, 3, 299, 148, 0, 1113, 1111, 1, 0, 0, 0, 1113, 1112, 1, 0, 0, 0, 1113, 1114, 1, 0, 0, 0, 1114, 1116, 1, 0, 0, 0, 1115, 1117, 3, 281, 139, 0, 1116, 1115, 1, 0, 0, 0, 1117, 1118, 1, 0, 0, 0, 1118, 1116, 1, 0, 0, 0, 1118, 1119, 1, 0, 0, 0, 1119, 1176, 1, 0, 0, 0, 1120, 1123, 3, 221, 109, 0, 1121, 1124, 3, 255, 126, 0, 1122, 1124, 3, 233, 115, 0, 1123, 1121, 1, 0, 0, 0, 1123, 1122, 1, 0, 0, 0, 1124, 1127, 1, 0, 0, 0, 1125, 1128, 3, 341, 169, 0, 1126, 1128, 3, 299, 148, 0, 1127, 1125, 1, 0, 0, 0, 1127, 1126, 1, 0, 0, 0, 1127, 1128, 1, 0, 0, 0, 1128, 1130, 1, 0, 0, 0, 1129, 1131, 3, 281, 139, 0, 1130, 1129, 1, 0, 0, 0, 1131, 1132, 1, 0, 0, 0, 1132, 1130, 1, 0, 0, 0, 1132, 1133, 1, 0, 0, 0, 1133, 1176, 1, 0, 0, 0, 1134, 1135, 3, 219, 108, 0, 1135, 1139, 3, 303, 150, 0, 1136, 1138, 3, 281, 139, 0, 1137, 1136, 1, 0, 0, 0, 1138, 1141, 1, 0, 0, 0, 1139, 1137, 1, 0, 0, 0, 1139, 1140, 1, 0, 0, 0, 1140, 1142, 1, 0, 0, 0, 1141, 1139, 1, 0, 0, 0, 1142, 1145, 3, 233, 115, 0, 1143, 1146, 3, 341, 169, 0, 1144, 1146, 3, 299, 148, 0, 1145, 1143, 1, 0, 0, 0, 1145, 1144, 1, 0, 0, 0, 1145, 1146, 1, 0, 0, 0, 1146, 1148, 1, 0, 0, 0, 1147, 1149, 3, 281, 139, 0, 1148, 1147, 1, 0, 0, 0, 1149, 1150, 1, 0, 0, 0, 1150, 1148, 1, 0, 0, 0, 1150, 1151, 1, 0, 0, 0, 1151, 1176, 1, 0, 0, 0, 1152, 1153, 3, 303, 150, 0, 1153, 1154, 3, 219, 108, 0, 1154, 1157, 3, 233, 115, 0, 1155, 1158, 3, 341, 169, 0, 1156, 1158, 3, 299, 148, 0, 1157, 1155, 1, 0, 0, 0, 1157, 1156, 1, 0, 0, 0, 1157, 1158, 1, 0, 0, 0, 1158, 1160, 1, 0, 0, 0, 1159, 1161, 3, 281, 139, 0, 1160, 1159, 1, 0, 0, 0, 1161, 1162, 1, 0, 0, 0, 1162, 1160, 1, 0, 0, 0, 1162, 1163, 1, 0, 0, 0, 1163, 1176, 1, 0, 0, 0, 1164, 1165, 3, 219, 108, 0, 1165, 1168, 3, 233, 115, 0, 1166, 1169, 3, 341, 169, 0, 1167, 1169, 3, 299, 148, 0, 1168, 1166, 1, 0, 0, 0, 1168, 1167, 1, 0, 0, 0, 1168, 1169, 1, 0, 0, 0, 1169, 1171, 1, 0, 0, 0, 1170, 1172, 3, 281, 139, 0, 1171, 1170, 1, 0, 0, 0, 1172, 1173, 1, 0, 0, 0, 1173, 1171, 1, 0, 0, 0, 1173, 1174, 1, 0, 0, 0, 1174, 1176, 1, 0, 0, 0, 1175, 1099, 1, 0, 0, 0, 1175, 1120, 1, 0, 0, 0, 1175, 1134, 1, 0, 0, 0, 1175, 1152, 1, 0, 0, 0, 1175, 1164, 1, 0, 0, 0, 1176, 216, 1, 0, 0, 0, 1177, 1179, 5, 48, 0, 0, 1178, 1180, 3, 279, 138, 0, 1179, 1178, 1, 0, 0, 0, 1180, 1181, 1, 0, 0, 0, 1181, 1179, 1, 0, 0, 0, 1181, 1182, 1, 0, 0, 0, 1182, 218, 1, 0, 0, 0, 1183, 1185, 3, 281, 139, 0, 1184, 1183, 1, 0, 0, 0, 1185, 1186, 1, 0, 0, 0, 1186, 1184, 1, 0, 0, 0, 1186, 1187, 1, 0, 0, 0, 1187, 220, 1, 0, 0, 0, 1188, 1189, 5, 48, 0, 0, 1189, 1191, 3, 271, 134, 0, 1190, 1192, 3, 283, 140, 0, 1191, 1190, 1, 0, 0, 0, 1192, 1193, 1, 0, 0, 0, 1193, 1191, 1, 0, 0, 0, 1193, 1194, 1, 0, 0, 0, 1194, 222, 1, 0, 0, 0, 1195, 1206, 3, 351, 174, 0, 1196, 1205, 8, 2, 0, 0, 1197, 1205, 3, 211, 104, 0, 1198, 1199, 3, 291, 144, 0, 1199, 1200, 3, 351, 174, 0, 1200, 1205, 1, 0, 0, 0, 1201, 1202, 3, 351, 174, 0, 1202, 1203, 3, 351, 174, 0, 1203, 1205, 1, 0, 0, 0, 1204, 1196, 1, 0, 0, 0, 1204, 1197, 1, 0, 0, 0, 1204, 1198, 1, 0, 0, 0, 1204, 1201, 1, 0, 0, 0, 1205, 1208, 1, 0, 0, 0, 1206, 1204, 1, 0, 0, 0, 1206, 1207, 1, 0, 0, 0, 1207, 1209, 1, 0, 0, 0, 1208, 1206, 1, 0, 0, 0, 1209, 1210, 3, 351, 174, 0, 1210, 224, 1, 0, 0, 0, 1211, 1212, 7, 3, 0, 0, 1212, 226, 1, 0, 0, 0, 1213, 1214, 7, 4, 0, 0, 1214, 228, 1, 0, 0, 0, 1215, 1216, 7, 5, 0, 0, 1216, 230, 1, 0, 0, 0, 1217, 1218, 7, 6, 0, 0, 1218, 232, 1, 0, 0, 0, 1219, 1220, 7, 7, 0, 0, 1220, 234, 1, 0, 0, 0, 1221, 1222, 7, 8, 0, 0, 1222, 236, 1, 0, 0, 0, 1223, 1224, 7, 9, 0, 0, 1224, 238, 1, 0, 0, 0, 1225, 1226, 7, 10, 0, 0, 1226, 240, 1, 0, 0, 0, 1227, 1228, 7, 11, 0, 0, 1228, 242, 1, 0, 0, 0, 1229, 1230, 7, 12, 0, 0, 1230, 244, 1, 0, 0, 0, 1231, 1232, 7, 13, 0, 0, 1232, 246, 1, 0, 0, 0, 1233, 1234, 7, 14, 0, 0, 1234, 248, 1, 0, 0, 0, 1235, 1236, 7, 15, 0, 0, 1236, 250, 1, 0, 0, 0, 1237, 1238, 7, 16, 0, 0, 1238, 252, 1, 0, 0, 0, 1239, 1240, 7, 17, 0, 0, 1240, 254, 1, 0, 0, 0, 1241, 1242, 7, 18, 0, 0, 1242, 256, 1, 0, 0, 0, 1243, 1244, 7, 19, 0, 0, 1244, 258, 1, 0, 0, 0, 1245, 1246, 7, 20, 0, 0, 1246, 260, 1, 0, 0, 0, 1247, 1248, 7, 21, 0, 0, 1248, 262, 1, 0, 0, 0, 1249, 1250, 7, 22, 0, 0, 1250, 264, 1, 0, 0, 0, 1251, 1252, 7, 23, 0, 0, 1252, 266, 1, 0, 0, 0, 1253, 1254, 7, 24, 0, 0, 1254, 268, 1, 0, 0, 0, 1255, 1256, 7, 25, 0, 0, 1256, 270, 1, 0, 0, 0, 1257, 1258, 7, 26, 0, 0, 1258, 272, 1, 0, 0, 0, 1259, 1260, 7, 27, 0, 0, 1260, 274, 1, 0, 0, 0, 1261, 1262, 7, 28, 0, 0, 1262, 276, 1, 0, 0, 0, 1263, 1264, 7, 29, 0, 0, 1264, 278, 1, 0, 0, 0, 1265, 1266, 7, 30, 0, 0, 1266, 280, 1, 0, 0, 0, 1267, 1268, 7, 31, 0, 0, 1268, 282, 1, 0, 0, 0, 1269, 1270, 7, 32, 0, 0, 1270, 284, 1, 0, 0, 0, 1271, 1272, 5, 45, 0, 0, 1272, 1273, 5, 62, 0, 0, 1273, 286, 1, 0, 0, 0, 1274, 1275, 5, 42, 0, 0, 1275, 288, 1, 0, 0, 0, 1276, 1277, 5, 96, 0, 0, 1277, 290, 1, 0, 0, 0, 1278, 1279, 5, 92, 0, 0, 1279, 292, 1, 0, 0, 0, 1280, 1281, 5, 58, 0, 0, 1281, 294, 1, 0, 0, 0, 1282, 1283, 5, 44, 0, 0, 1283, 296, 1, 0, 0, 0, 1284, 1285, 5, 124, 0, 0, 1285, 1286, 5, 124, 0, 0, 1286, 298, 1, 0, 0, 0, 1287, 1288, 5, 45, 0, 0, 1288, 300, 1, 0, 0, 0, 1289, 1290, 5, 36, 0, 0, 1290, 302, 1, 0, 0, 0, 1291, 1292, 5, 46, 0, 0, 1292, 304, 1, 0, 0, 0, 1293, 1294, 5, 61, 0, 0, 1294, 1295, 5, 61, 0, 0, 1295, 306, 1, 0, 0, 0, 1296, 1297, 5, 61, 0, 0, 1297, 308, 1, 0, 0, 0, 1298, 1299, 5, 62, 0, 0, 1299, 1300, 5, 61, 0, 0, 1300, 310, 1, 0, 0, 0, 1301, 1302, 5, 62, 0, 0, 1302, 312, 1, 0, 0, 0, 1303, 1304, 5, 35, 0, 0, 1304, 314, 1, 0, 0, 0, 1305, 1306, 5, 126, 0, 0, 1306, 1307, 5, 42, 0, 0, 1307, 316, 1, 0, 0, 0, 1308, 1309, 5, 61, 0, 0, 1309, 1310, 5, 126, 0, 0, 1310, 1311, 5, 42, 0, 0, 1311, 318, 1, 0, 0, 0, 1312, 1313, 5, 123, 0, 0, 1313, 1314, 1, 0, 0, 0, 1314, 1315, 6, 158, 0, 0, 1315, 320, 1, 0, 0, 0, 1316, 1317, 5, 91, 0, 0, 1317, 322, 1, 0, 0, 0, 1318, 1319, 5, 40, 0, 0, 1319, 324, 1, 0, 0, 0, 1320, 1321, 5, 60, 0, 0, 1321, 1322, 5, 61, 0, 0, 1322, 326, 1, 0, 0, 0, 1323, 1324, 5, 60, 0, 0, 1324, 328, 1, 0, 0, 0, 1325, 1326, 5, 33, 0, 0, 1326, 1330, 5, 61, 0, 0, 1327, 1328, 5, 60, 0, 0, 1328, 1330, 5, 62, 0, 0, 1329, 1325, 1, 0, 0, 0, 1329, 1327, 1, 0, 0, 0, 1330, 330, 1, 0, 0, 0, 1331, 1332, 5, 33, 0, 0, 1332, 1333, 5, 126, 0, 0, 1333, 1334, 5, 42, 0, 0, 1334, 332, 1, 0, 0, 0, 1335, 1336, 5, 33, 0, 0, 1336, 1337, 5, 126, 0, 0, 1337, 334, 1, 0, 0, 0, 1338, 1339, 5, 63, 0, 0, 1339, 1340, 5, 46, 0, 0, 1340, 336, 1, 0, 0, 0, 1341, 1342, 5, 63, 0, 0, 1342, 1343, 5, 63, 0, 0, 1343, 338, 1, 0, 0, 0, 1344, 1345, 5, 37, 0, 0, 1345, 340, 1, 0, 0, 0, 1346, 1347, 5, 43, 0, 0, 1347, 342, 1, 0, 0, 0, 1348, 1349, 5, 63, 0, 0, 1349, 344, 1, 0, 0, 0, 1350, 1351, 5, 34, 0, 0, 1351, 346, 1, 0, 0, 0, 1352, 1353, 5, 102, 0, 0, 1353, 1354, 5, 39, 0, 0, 1354, 1355, 1, 0, 0, 0, 1355, 1356, 6, 172, 1, 0, 1356, 348, 1, 0, 0, 0, 1357, 1358, 5, 70, 0, 0, 1358, 1359, 5, 39, 0, 0, 1359, 1360, 1, 0, 0, 0, 1360, 1361, 6, 173, 2, 0, 1361, 350, 1, 0, 0, 0, 1362, 1363, 5, 39, 0, 0, 1363, 352, 1, 0, 0, 0, 1364, 1365, 5, 126, 0, 0, 1365, 354, 1, 0, 0, 0, 1366, 1367, 5, 61, 0, 0, 1367, 1368, 5, 126, 0, 0, 1368, 356, 1, 0, 0, 0, 1369, 1370, 5, 125, 0, 0, 1370, 1371, 1, 0, 0, 0, 1371, 1372, 6, 177, 3, 0, 1372, 358, 1, 0, 0, 0, 1373, 1374, 5, 93, 0, 0, 1374, 360, 1, 0, 0, 0, 1375, 1376, 5, 41, 0, 0, 1376, 362, 1, 0, 0, 0, 1377, 1378, 5, 59, 0, 0, 1378, 364, 1, 0, 0, 0, 1379, 1380, 5, 47, 0, 0, 1380, 366, 1, 0, 0, 0, 1381, 1382, 5, 95, 0, 0, 1382, 368, 1, 0, 0, 0, 1383, 1384, 5, 47, 0, 0, 1384, 1385, 5, 42, 0, 0, 1385, 1389, 1, 0, 0, 0, 1386, 1388, 9, 0, 0, 0, 1387, 1386, 1, 0, 0, 0, 1388, 1391, 1, 0, 0, 0, 1389, 1390, 1, 0, 0, 0, 1389, 1387, 1, 0, 0, 0, 1390, 1392, 1, 0, 0, 0, 1391, 1389, 1, 0, 0, 0, 1392, 1393, 5, 42, 0, 0, 1393, 1394, 5, 47, 0, 0, 1394, 1395, 1, 0, 0, 0, 1395, 1396, 6, 183, 4, 0, 1396, 370, 1, 0, 0, 0, 1397, 1398, 5, 45, 0, 0, 1398, 1402, 5, 45, 0, 0, 1399, 1400, 5, 47, 0, 0, 1400, 1402, 5, 47, 0, 0, 1401, 1397, 1, 0, 0, 0, 1401, 1399, 1, 0, 0, 0, 1402, 1406, 1, 0, 0, 0, 1403, 1405, 8, 33, 0, 0, 1404, 1403, 1, 0, 0, 0, 1405, 1408, 1, 0, 0, 0, 1406, 1404, 1, 0, 0, 0, 1406, 1407, 1, 0, 0, 0, 1407, 1410, 1, 0, 0, 0, 1408, 1406, 1, 0, 0, 0, 1409, 1411, 7, 34, 0, 0, 1410, 1409, 1, 0, 0, 0, 1411, 1412, 1, 0, 0, 0, 1412, 1413, 6, 184, 4, 0, 1413, 372, 1, 0, 0, 0, 1414, 1415, 7, 35, 0, 0, 1415, 1416, 1, 0, 0, 0, 1416, 1417, 6, 185, 5, 0, 1417, 374, 1, 0, 0, 0, 1418, 1430, 8, 36, 0, 0, 1419, 1430, 3, 211, 104, 0, 1420, 1421, 3, 291, 144, 0, 1421, 1422, 3, 351, 174, 0, 1422, 1430, 1, 0, 0, 0, 1423, 1424, 3, 291, 144, 0, 1424, 1425, 3, 319, 158, 0, 1425, 1430, 1, 0, 0, 0, 1426, 1427, 3, 351, 174, 0, 1427, 1428, 3, 351, 174, 0, 1428, 1430, 1, 0, 0, 0, 1429, 1418, 1, 0, 0, 0, 1429, 1419, 1, 0, 0, 0, 1429, 1420, 1, 0, 0, 0, 1429, 1423, 1, 0, 0, 0, 1429, 1426, 1, 0, 0, 0, 1430, 1431, 1, 0, 0, 0, 1431, 1429, 1, 0, 0, 0, 1431, 1432, 1, 0, 0, 0, 1432, 376, 1, 0, 0, 0, 1433, 1434, 3, 319, 158, 0, 1434, 1435, 1, 0, 0, 0, 1435, 1436, 6, 187, 0, 0, 1436, 378, 1, 0, 0, 0, 1437, 1438, 3, 351, 174, 0, 1438, 1439, 1, 0, 0, 0, 1439, 1440, 6, 188, 6, 0, 1440, 1441, 6, 188, 3, 0, 1441, 380, 1, 0, 0, 0, 1442, 1448, 8, 37, 0, 0, 1443, 1448, 3, 211, 104, 0, 1444, 1445, 3, 291, 144, 0, 1445, 1446, 3, 319, 158, 0, 1446, 1448, 1, 0, 0, 0, 1447, 1442, 1, 0, 0, 0, 1447, 1443, 1, 0, 0, 0, 1447, 1444, 1, 0, 0, 0, 1448, 1449, 1, 0, 0, 0, 1449, 1447, 1, 0, 0, 0, 1449, 1450, 1, 0, 0, 0, 1450, 382, 1, 0, 0, 0, 1451, 1452, 3, 319, 158, 0, 1452, 1453, 1, 0, 0, 0, 1453, 1454, 6, 190, 0, 0, 1454, 384, 1, 0, 0, 0, 44, 0, 1, 2, 425, 646, 1020, 1049, 1054, 1060, 1062, 1074, 1076, 1090, 1092, 1097, 1104, 1109, 1113, 1118, 1123, 1127, 1132, 1139, 1145, 1150, 1157, 1162, 1168, 1173, 1175, 1181, 1186, 1193, 1204, 1206, 1329, 1389, 1401, 1406, 1410, 1429, 1431, 1447, 1449, 7, 5, 0, 0, 5, 1, 0, 5, 2, 0, 4, 0, 0, 6, 0, 0, 0, 1, 0, 7, 145, 0] \ No newline at end of file +[4, 0, 162, 1476, 6, -1, 6, -1, 6, -1, 2, 0, 7, 0, 2, 1, 7, 1, 2, 2, 7, 2, 2, 3, 7, 3, 2, 4, 7, 4, 2, 5, 7, 5, 2, 6, 7, 6, 2, 7, 7, 7, 2, 8, 7, 8, 2, 9, 7, 9, 2, 10, 7, 10, 2, 11, 7, 11, 2, 12, 7, 12, 2, 13, 7, 13, 2, 14, 7, 14, 2, 15, 7, 15, 2, 16, 7, 16, 2, 17, 7, 17, 2, 18, 7, 18, 2, 19, 7, 19, 2, 20, 7, 20, 2, 21, 7, 21, 2, 22, 7, 22, 2, 23, 7, 23, 2, 24, 7, 24, 2, 25, 7, 25, 2, 26, 7, 26, 2, 27, 7, 27, 2, 28, 7, 28, 2, 29, 7, 29, 2, 30, 7, 30, 2, 31, 7, 31, 2, 32, 7, 32, 2, 33, 7, 33, 2, 34, 7, 34, 2, 35, 7, 35, 2, 36, 7, 36, 2, 37, 7, 37, 2, 38, 7, 38, 2, 39, 7, 39, 2, 40, 7, 40, 2, 41, 7, 41, 2, 42, 7, 42, 2, 43, 7, 43, 2, 44, 7, 44, 2, 45, 7, 45, 2, 46, 7, 46, 2, 47, 7, 47, 2, 48, 7, 48, 2, 49, 7, 49, 2, 50, 7, 50, 2, 51, 7, 51, 2, 52, 7, 52, 2, 53, 7, 53, 2, 54, 7, 54, 2, 55, 7, 55, 2, 56, 7, 56, 2, 57, 7, 57, 2, 58, 7, 58, 2, 59, 7, 59, 2, 60, 7, 60, 2, 61, 7, 61, 2, 62, 7, 62, 2, 63, 7, 63, 2, 64, 7, 64, 2, 65, 7, 65, 2, 66, 7, 66, 2, 67, 7, 67, 2, 68, 7, 68, 2, 69, 7, 69, 2, 70, 7, 70, 2, 71, 7, 71, 2, 72, 7, 72, 2, 73, 7, 73, 2, 74, 7, 74, 2, 75, 7, 75, 2, 76, 7, 76, 2, 77, 7, 77, 2, 78, 7, 78, 2, 79, 7, 79, 2, 80, 7, 80, 2, 81, 7, 81, 2, 82, 7, 82, 2, 83, 7, 83, 2, 84, 7, 84, 2, 85, 7, 85, 2, 86, 7, 86, 2, 87, 7, 87, 2, 88, 7, 88, 2, 89, 7, 89, 2, 90, 7, 90, 2, 91, 7, 91, 2, 92, 7, 92, 2, 93, 7, 93, 2, 94, 7, 94, 2, 95, 7, 95, 2, 96, 7, 96, 2, 97, 7, 97, 2, 98, 7, 98, 2, 99, 7, 99, 2, 100, 7, 100, 2, 101, 7, 101, 2, 102, 7, 102, 2, 103, 7, 103, 2, 104, 7, 104, 2, 105, 7, 105, 2, 106, 7, 106, 2, 107, 7, 107, 2, 108, 7, 108, 2, 109, 7, 109, 2, 110, 7, 110, 2, 111, 7, 111, 2, 112, 7, 112, 2, 113, 7, 113, 2, 114, 7, 114, 2, 115, 7, 115, 2, 116, 7, 116, 2, 117, 7, 117, 2, 118, 7, 118, 2, 119, 7, 119, 2, 120, 7, 120, 2, 121, 7, 121, 2, 122, 7, 122, 2, 123, 7, 123, 2, 124, 7, 124, 2, 125, 7, 125, 2, 126, 7, 126, 2, 127, 7, 127, 2, 128, 7, 128, 2, 129, 7, 129, 2, 130, 7, 130, 2, 131, 7, 131, 2, 132, 7, 132, 2, 133, 7, 133, 2, 134, 7, 134, 2, 135, 7, 135, 2, 136, 7, 136, 2, 137, 7, 137, 2, 138, 7, 138, 2, 139, 7, 139, 2, 140, 7, 140, 2, 141, 7, 141, 2, 142, 7, 142, 2, 143, 7, 143, 2, 144, 7, 144, 2, 145, 7, 145, 2, 146, 7, 146, 2, 147, 7, 147, 2, 148, 7, 148, 2, 149, 7, 149, 2, 150, 7, 150, 2, 151, 7, 151, 2, 152, 7, 152, 2, 153, 7, 153, 2, 154, 7, 154, 2, 155, 7, 155, 2, 156, 7, 156, 2, 157, 7, 157, 2, 158, 7, 158, 2, 159, 7, 159, 2, 160, 7, 160, 2, 161, 7, 161, 2, 162, 7, 162, 2, 163, 7, 163, 2, 164, 7, 164, 2, 165, 7, 165, 2, 166, 7, 166, 2, 167, 7, 167, 2, 168, 7, 168, 2, 169, 7, 169, 2, 170, 7, 170, 2, 171, 7, 171, 2, 172, 7, 172, 2, 173, 7, 173, 2, 174, 7, 174, 2, 175, 7, 175, 2, 176, 7, 176, 2, 177, 7, 177, 2, 178, 7, 178, 2, 179, 7, 179, 2, 180, 7, 180, 2, 181, 7, 181, 2, 182, 7, 182, 2, 183, 7, 183, 2, 184, 7, 184, 2, 185, 7, 185, 2, 186, 7, 186, 2, 187, 7, 187, 2, 188, 7, 188, 2, 189, 7, 189, 2, 190, 7, 190, 2, 191, 7, 191, 2, 192, 7, 192, 1, 0, 1, 0, 1, 0, 1, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 2, 1, 2, 1, 2, 1, 2, 1, 2, 1, 3, 1, 3, 1, 3, 1, 3, 1, 4, 1, 4, 1, 4, 1, 4, 1, 4, 1, 4, 1, 5, 1, 5, 1, 5, 1, 6, 1, 6, 1, 6, 1, 6, 1, 6, 1, 6, 1, 6, 1, 6, 1, 6, 1, 6, 1, 6, 1, 6, 1, 6, 1, 6, 3, 6, 430, 8, 6, 1, 7, 1, 7, 1, 7, 1, 7, 1, 7, 1, 8, 1, 8, 1, 8, 1, 8, 1, 8, 1, 8, 1, 8, 1, 8, 1, 9, 1, 9, 1, 9, 1, 9, 1, 9, 1, 10, 1, 10, 1, 10, 1, 11, 1, 11, 1, 11, 1, 11, 1, 11, 1, 12, 1, 12, 1, 12, 1, 12, 1, 12, 1, 13, 1, 13, 1, 13, 1, 13, 1, 13, 1, 13, 1, 14, 1, 14, 1, 14, 1, 14, 1, 14, 1, 14, 1, 14, 1, 15, 1, 15, 1, 15, 1, 15, 1, 15, 1, 15, 1, 15, 1, 15, 1, 16, 1, 16, 1, 16, 1, 16, 1, 16, 1, 16, 1, 17, 1, 17, 1, 17, 1, 17, 1, 17, 1, 18, 1, 18, 1, 18, 1, 18, 1, 18, 1, 18, 1, 18, 1, 18, 1, 19, 1, 19, 1, 19, 1, 19, 1, 19, 1, 20, 1, 20, 1, 20, 1, 20, 1, 21, 1, 21, 1, 21, 1, 21, 1, 21, 1, 22, 1, 22, 1, 22, 1, 22, 1, 22, 1, 22, 1, 22, 1, 22, 1, 22, 1, 22, 1, 22, 1, 23, 1, 23, 1, 23, 1, 23, 1, 23, 1, 23, 1, 23, 1, 23, 1, 23, 1, 24, 1, 24, 1, 24, 1, 24, 1, 24, 1, 25, 1, 25, 1, 25, 1, 25, 1, 26, 1, 26, 1, 26, 1, 26, 1, 26, 1, 26, 1, 26, 1, 27, 1, 27, 1, 27, 1, 27, 1, 27, 1, 27, 1, 27, 1, 27, 1, 28, 1, 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, 30, 1, 30, 1, 30, 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, 1, 32, 1, 32, 1, 33, 1, 33, 1, 33, 1, 33, 1, 34, 1, 34, 1, 34, 1, 34, 1, 34, 1, 35, 1, 35, 1, 35, 1, 35, 1, 35, 1, 36, 1, 36, 1, 36, 1, 36, 1, 37, 1, 37, 1, 37, 1, 37, 1, 37, 1, 37, 1, 38, 1, 38, 1, 38, 1, 38, 1, 38, 1, 38, 1, 38, 1, 39, 1, 39, 1, 39, 1, 39, 1, 39, 1, 40, 1, 40, 1, 40, 1, 41, 1, 41, 1, 41, 1, 42, 1, 42, 1, 42, 1, 42, 1, 42, 1, 42, 1, 43, 1, 43, 1, 43, 1, 44, 1, 44, 1, 44, 1, 44, 1, 44, 1, 44, 1, 44, 1, 44, 1, 44, 1, 44, 1, 44, 1, 44, 1, 44, 3, 44, 658, 8, 44, 1, 45, 1, 45, 1, 45, 1, 45, 1, 45, 1, 45, 1, 46, 1, 46, 1, 46, 1, 46, 1, 46, 1, 46, 1, 46, 1, 46, 1, 46, 1, 46, 1, 47, 1, 47, 1, 47, 1, 47, 1, 47, 1, 47, 1, 47, 1, 47, 1, 47, 1, 48, 1, 48, 1, 48, 1, 49, 1, 49, 1, 49, 1, 49, 1, 49, 1, 50, 1, 50, 1, 50, 1, 50, 1, 51, 1, 51, 1, 51, 1, 51, 1, 51, 1, 52, 1, 52, 1, 52, 1, 52, 1, 52, 1, 52, 1, 52, 1, 52, 1, 53, 1, 53, 1, 53, 1, 53, 1, 53, 1, 54, 1, 54, 1, 54, 1, 54, 1, 55, 1, 55, 1, 55, 1, 55, 1, 55, 1, 56, 1, 56, 1, 56, 1, 56, 1, 56, 1, 56, 1, 57, 1, 57, 1, 57, 1, 57, 1, 57, 1, 57, 1, 57, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 58, 1, 59, 1, 59, 1, 59, 1, 59, 1, 60, 1, 60, 1, 60, 1, 60, 1, 61, 1, 61, 1, 61, 1, 61, 1, 61, 1, 62, 1, 62, 1, 62, 1, 62, 1, 62, 1, 62, 1, 63, 1, 63, 1, 63, 1, 63, 1, 63, 1, 63, 1, 63, 1, 64, 1, 64, 1, 64, 1, 65, 1, 65, 1, 65, 1, 66, 1, 66, 1, 66, 1, 66, 1, 66, 1, 66, 1, 67, 1, 67, 1, 67, 1, 67, 1, 67, 1, 67, 1, 68, 1, 68, 1, 68, 1, 68, 1, 68, 1, 69, 1, 69, 1, 69, 1, 69, 1, 69, 1, 69, 1, 69, 1, 69, 1, 69, 1, 69, 1, 70, 1, 70, 1, 70, 1, 70, 1, 70, 1, 70, 1, 70, 1, 70, 1, 70, 1, 70, 1, 71, 1, 71, 1, 71, 1, 71, 1, 71, 1, 71, 1, 71, 1, 71, 1, 71, 1, 72, 1, 72, 1, 72, 1, 72, 1, 72, 1, 72, 1, 72, 1, 72, 1, 73, 1, 73, 1, 73, 1, 73, 1, 73, 1, 73, 1, 74, 1, 74, 1, 74, 1, 74, 1, 74, 1, 74, 1, 74, 1, 75, 1, 75, 1, 75, 1, 75, 1, 75, 1, 75, 1, 76, 1, 76, 1, 76, 1, 76, 1, 76, 1, 76, 1, 76, 1, 77, 1, 77, 1, 77, 1, 77, 1, 78, 1, 78, 1, 78, 1, 78, 1, 78, 1, 79, 1, 79, 1, 79, 1, 79, 1, 79, 1, 79, 1, 79, 1, 80, 1, 80, 1, 80, 1, 80, 1, 80, 1, 80, 1, 80, 1, 81, 1, 81, 1, 81, 1, 81, 1, 81, 1, 81, 1, 81, 1, 82, 1, 82, 1, 82, 1, 82, 1, 82, 1, 83, 1, 83, 1, 83, 1, 83, 1, 83, 1, 83, 1, 83, 1, 83, 1, 83, 1, 84, 1, 84, 1, 84, 1, 84, 1, 84, 1, 84, 1, 84, 1, 84, 1, 84, 1, 84, 1, 85, 1, 85, 1, 85, 1, 85, 1, 85, 1, 86, 1, 86, 1, 86, 1, 86, 1, 86, 1, 86, 1, 87, 1, 87, 1, 87, 1, 87, 1, 87, 1, 88, 1, 88, 1, 88, 1, 88, 1, 88, 1, 88, 1, 88, 1, 88, 1, 88, 1, 88, 1, 89, 1, 89, 1, 89, 1, 90, 1, 90, 1, 90, 1, 90, 1, 91, 1, 91, 1, 91, 1, 91, 1, 91, 1, 91, 1, 91, 1, 92, 1, 92, 1, 92, 1, 92, 1, 92, 1, 92, 1, 92, 1, 92, 1, 92, 1, 93, 1, 93, 1, 93, 1, 93, 1, 93, 1, 94, 1, 94, 1, 94, 1, 94, 1, 94, 1, 94, 1, 94, 1, 94, 1, 94, 1, 95, 1, 95, 1, 95, 1, 95, 1, 96, 1, 96, 1, 96, 1, 96, 1, 96, 1, 96, 1, 96, 1, 96, 1, 96, 1, 96, 1, 97, 1, 97, 1, 97, 1, 97, 1, 97, 1, 97, 1, 98, 1, 98, 1, 98, 1, 98, 1, 98, 1, 98, 1, 99, 1, 99, 1, 99, 1, 99, 1, 99, 1, 100, 1, 100, 1, 100, 1, 100, 1, 100, 1, 101, 1, 101, 1, 101, 1, 101, 1, 101, 1, 101, 1, 102, 1, 102, 1, 102, 1, 102, 1, 102, 1, 102, 1, 103, 1, 103, 1, 103, 1, 103, 1, 103, 1, 103, 1, 103, 1, 104, 1, 104, 1, 104, 1, 104, 1, 104, 1, 105, 1, 105, 1, 105, 1, 105, 1, 105, 1, 105, 1, 105, 1, 105, 1, 105, 1, 105, 3, 105, 1042, 8, 105, 1, 106, 1, 106, 1, 106, 1, 106, 1, 106, 1, 106, 1, 106, 1, 106, 1, 106, 1, 106, 1, 106, 1, 106, 1, 106, 1, 106, 1, 106, 1, 106, 1, 106, 1, 106, 1, 106, 1, 106, 1, 106, 1, 106, 1, 106, 1, 106, 1, 106, 1, 106, 1, 106, 3, 106, 1071, 8, 106, 1, 107, 1, 107, 1, 107, 3, 107, 1076, 8, 107, 1, 107, 1, 107, 1, 107, 1, 107, 5, 107, 1082, 8, 107, 10, 107, 12, 107, 1085, 9, 107, 1, 107, 1, 107, 1, 107, 1, 107, 1, 107, 1, 107, 1, 107, 1, 107, 1, 107, 5, 107, 1096, 8, 107, 10, 107, 12, 107, 1099, 9, 107, 1, 107, 1, 107, 1, 107, 1, 107, 1, 107, 1, 107, 1, 107, 1, 107, 1, 107, 1, 107, 1, 107, 5, 107, 1112, 8, 107, 10, 107, 12, 107, 1115, 9, 107, 1, 107, 1, 107, 3, 107, 1119, 8, 107, 1, 108, 1, 108, 1, 108, 5, 108, 1124, 8, 108, 10, 108, 12, 108, 1127, 9, 108, 1, 108, 1, 108, 3, 108, 1131, 8, 108, 1, 108, 1, 108, 3, 108, 1135, 8, 108, 1, 108, 4, 108, 1138, 8, 108, 11, 108, 12, 108, 1139, 1, 108, 1, 108, 1, 108, 3, 108, 1145, 8, 108, 1, 108, 1, 108, 3, 108, 1149, 8, 108, 1, 108, 4, 108, 1152, 8, 108, 11, 108, 12, 108, 1153, 1, 108, 1, 108, 1, 108, 5, 108, 1159, 8, 108, 10, 108, 12, 108, 1162, 9, 108, 1, 108, 1, 108, 1, 108, 3, 108, 1167, 8, 108, 1, 108, 4, 108, 1170, 8, 108, 11, 108, 12, 108, 1171, 1, 108, 1, 108, 1, 108, 1, 108, 1, 108, 3, 108, 1179, 8, 108, 1, 108, 4, 108, 1182, 8, 108, 11, 108, 12, 108, 1183, 1, 108, 1, 108, 1, 108, 1, 108, 3, 108, 1190, 8, 108, 1, 108, 4, 108, 1193, 8, 108, 11, 108, 12, 108, 1194, 3, 108, 1197, 8, 108, 1, 109, 1, 109, 4, 109, 1201, 8, 109, 11, 109, 12, 109, 1202, 1, 110, 4, 110, 1206, 8, 110, 11, 110, 12, 110, 1207, 1, 111, 1, 111, 1, 111, 4, 111, 1213, 8, 111, 11, 111, 12, 111, 1214, 1, 112, 1, 112, 1, 112, 1, 112, 1, 112, 1, 112, 1, 112, 1, 112, 1, 112, 5, 112, 1226, 8, 112, 10, 112, 12, 112, 1229, 9, 112, 1, 112, 1, 112, 1, 113, 1, 113, 1, 114, 1, 114, 1, 115, 1, 115, 1, 116, 1, 116, 1, 117, 1, 117, 1, 118, 1, 118, 1, 119, 1, 119, 1, 120, 1, 120, 1, 121, 1, 121, 1, 122, 1, 122, 1, 123, 1, 123, 1, 124, 1, 124, 1, 125, 1, 125, 1, 126, 1, 126, 1, 127, 1, 127, 1, 128, 1, 128, 1, 129, 1, 129, 1, 130, 1, 130, 1, 131, 1, 131, 1, 132, 1, 132, 1, 133, 1, 133, 1, 134, 1, 134, 1, 135, 1, 135, 1, 136, 1, 136, 1, 137, 1, 137, 1, 138, 1, 138, 1, 139, 1, 139, 1, 140, 1, 140, 1, 141, 1, 141, 1, 142, 1, 142, 1, 143, 1, 143, 1, 143, 1, 144, 1, 144, 1, 145, 1, 145, 1, 146, 1, 146, 1, 147, 1, 147, 1, 148, 1, 148, 1, 149, 1, 149, 1, 149, 1, 150, 1, 150, 1, 151, 1, 151, 1, 152, 1, 152, 1, 153, 1, 153, 1, 153, 1, 154, 1, 154, 1, 155, 1, 155, 1, 155, 1, 156, 1, 156, 1, 157, 1, 157, 1, 158, 1, 158, 1, 158, 1, 159, 1, 159, 1, 159, 1, 159, 1, 160, 1, 160, 1, 160, 1, 160, 1, 161, 1, 161, 1, 162, 1, 162, 1, 163, 1, 163, 1, 163, 1, 164, 1, 164, 1, 165, 1, 165, 1, 165, 1, 165, 3, 165, 1351, 8, 165, 1, 166, 1, 166, 1, 166, 1, 166, 1, 167, 1, 167, 1, 167, 1, 168, 1, 168, 1, 168, 1, 169, 1, 169, 1, 169, 1, 170, 1, 170, 1, 171, 1, 171, 1, 172, 1, 172, 1, 173, 1, 173, 1, 174, 1, 174, 1, 174, 1, 174, 1, 174, 1, 175, 1, 175, 1, 175, 1, 175, 1, 175, 1, 176, 1, 176, 1, 177, 1, 177, 1, 178, 1, 178, 1, 178, 1, 179, 1, 179, 1, 179, 1, 179, 1, 180, 1, 180, 1, 181, 1, 181, 1, 182, 1, 182, 1, 183, 1, 183, 1, 184, 1, 184, 1, 185, 1, 185, 1, 185, 1, 185, 5, 185, 1409, 8, 185, 10, 185, 12, 185, 1412, 9, 185, 1, 185, 1, 185, 1, 185, 1, 185, 1, 185, 1, 186, 1, 186, 1, 186, 1, 186, 3, 186, 1423, 8, 186, 1, 186, 5, 186, 1426, 8, 186, 10, 186, 12, 186, 1429, 9, 186, 1, 186, 3, 186, 1432, 8, 186, 1, 186, 1, 186, 1, 187, 1, 187, 1, 187, 1, 187, 1, 188, 1, 188, 1, 188, 1, 188, 1, 188, 1, 188, 1, 188, 1, 188, 1, 188, 1, 188, 1, 188, 4, 188, 1451, 8, 188, 11, 188, 12, 188, 1452, 1, 189, 1, 189, 1, 189, 1, 189, 1, 190, 1, 190, 1, 190, 1, 190, 1, 190, 1, 191, 1, 191, 1, 191, 1, 191, 1, 191, 4, 191, 1469, 8, 191, 11, 191, 12, 191, 1470, 1, 192, 1, 192, 1, 192, 1, 192, 1, 1410, 0, 193, 3, 1, 5, 2, 7, 3, 9, 4, 11, 5, 13, 6, 15, 7, 17, 8, 19, 9, 21, 10, 23, 11, 25, 12, 27, 13, 29, 14, 31, 15, 33, 16, 35, 17, 37, 18, 39, 19, 41, 20, 43, 21, 45, 22, 47, 23, 49, 24, 51, 25, 53, 26, 55, 27, 57, 28, 59, 29, 61, 30, 63, 31, 65, 32, 67, 33, 69, 34, 71, 35, 73, 36, 75, 37, 77, 38, 79, 39, 81, 40, 83, 41, 85, 42, 87, 43, 89, 44, 91, 45, 93, 46, 95, 47, 97, 48, 99, 49, 101, 50, 103, 51, 105, 52, 107, 53, 109, 54, 111, 55, 113, 56, 115, 57, 117, 58, 119, 59, 121, 60, 123, 61, 125, 62, 127, 63, 129, 64, 131, 65, 133, 66, 135, 67, 137, 68, 139, 69, 141, 70, 143, 71, 145, 72, 147, 73, 149, 74, 151, 75, 153, 76, 155, 77, 157, 78, 159, 79, 161, 80, 163, 81, 165, 82, 167, 83, 169, 84, 171, 85, 173, 86, 175, 87, 177, 88, 179, 89, 181, 90, 183, 91, 185, 92, 187, 93, 189, 94, 191, 95, 193, 96, 195, 97, 197, 98, 199, 99, 201, 100, 203, 101, 205, 102, 207, 103, 209, 104, 211, 105, 213, 106, 215, 107, 217, 108, 219, 109, 221, 110, 223, 111, 225, 112, 227, 113, 229, 0, 231, 0, 233, 0, 235, 0, 237, 0, 239, 0, 241, 0, 243, 0, 245, 0, 247, 0, 249, 0, 251, 0, 253, 0, 255, 0, 257, 0, 259, 0, 261, 0, 263, 0, 265, 0, 267, 0, 269, 0, 271, 0, 273, 0, 275, 0, 277, 0, 279, 0, 281, 0, 283, 0, 285, 0, 287, 0, 289, 114, 291, 115, 293, 116, 295, 117, 297, 118, 299, 119, 301, 120, 303, 121, 305, 122, 307, 123, 309, 124, 311, 125, 313, 126, 315, 127, 317, 128, 319, 129, 321, 130, 323, 131, 325, 132, 327, 133, 329, 134, 331, 135, 333, 136, 335, 137, 337, 138, 339, 139, 341, 140, 343, 141, 345, 142, 347, 143, 349, 144, 351, 145, 353, 146, 355, 147, 357, 148, 359, 149, 361, 150, 363, 151, 365, 152, 367, 153, 369, 154, 371, 155, 373, 156, 375, 157, 377, 158, 379, 159, 381, 160, 383, 0, 385, 161, 387, 162, 3, 0, 1, 2, 38, 2, 0, 92, 92, 96, 96, 2, 0, 34, 34, 92, 92, 2, 0, 39, 39, 92, 92, 2, 0, 65, 65, 97, 97, 2, 0, 66, 66, 98, 98, 2, 0, 67, 67, 99, 99, 2, 0, 68, 68, 100, 100, 2, 0, 69, 69, 101, 101, 2, 0, 70, 70, 102, 102, 2, 0, 71, 71, 103, 103, 2, 0, 72, 72, 104, 104, 2, 0, 73, 73, 105, 105, 2, 0, 74, 74, 106, 106, 2, 0, 75, 75, 107, 107, 2, 0, 76, 76, 108, 108, 2, 0, 77, 77, 109, 109, 2, 0, 78, 78, 110, 110, 2, 0, 79, 79, 111, 111, 2, 0, 80, 80, 112, 112, 2, 0, 81, 81, 113, 113, 2, 0, 82, 82, 114, 114, 2, 0, 83, 83, 115, 115, 2, 0, 84, 84, 116, 116, 2, 0, 85, 85, 117, 117, 2, 0, 86, 86, 118, 118, 2, 0, 87, 87, 119, 119, 2, 0, 88, 88, 120, 120, 2, 0, 89, 89, 121, 121, 2, 0, 90, 90, 122, 122, 2, 0, 65, 90, 97, 122, 1, 0, 48, 55, 1, 0, 48, 57, 3, 0, 48, 57, 65, 70, 97, 102, 2, 0, 10, 10, 13, 13, 2, 1, 10, 10, 13, 13, 2, 0, 9, 13, 32, 32, 3, 0, 39, 39, 92, 92, 123, 123, 1, 0, 123, 123, 1512, 0, 3, 1, 0, 0, 0, 0, 5, 1, 0, 0, 0, 0, 7, 1, 0, 0, 0, 0, 9, 1, 0, 0, 0, 0, 11, 1, 0, 0, 0, 0, 13, 1, 0, 0, 0, 0, 15, 1, 0, 0, 0, 0, 17, 1, 0, 0, 0, 0, 19, 1, 0, 0, 0, 0, 21, 1, 0, 0, 0, 0, 23, 1, 0, 0, 0, 0, 25, 1, 0, 0, 0, 0, 27, 1, 0, 0, 0, 0, 29, 1, 0, 0, 0, 0, 31, 1, 0, 0, 0, 0, 33, 1, 0, 0, 0, 0, 35, 1, 0, 0, 0, 0, 37, 1, 0, 0, 0, 0, 39, 1, 0, 0, 0, 0, 41, 1, 0, 0, 0, 0, 43, 1, 0, 0, 0, 0, 45, 1, 0, 0, 0, 0, 47, 1, 0, 0, 0, 0, 49, 1, 0, 0, 0, 0, 51, 1, 0, 0, 0, 0, 53, 1, 0, 0, 0, 0, 55, 1, 0, 0, 0, 0, 57, 1, 0, 0, 0, 0, 59, 1, 0, 0, 0, 0, 61, 1, 0, 0, 0, 0, 63, 1, 0, 0, 0, 0, 65, 1, 0, 0, 0, 0, 67, 1, 0, 0, 0, 0, 69, 1, 0, 0, 0, 0, 71, 1, 0, 0, 0, 0, 73, 1, 0, 0, 0, 0, 75, 1, 0, 0, 0, 0, 77, 1, 0, 0, 0, 0, 79, 1, 0, 0, 0, 0, 81, 1, 0, 0, 0, 0, 83, 1, 0, 0, 0, 0, 85, 1, 0, 0, 0, 0, 87, 1, 0, 0, 0, 0, 89, 1, 0, 0, 0, 0, 91, 1, 0, 0, 0, 0, 93, 1, 0, 0, 0, 0, 95, 1, 0, 0, 0, 0, 97, 1, 0, 0, 0, 0, 99, 1, 0, 0, 0, 0, 101, 1, 0, 0, 0, 0, 103, 1, 0, 0, 0, 0, 105, 1, 0, 0, 0, 0, 107, 1, 0, 0, 0, 0, 109, 1, 0, 0, 0, 0, 111, 1, 0, 0, 0, 0, 113, 1, 0, 0, 0, 0, 115, 1, 0, 0, 0, 0, 117, 1, 0, 0, 0, 0, 119, 1, 0, 0, 0, 0, 121, 1, 0, 0, 0, 0, 123, 1, 0, 0, 0, 0, 125, 1, 0, 0, 0, 0, 127, 1, 0, 0, 0, 0, 129, 1, 0, 0, 0, 0, 131, 1, 0, 0, 0, 0, 133, 1, 0, 0, 0, 0, 135, 1, 0, 0, 0, 0, 137, 1, 0, 0, 0, 0, 139, 1, 0, 0, 0, 0, 141, 1, 0, 0, 0, 0, 143, 1, 0, 0, 0, 0, 145, 1, 0, 0, 0, 0, 147, 1, 0, 0, 0, 0, 149, 1, 0, 0, 0, 0, 151, 1, 0, 0, 0, 0, 153, 1, 0, 0, 0, 0, 155, 1, 0, 0, 0, 0, 157, 1, 0, 0, 0, 0, 159, 1, 0, 0, 0, 0, 161, 1, 0, 0, 0, 0, 163, 1, 0, 0, 0, 0, 165, 1, 0, 0, 0, 0, 167, 1, 0, 0, 0, 0, 169, 1, 0, 0, 0, 0, 171, 1, 0, 0, 0, 0, 173, 1, 0, 0, 0, 0, 175, 1, 0, 0, 0, 0, 177, 1, 0, 0, 0, 0, 179, 1, 0, 0, 0, 0, 181, 1, 0, 0, 0, 0, 183, 1, 0, 0, 0, 0, 185, 1, 0, 0, 0, 0, 187, 1, 0, 0, 0, 0, 189, 1, 0, 0, 0, 0, 191, 1, 0, 0, 0, 0, 193, 1, 0, 0, 0, 0, 195, 1, 0, 0, 0, 0, 197, 1, 0, 0, 0, 0, 199, 1, 0, 0, 0, 0, 201, 1, 0, 0, 0, 0, 203, 1, 0, 0, 0, 0, 205, 1, 0, 0, 0, 0, 207, 1, 0, 0, 0, 0, 209, 1, 0, 0, 0, 0, 211, 1, 0, 0, 0, 0, 213, 1, 0, 0, 0, 0, 215, 1, 0, 0, 0, 0, 217, 1, 0, 0, 0, 0, 219, 1, 0, 0, 0, 0, 221, 1, 0, 0, 0, 0, 223, 1, 0, 0, 0, 0, 225, 1, 0, 0, 0, 0, 227, 1, 0, 0, 0, 0, 289, 1, 0, 0, 0, 0, 291, 1, 0, 0, 0, 0, 293, 1, 0, 0, 0, 0, 295, 1, 0, 0, 0, 0, 297, 1, 0, 0, 0, 0, 299, 1, 0, 0, 0, 0, 301, 1, 0, 0, 0, 0, 303, 1, 0, 0, 0, 0, 305, 1, 0, 0, 0, 0, 307, 1, 0, 0, 0, 0, 309, 1, 0, 0, 0, 0, 311, 1, 0, 0, 0, 0, 313, 1, 0, 0, 0, 0, 315, 1, 0, 0, 0, 0, 317, 1, 0, 0, 0, 0, 319, 1, 0, 0, 0, 0, 321, 1, 0, 0, 0, 0, 323, 1, 0, 0, 0, 0, 325, 1, 0, 0, 0, 0, 327, 1, 0, 0, 0, 0, 329, 1, 0, 0, 0, 0, 331, 1, 0, 0, 0, 0, 333, 1, 0, 0, 0, 0, 335, 1, 0, 0, 0, 0, 337, 1, 0, 0, 0, 0, 339, 1, 0, 0, 0, 0, 341, 1, 0, 0, 0, 0, 343, 1, 0, 0, 0, 0, 345, 1, 0, 0, 0, 0, 347, 1, 0, 0, 0, 0, 349, 1, 0, 0, 0, 0, 351, 1, 0, 0, 0, 0, 353, 1, 0, 0, 0, 0, 355, 1, 0, 0, 0, 0, 357, 1, 0, 0, 0, 0, 359, 1, 0, 0, 0, 0, 361, 1, 0, 0, 0, 0, 363, 1, 0, 0, 0, 0, 365, 1, 0, 0, 0, 0, 367, 1, 0, 0, 0, 0, 369, 1, 0, 0, 0, 0, 371, 1, 0, 0, 0, 0, 373, 1, 0, 0, 0, 0, 375, 1, 0, 0, 0, 0, 377, 1, 0, 0, 0, 1, 379, 1, 0, 0, 0, 1, 381, 1, 0, 0, 0, 1, 383, 1, 0, 0, 0, 2, 385, 1, 0, 0, 0, 2, 387, 1, 0, 0, 0, 3, 389, 1, 0, 0, 0, 5, 393, 1, 0, 0, 0, 7, 397, 1, 0, 0, 0, 9, 402, 1, 0, 0, 0, 11, 406, 1, 0, 0, 0, 13, 412, 1, 0, 0, 0, 15, 429, 1, 0, 0, 0, 17, 431, 1, 0, 0, 0, 19, 436, 1, 0, 0, 0, 21, 444, 1, 0, 0, 0, 23, 449, 1, 0, 0, 0, 25, 452, 1, 0, 0, 0, 27, 457, 1, 0, 0, 0, 29, 462, 1, 0, 0, 0, 31, 468, 1, 0, 0, 0, 33, 475, 1, 0, 0, 0, 35, 483, 1, 0, 0, 0, 37, 489, 1, 0, 0, 0, 39, 494, 1, 0, 0, 0, 41, 502, 1, 0, 0, 0, 43, 507, 1, 0, 0, 0, 45, 511, 1, 0, 0, 0, 47, 516, 1, 0, 0, 0, 49, 527, 1, 0, 0, 0, 51, 536, 1, 0, 0, 0, 53, 541, 1, 0, 0, 0, 55, 545, 1, 0, 0, 0, 57, 552, 1, 0, 0, 0, 59, 560, 1, 0, 0, 0, 61, 566, 1, 0, 0, 0, 63, 574, 1, 0, 0, 0, 65, 580, 1, 0, 0, 0, 67, 583, 1, 0, 0, 0, 69, 593, 1, 0, 0, 0, 71, 597, 1, 0, 0, 0, 73, 602, 1, 0, 0, 0, 75, 607, 1, 0, 0, 0, 77, 611, 1, 0, 0, 0, 79, 617, 1, 0, 0, 0, 81, 624, 1, 0, 0, 0, 83, 629, 1, 0, 0, 0, 85, 632, 1, 0, 0, 0, 87, 635, 1, 0, 0, 0, 89, 641, 1, 0, 0, 0, 91, 657, 1, 0, 0, 0, 93, 659, 1, 0, 0, 0, 95, 665, 1, 0, 0, 0, 97, 675, 1, 0, 0, 0, 99, 684, 1, 0, 0, 0, 101, 687, 1, 0, 0, 0, 103, 692, 1, 0, 0, 0, 105, 696, 1, 0, 0, 0, 107, 701, 1, 0, 0, 0, 109, 709, 1, 0, 0, 0, 111, 714, 1, 0, 0, 0, 113, 718, 1, 0, 0, 0, 115, 723, 1, 0, 0, 0, 117, 729, 1, 0, 0, 0, 119, 736, 1, 0, 0, 0, 121, 742, 1, 0, 0, 0, 123, 746, 1, 0, 0, 0, 125, 750, 1, 0, 0, 0, 127, 755, 1, 0, 0, 0, 129, 761, 1, 0, 0, 0, 131, 768, 1, 0, 0, 0, 133, 771, 1, 0, 0, 0, 135, 774, 1, 0, 0, 0, 137, 780, 1, 0, 0, 0, 139, 786, 1, 0, 0, 0, 141, 791, 1, 0, 0, 0, 143, 801, 1, 0, 0, 0, 145, 811, 1, 0, 0, 0, 147, 820, 1, 0, 0, 0, 149, 828, 1, 0, 0, 0, 151, 834, 1, 0, 0, 0, 153, 841, 1, 0, 0, 0, 155, 847, 1, 0, 0, 0, 157, 854, 1, 0, 0, 0, 159, 858, 1, 0, 0, 0, 161, 863, 1, 0, 0, 0, 163, 870, 1, 0, 0, 0, 165, 877, 1, 0, 0, 0, 167, 884, 1, 0, 0, 0, 169, 889, 1, 0, 0, 0, 171, 898, 1, 0, 0, 0, 173, 908, 1, 0, 0, 0, 175, 913, 1, 0, 0, 0, 177, 919, 1, 0, 0, 0, 179, 924, 1, 0, 0, 0, 181, 934, 1, 0, 0, 0, 183, 937, 1, 0, 0, 0, 185, 941, 1, 0, 0, 0, 187, 948, 1, 0, 0, 0, 189, 957, 1, 0, 0, 0, 191, 962, 1, 0, 0, 0, 193, 971, 1, 0, 0, 0, 195, 975, 1, 0, 0, 0, 197, 985, 1, 0, 0, 0, 199, 991, 1, 0, 0, 0, 201, 997, 1, 0, 0, 0, 203, 1002, 1, 0, 0, 0, 205, 1007, 1, 0, 0, 0, 207, 1013, 1, 0, 0, 0, 209, 1019, 1, 0, 0, 0, 211, 1026, 1, 0, 0, 0, 213, 1041, 1, 0, 0, 0, 215, 1070, 1, 0, 0, 0, 217, 1118, 1, 0, 0, 0, 219, 1196, 1, 0, 0, 0, 221, 1198, 1, 0, 0, 0, 223, 1205, 1, 0, 0, 0, 225, 1209, 1, 0, 0, 0, 227, 1216, 1, 0, 0, 0, 229, 1232, 1, 0, 0, 0, 231, 1234, 1, 0, 0, 0, 233, 1236, 1, 0, 0, 0, 235, 1238, 1, 0, 0, 0, 237, 1240, 1, 0, 0, 0, 239, 1242, 1, 0, 0, 0, 241, 1244, 1, 0, 0, 0, 243, 1246, 1, 0, 0, 0, 245, 1248, 1, 0, 0, 0, 247, 1250, 1, 0, 0, 0, 249, 1252, 1, 0, 0, 0, 251, 1254, 1, 0, 0, 0, 253, 1256, 1, 0, 0, 0, 255, 1258, 1, 0, 0, 0, 257, 1260, 1, 0, 0, 0, 259, 1262, 1, 0, 0, 0, 261, 1264, 1, 0, 0, 0, 263, 1266, 1, 0, 0, 0, 265, 1268, 1, 0, 0, 0, 267, 1270, 1, 0, 0, 0, 269, 1272, 1, 0, 0, 0, 271, 1274, 1, 0, 0, 0, 273, 1276, 1, 0, 0, 0, 275, 1278, 1, 0, 0, 0, 277, 1280, 1, 0, 0, 0, 279, 1282, 1, 0, 0, 0, 281, 1284, 1, 0, 0, 0, 283, 1286, 1, 0, 0, 0, 285, 1288, 1, 0, 0, 0, 287, 1290, 1, 0, 0, 0, 289, 1292, 1, 0, 0, 0, 291, 1295, 1, 0, 0, 0, 293, 1297, 1, 0, 0, 0, 295, 1299, 1, 0, 0, 0, 297, 1301, 1, 0, 0, 0, 299, 1303, 1, 0, 0, 0, 301, 1305, 1, 0, 0, 0, 303, 1308, 1, 0, 0, 0, 305, 1310, 1, 0, 0, 0, 307, 1312, 1, 0, 0, 0, 309, 1314, 1, 0, 0, 0, 311, 1317, 1, 0, 0, 0, 313, 1319, 1, 0, 0, 0, 315, 1322, 1, 0, 0, 0, 317, 1324, 1, 0, 0, 0, 319, 1326, 1, 0, 0, 0, 321, 1329, 1, 0, 0, 0, 323, 1333, 1, 0, 0, 0, 325, 1337, 1, 0, 0, 0, 327, 1339, 1, 0, 0, 0, 329, 1341, 1, 0, 0, 0, 331, 1344, 1, 0, 0, 0, 333, 1350, 1, 0, 0, 0, 335, 1352, 1, 0, 0, 0, 337, 1356, 1, 0, 0, 0, 339, 1359, 1, 0, 0, 0, 341, 1362, 1, 0, 0, 0, 343, 1365, 1, 0, 0, 0, 345, 1367, 1, 0, 0, 0, 347, 1369, 1, 0, 0, 0, 349, 1371, 1, 0, 0, 0, 351, 1373, 1, 0, 0, 0, 353, 1378, 1, 0, 0, 0, 355, 1383, 1, 0, 0, 0, 357, 1385, 1, 0, 0, 0, 359, 1387, 1, 0, 0, 0, 361, 1390, 1, 0, 0, 0, 363, 1394, 1, 0, 0, 0, 365, 1396, 1, 0, 0, 0, 367, 1398, 1, 0, 0, 0, 369, 1400, 1, 0, 0, 0, 371, 1402, 1, 0, 0, 0, 373, 1404, 1, 0, 0, 0, 375, 1422, 1, 0, 0, 0, 377, 1435, 1, 0, 0, 0, 379, 1450, 1, 0, 0, 0, 381, 1454, 1, 0, 0, 0, 383, 1458, 1, 0, 0, 0, 385, 1468, 1, 0, 0, 0, 387, 1472, 1, 0, 0, 0, 389, 390, 3, 229, 113, 0, 390, 391, 3, 251, 124, 0, 391, 392, 3, 251, 124, 0, 392, 4, 1, 0, 0, 0, 393, 394, 3, 229, 113, 0, 394, 395, 3, 255, 126, 0, 395, 396, 3, 235, 116, 0, 396, 6, 1, 0, 0, 0, 397, 398, 3, 229, 113, 0, 398, 399, 3, 255, 126, 0, 399, 400, 3, 267, 132, 0, 400, 401, 3, 245, 121, 0, 401, 8, 1, 0, 0, 0, 402, 403, 3, 229, 113, 0, 403, 404, 3, 255, 126, 0, 404, 405, 3, 277, 137, 0, 405, 10, 1, 0, 0, 0, 406, 407, 3, 229, 113, 0, 407, 408, 3, 263, 130, 0, 408, 409, 3, 263, 130, 0, 409, 410, 3, 229, 113, 0, 410, 411, 3, 277, 137, 0, 411, 12, 1, 0, 0, 0, 412, 413, 3, 229, 113, 0, 413, 414, 3, 265, 131, 0, 414, 14, 1, 0, 0, 0, 415, 416, 3, 229, 113, 0, 416, 417, 3, 265, 131, 0, 417, 418, 3, 233, 115, 0, 418, 430, 1, 0, 0, 0, 419, 420, 3, 229, 113, 0, 420, 421, 3, 265, 131, 0, 421, 422, 3, 233, 115, 0, 422, 423, 3, 237, 117, 0, 423, 424, 3, 255, 126, 0, 424, 425, 3, 235, 116, 0, 425, 426, 3, 245, 121, 0, 426, 427, 3, 255, 126, 0, 427, 428, 3, 241, 119, 0, 428, 430, 1, 0, 0, 0, 429, 415, 1, 0, 0, 0, 429, 419, 1, 0, 0, 0, 430, 16, 1, 0, 0, 0, 431, 432, 3, 229, 113, 0, 432, 433, 3, 265, 131, 0, 433, 434, 3, 257, 127, 0, 434, 435, 3, 239, 118, 0, 435, 18, 1, 0, 0, 0, 436, 437, 3, 231, 114, 0, 437, 438, 3, 237, 117, 0, 438, 439, 3, 267, 132, 0, 439, 440, 3, 273, 135, 0, 440, 441, 3, 237, 117, 0, 441, 442, 3, 237, 117, 0, 442, 443, 3, 255, 126, 0, 443, 20, 1, 0, 0, 0, 444, 445, 3, 231, 114, 0, 445, 446, 3, 257, 127, 0, 446, 447, 3, 267, 132, 0, 447, 448, 3, 243, 120, 0, 448, 22, 1, 0, 0, 0, 449, 450, 3, 231, 114, 0, 450, 451, 3, 277, 137, 0, 451, 24, 1, 0, 0, 0, 452, 453, 3, 233, 115, 0, 453, 454, 3, 229, 113, 0, 454, 455, 3, 265, 131, 0, 455, 456, 3, 237, 117, 0, 456, 26, 1, 0, 0, 0, 457, 458, 3, 233, 115, 0, 458, 459, 3, 229, 113, 0, 459, 460, 3, 265, 131, 0, 460, 461, 3, 267, 132, 0, 461, 28, 1, 0, 0, 0, 462, 463, 3, 233, 115, 0, 463, 464, 3, 229, 113, 0, 464, 465, 3, 267, 132, 0, 465, 466, 3, 233, 115, 0, 466, 467, 3, 243, 120, 0, 467, 30, 1, 0, 0, 0, 468, 469, 3, 233, 115, 0, 469, 470, 3, 257, 127, 0, 470, 471, 3, 243, 120, 0, 471, 472, 3, 257, 127, 0, 472, 473, 3, 263, 130, 0, 473, 474, 3, 267, 132, 0, 474, 32, 1, 0, 0, 0, 475, 476, 3, 233, 115, 0, 476, 477, 3, 257, 127, 0, 477, 478, 3, 251, 124, 0, 478, 479, 3, 251, 124, 0, 479, 480, 3, 229, 113, 0, 480, 481, 3, 267, 132, 0, 481, 482, 3, 237, 117, 0, 482, 34, 1, 0, 0, 0, 483, 484, 3, 233, 115, 0, 484, 485, 3, 263, 130, 0, 485, 486, 3, 257, 127, 0, 486, 487, 3, 265, 131, 0, 487, 488, 3, 265, 131, 0, 488, 36, 1, 0, 0, 0, 489, 490, 3, 233, 115, 0, 490, 491, 3, 269, 133, 0, 491, 492, 3, 231, 114, 0, 492, 493, 3, 237, 117, 0, 493, 38, 1, 0, 0, 0, 494, 495, 3, 233, 115, 0, 495, 496, 3, 269, 133, 0, 496, 497, 3, 263, 130, 0, 497, 498, 3, 263, 130, 0, 498, 499, 3, 237, 117, 0, 499, 500, 3, 255, 126, 0, 500, 501, 3, 267, 132, 0, 501, 40, 1, 0, 0, 0, 502, 503, 3, 235, 116, 0, 503, 504, 3, 229, 113, 0, 504, 505, 3, 267, 132, 0, 505, 506, 3, 237, 117, 0, 506, 42, 1, 0, 0, 0, 507, 508, 3, 235, 116, 0, 508, 509, 3, 229, 113, 0, 509, 510, 3, 277, 137, 0, 510, 44, 1, 0, 0, 0, 511, 512, 3, 235, 116, 0, 512, 513, 3, 237, 117, 0, 513, 514, 3, 265, 131, 0, 514, 515, 3, 233, 115, 0, 515, 46, 1, 0, 0, 0, 516, 517, 3, 235, 116, 0, 517, 518, 3, 237, 117, 0, 518, 519, 3, 265, 131, 0, 519, 520, 3, 233, 115, 0, 520, 521, 3, 237, 117, 0, 521, 522, 3, 255, 126, 0, 522, 523, 3, 235, 116, 0, 523, 524, 3, 245, 121, 0, 524, 525, 3, 255, 126, 0, 525, 526, 3, 241, 119, 0, 526, 48, 1, 0, 0, 0, 527, 528, 3, 235, 116, 0, 528, 529, 3, 245, 121, 0, 529, 530, 3, 265, 131, 0, 530, 531, 3, 267, 132, 0, 531, 532, 3, 245, 121, 0, 532, 533, 3, 255, 126, 0, 533, 534, 3, 233, 115, 0, 534, 535, 3, 267, 132, 0, 535, 50, 1, 0, 0, 0, 536, 537, 3, 237, 117, 0, 537, 538, 3, 251, 124, 0, 538, 539, 3, 265, 131, 0, 539, 540, 3, 237, 117, 0, 540, 52, 1, 0, 0, 0, 541, 542, 3, 237, 117, 0, 542, 543, 3, 255, 126, 0, 543, 544, 3, 235, 116, 0, 544, 54, 1, 0, 0, 0, 545, 546, 3, 237, 117, 0, 546, 547, 3, 275, 136, 0, 547, 548, 3, 233, 115, 0, 548, 549, 3, 237, 117, 0, 549, 550, 3, 259, 128, 0, 550, 551, 3, 267, 132, 0, 551, 56, 1, 0, 0, 0, 552, 553, 3, 237, 117, 0, 553, 554, 3, 275, 136, 0, 554, 555, 3, 267, 132, 0, 555, 556, 3, 263, 130, 0, 556, 557, 3, 229, 113, 0, 557, 558, 3, 233, 115, 0, 558, 559, 3, 267, 132, 0, 559, 58, 1, 0, 0, 0, 560, 561, 3, 239, 118, 0, 561, 562, 3, 245, 121, 0, 562, 563, 3, 255, 126, 0, 563, 564, 3, 229, 113, 0, 564, 565, 3, 251, 124, 0, 565, 60, 1, 0, 0, 0, 566, 567, 3, 239, 118, 0, 567, 568, 3, 245, 121, 0, 568, 569, 3, 255, 126, 0, 569, 570, 3, 229, 113, 0, 570, 571, 3, 251, 124, 0, 571, 572, 3, 251, 124, 0, 572, 573, 3, 277, 137, 0, 573, 62, 1, 0, 0, 0, 574, 575, 3, 239, 118, 0, 575, 576, 3, 245, 121, 0, 576, 577, 3, 263, 130, 0, 577, 578, 3, 265, 131, 0, 578, 579, 3, 267, 132, 0, 579, 64, 1, 0, 0, 0, 580, 581, 3, 239, 118, 0, 581, 582, 3, 255, 126, 0, 582, 66, 1, 0, 0, 0, 583, 584, 3, 239, 118, 0, 584, 585, 3, 257, 127, 0, 585, 586, 3, 251, 124, 0, 586, 587, 3, 251, 124, 0, 587, 588, 3, 257, 127, 0, 588, 589, 3, 273, 135, 0, 589, 590, 3, 245, 121, 0, 590, 591, 3, 255, 126, 0, 591, 592, 3, 241, 119, 0, 592, 68, 1, 0, 0, 0, 593, 594, 3, 239, 118, 0, 594, 595, 3, 257, 127, 0, 595, 596, 3, 263, 130, 0, 596, 70, 1, 0, 0, 0, 597, 598, 3, 239, 118, 0, 598, 599, 3, 263, 130, 0, 599, 600, 3, 257, 127, 0, 600, 601, 3, 253, 125, 0, 601, 72, 1, 0, 0, 0, 602, 603, 3, 239, 118, 0, 603, 604, 3, 269, 133, 0, 604, 605, 3, 251, 124, 0, 605, 606, 3, 251, 124, 0, 606, 74, 1, 0, 0, 0, 607, 608, 3, 239, 118, 0, 608, 609, 3, 269, 133, 0, 609, 610, 3, 255, 126, 0, 610, 76, 1, 0, 0, 0, 611, 612, 3, 241, 119, 0, 612, 613, 3, 263, 130, 0, 613, 614, 3, 257, 127, 0, 614, 615, 3, 269, 133, 0, 615, 616, 3, 259, 128, 0, 616, 78, 1, 0, 0, 0, 617, 618, 3, 243, 120, 0, 618, 619, 3, 229, 113, 0, 619, 620, 3, 271, 134, 0, 620, 621, 3, 245, 121, 0, 621, 622, 3, 255, 126, 0, 622, 623, 3, 241, 119, 0, 623, 80, 1, 0, 0, 0, 624, 625, 3, 243, 120, 0, 625, 626, 3, 257, 127, 0, 626, 627, 3, 269, 133, 0, 627, 628, 3, 263, 130, 0, 628, 82, 1, 0, 0, 0, 629, 630, 3, 245, 121, 0, 630, 631, 3, 235, 116, 0, 631, 84, 1, 0, 0, 0, 632, 633, 3, 245, 121, 0, 633, 634, 3, 239, 118, 0, 634, 86, 1, 0, 0, 0, 635, 636, 3, 245, 121, 0, 636, 637, 3, 251, 124, 0, 637, 638, 3, 245, 121, 0, 638, 639, 3, 249, 123, 0, 639, 640, 3, 237, 117, 0, 640, 88, 1, 0, 0, 0, 641, 642, 3, 245, 121, 0, 642, 643, 3, 255, 126, 0, 643, 90, 1, 0, 0, 0, 644, 645, 3, 245, 121, 0, 645, 646, 3, 255, 126, 0, 646, 647, 3, 239, 118, 0, 647, 658, 1, 0, 0, 0, 648, 649, 3, 245, 121, 0, 649, 650, 3, 255, 126, 0, 650, 651, 3, 239, 118, 0, 651, 652, 3, 245, 121, 0, 652, 653, 3, 255, 126, 0, 653, 654, 3, 245, 121, 0, 654, 655, 3, 267, 132, 0, 655, 656, 3, 277, 137, 0, 656, 658, 1, 0, 0, 0, 657, 644, 1, 0, 0, 0, 657, 648, 1, 0, 0, 0, 658, 92, 1, 0, 0, 0, 659, 660, 3, 245, 121, 0, 660, 661, 3, 255, 126, 0, 661, 662, 3, 255, 126, 0, 662, 663, 3, 237, 117, 0, 663, 664, 3, 263, 130, 0, 664, 94, 1, 0, 0, 0, 665, 666, 3, 245, 121, 0, 666, 667, 3, 255, 126, 0, 667, 668, 3, 267, 132, 0, 668, 669, 3, 237, 117, 0, 669, 670, 3, 263, 130, 0, 670, 671, 3, 265, 131, 0, 671, 672, 3, 237, 117, 0, 672, 673, 3, 233, 115, 0, 673, 674, 3, 267, 132, 0, 674, 96, 1, 0, 0, 0, 675, 676, 3, 245, 121, 0, 676, 677, 3, 255, 126, 0, 677, 678, 3, 267, 132, 0, 678, 679, 3, 237, 117, 0, 679, 680, 3, 263, 130, 0, 680, 681, 3, 271, 134, 0, 681, 682, 3, 229, 113, 0, 682, 683, 3, 251, 124, 0, 683, 98, 1, 0, 0, 0, 684, 685, 3, 245, 121, 0, 685, 686, 3, 265, 131, 0, 686, 100, 1, 0, 0, 0, 687, 688, 3, 247, 122, 0, 688, 689, 3, 257, 127, 0, 689, 690, 3, 245, 121, 0, 690, 691, 3, 255, 126, 0, 691, 102, 1, 0, 0, 0, 692, 693, 3, 249, 123, 0, 693, 694, 3, 237, 117, 0, 694, 695, 3, 277, 137, 0, 695, 104, 1, 0, 0, 0, 696, 697, 3, 251, 124, 0, 697, 698, 3, 229, 113, 0, 698, 699, 3, 265, 131, 0, 699, 700, 3, 267, 132, 0, 700, 106, 1, 0, 0, 0, 701, 702, 3, 251, 124, 0, 702, 703, 3, 237, 117, 0, 703, 704, 3, 229, 113, 0, 704, 705, 3, 235, 116, 0, 705, 706, 3, 245, 121, 0, 706, 707, 3, 255, 126, 0, 707, 708, 3, 241, 119, 0, 708, 108, 1, 0, 0, 0, 709, 710, 3, 251, 124, 0, 710, 711, 3, 237, 117, 0, 711, 712, 3, 239, 118, 0, 712, 713, 3, 267, 132, 0, 713, 110, 1, 0, 0, 0, 714, 715, 3, 251, 124, 0, 715, 716, 3, 237, 117, 0, 716, 717, 3, 267, 132, 0, 717, 112, 1, 0, 0, 0, 718, 719, 3, 251, 124, 0, 719, 720, 3, 245, 121, 0, 720, 721, 3, 249, 123, 0, 721, 722, 3, 237, 117, 0, 722, 114, 1, 0, 0, 0, 723, 724, 3, 251, 124, 0, 724, 725, 3, 245, 121, 0, 725, 726, 3, 253, 125, 0, 726, 727, 3, 245, 121, 0, 727, 728, 3, 267, 132, 0, 728, 116, 1, 0, 0, 0, 729, 730, 3, 253, 125, 0, 730, 731, 3, 245, 121, 0, 731, 732, 3, 255, 126, 0, 732, 733, 3, 269, 133, 0, 733, 734, 3, 267, 132, 0, 734, 735, 3, 237, 117, 0, 735, 118, 1, 0, 0, 0, 736, 737, 3, 253, 125, 0, 737, 738, 3, 257, 127, 0, 738, 739, 3, 255, 126, 0, 739, 740, 3, 267, 132, 0, 740, 741, 3, 243, 120, 0, 741, 120, 1, 0, 0, 0, 742, 743, 3, 255, 126, 0, 743, 744, 3, 229, 113, 0, 744, 745, 3, 255, 126, 0, 745, 122, 1, 0, 0, 0, 746, 747, 3, 255, 126, 0, 747, 748, 3, 257, 127, 0, 748, 749, 3, 267, 132, 0, 749, 124, 1, 0, 0, 0, 750, 751, 3, 255, 126, 0, 751, 752, 3, 269, 133, 0, 752, 753, 3, 251, 124, 0, 753, 754, 3, 251, 124, 0, 754, 126, 1, 0, 0, 0, 755, 756, 3, 255, 126, 0, 756, 757, 3, 269, 133, 0, 757, 758, 3, 251, 124, 0, 758, 759, 3, 251, 124, 0, 759, 760, 3, 265, 131, 0, 760, 128, 1, 0, 0, 0, 761, 762, 3, 257, 127, 0, 762, 763, 3, 239, 118, 0, 763, 764, 3, 239, 118, 0, 764, 765, 3, 265, 131, 0, 765, 766, 3, 237, 117, 0, 766, 767, 3, 267, 132, 0, 767, 130, 1, 0, 0, 0, 768, 769, 3, 257, 127, 0, 769, 770, 3, 255, 126, 0, 770, 132, 1, 0, 0, 0, 771, 772, 3, 257, 127, 0, 772, 773, 3, 263, 130, 0, 773, 134, 1, 0, 0, 0, 774, 775, 3, 257, 127, 0, 775, 776, 3, 263, 130, 0, 776, 777, 3, 235, 116, 0, 777, 778, 3, 237, 117, 0, 778, 779, 3, 263, 130, 0, 779, 136, 1, 0, 0, 0, 780, 781, 3, 257, 127, 0, 781, 782, 3, 269, 133, 0, 782, 783, 3, 267, 132, 0, 783, 784, 3, 237, 117, 0, 784, 785, 3, 263, 130, 0, 785, 138, 1, 0, 0, 0, 786, 787, 3, 257, 127, 0, 787, 788, 3, 271, 134, 0, 788, 789, 3, 237, 117, 0, 789, 790, 3, 263, 130, 0, 790, 140, 1, 0, 0, 0, 791, 792, 3, 259, 128, 0, 792, 793, 3, 229, 113, 0, 793, 794, 3, 263, 130, 0, 794, 795, 3, 267, 132, 0, 795, 796, 3, 245, 121, 0, 796, 797, 3, 267, 132, 0, 797, 798, 3, 245, 121, 0, 798, 799, 3, 257, 127, 0, 799, 800, 3, 255, 126, 0, 800, 142, 1, 0, 0, 0, 801, 802, 3, 259, 128, 0, 802, 803, 3, 263, 130, 0, 803, 804, 3, 237, 117, 0, 804, 805, 3, 233, 115, 0, 805, 806, 3, 237, 117, 0, 806, 807, 3, 235, 116, 0, 807, 808, 3, 245, 121, 0, 808, 809, 3, 255, 126, 0, 809, 810, 3, 241, 119, 0, 810, 144, 1, 0, 0, 0, 811, 812, 3, 259, 128, 0, 812, 813, 3, 263, 130, 0, 813, 814, 3, 237, 117, 0, 814, 815, 3, 273, 135, 0, 815, 816, 3, 243, 120, 0, 816, 817, 3, 237, 117, 0, 817, 818, 3, 263, 130, 0, 818, 819, 3, 237, 117, 0, 819, 146, 1, 0, 0, 0, 820, 821, 3, 261, 129, 0, 821, 822, 3, 269, 133, 0, 822, 823, 3, 229, 113, 0, 823, 824, 3, 263, 130, 0, 824, 825, 3, 267, 132, 0, 825, 826, 3, 237, 117, 0, 826, 827, 3, 263, 130, 0, 827, 148, 1, 0, 0, 0, 828, 829, 3, 263, 130, 0, 829, 830, 3, 229, 113, 0, 830, 831, 3, 255, 126, 0, 831, 832, 3, 241, 119, 0, 832, 833, 3, 237, 117, 0, 833, 150, 1, 0, 0, 0, 834, 835, 3, 263, 130, 0, 835, 836, 3, 237, 117, 0, 836, 837, 3, 267, 132, 0, 837, 838, 3, 269, 133, 0, 838, 839, 3, 263, 130, 0, 839, 840, 3, 255, 126, 0, 840, 152, 1, 0, 0, 0, 841, 842, 3, 263, 130, 0, 842, 843, 3, 245, 121, 0, 843, 844, 3, 241, 119, 0, 844, 845, 3, 243, 120, 0, 845, 846, 3, 267, 132, 0, 846, 154, 1, 0, 0, 0, 847, 848, 3, 263, 130, 0, 848, 849, 3, 257, 127, 0, 849, 850, 3, 251, 124, 0, 850, 851, 3, 251, 124, 0, 851, 852, 3, 269, 133, 0, 852, 853, 3, 259, 128, 0, 853, 156, 1, 0, 0, 0, 854, 855, 3, 263, 130, 0, 855, 856, 3, 257, 127, 0, 856, 857, 3, 273, 135, 0, 857, 158, 1, 0, 0, 0, 858, 859, 3, 263, 130, 0, 859, 860, 3, 257, 127, 0, 860, 861, 3, 273, 135, 0, 861, 862, 3, 265, 131, 0, 862, 160, 1, 0, 0, 0, 863, 864, 3, 265, 131, 0, 864, 865, 3, 229, 113, 0, 865, 866, 3, 253, 125, 0, 866, 867, 3, 259, 128, 0, 867, 868, 3, 251, 124, 0, 868, 869, 3, 237, 117, 0, 869, 162, 1, 0, 0, 0, 870, 871, 3, 265, 131, 0, 871, 872, 3, 237, 117, 0, 872, 873, 3, 233, 115, 0, 873, 874, 3, 257, 127, 0, 874, 875, 3, 255, 126, 0, 875, 876, 3, 235, 116, 0, 876, 164, 1, 0, 0, 0, 877, 878, 3, 265, 131, 0, 878, 879, 3, 237, 117, 0, 879, 880, 3, 251, 124, 0, 880, 881, 3, 237, 117, 0, 881, 882, 3, 233, 115, 0, 882, 883, 3, 267, 132, 0, 883, 166, 1, 0, 0, 0, 884, 885, 3, 265, 131, 0, 885, 886, 3, 237, 117, 0, 886, 887, 3, 253, 125, 0, 887, 888, 3, 245, 121, 0, 888, 168, 1, 0, 0, 0, 889, 890, 3, 265, 131, 0, 890, 891, 3, 237, 117, 0, 891, 892, 3, 267, 132, 0, 892, 893, 3, 267, 132, 0, 893, 894, 3, 245, 121, 0, 894, 895, 3, 255, 126, 0, 895, 896, 3, 241, 119, 0, 896, 897, 3, 265, 131, 0, 897, 170, 1, 0, 0, 0, 898, 899, 3, 265, 131, 0, 899, 900, 3, 269, 133, 0, 900, 901, 3, 231, 114, 0, 901, 902, 3, 265, 131, 0, 902, 903, 3, 267, 132, 0, 903, 904, 3, 263, 130, 0, 904, 905, 3, 245, 121, 0, 905, 906, 3, 255, 126, 0, 906, 907, 3, 241, 119, 0, 907, 172, 1, 0, 0, 0, 908, 909, 3, 267, 132, 0, 909, 910, 3, 243, 120, 0, 910, 911, 3, 237, 117, 0, 911, 912, 3, 255, 126, 0, 912, 174, 1, 0, 0, 0, 913, 914, 3, 267, 132, 0, 914, 915, 3, 243, 120, 0, 915, 916, 3, 263, 130, 0, 916, 917, 3, 257, 127, 0, 917, 918, 3, 273, 135, 0, 918, 176, 1, 0, 0, 0, 919, 920, 3, 267, 132, 0, 920, 921, 3, 245, 121, 0, 921, 922, 3, 237, 117, 0, 922, 923, 3, 265, 131, 0, 923, 178, 1, 0, 0, 0, 924, 925, 3, 267, 132, 0, 925, 926, 3, 245, 121, 0, 926, 927, 3, 253, 125, 0, 927, 928, 3, 237, 117, 0, 928, 929, 3, 265, 131, 0, 929, 930, 3, 267, 132, 0, 930, 931, 3, 229, 113, 0, 931, 932, 3, 253, 125, 0, 932, 933, 3, 259, 128, 0, 933, 180, 1, 0, 0, 0, 934, 935, 3, 267, 132, 0, 935, 936, 3, 257, 127, 0, 936, 182, 1, 0, 0, 0, 937, 938, 3, 267, 132, 0, 938, 939, 3, 257, 127, 0, 939, 940, 3, 259, 128, 0, 940, 184, 1, 0, 0, 0, 941, 942, 3, 267, 132, 0, 942, 943, 3, 257, 127, 0, 943, 944, 3, 267, 132, 0, 944, 945, 3, 229, 113, 0, 945, 946, 3, 251, 124, 0, 946, 947, 3, 265, 131, 0, 947, 186, 1, 0, 0, 0, 948, 949, 3, 267, 132, 0, 949, 950, 3, 263, 130, 0, 950, 951, 3, 229, 113, 0, 951, 952, 3, 245, 121, 0, 952, 953, 3, 251, 124, 0, 953, 954, 3, 245, 121, 0, 954, 955, 3, 255, 126, 0, 955, 956, 3, 241, 119, 0, 956, 188, 1, 0, 0, 0, 957, 958, 3, 267, 132, 0, 958, 959, 3, 263, 130, 0, 959, 960, 3, 245, 121, 0, 960, 961, 3, 253, 125, 0, 961, 190, 1, 0, 0, 0, 962, 963, 3, 267, 132, 0, 963, 964, 3, 263, 130, 0, 964, 965, 3, 269, 133, 0, 965, 966, 3, 255, 126, 0, 966, 967, 3, 233, 115, 0, 967, 968, 3, 229, 113, 0, 968, 969, 3, 267, 132, 0, 969, 970, 3, 237, 117, 0, 970, 192, 1, 0, 0, 0, 971, 972, 3, 267, 132, 0, 972, 973, 3, 263, 130, 0, 973, 974, 3, 277, 137, 0, 974, 194, 1, 0, 0, 0, 975, 976, 3, 269, 133, 0, 976, 977, 3, 255, 126, 0, 977, 978, 3, 231, 114, 0, 978, 979, 3, 257, 127, 0, 979, 980, 3, 269, 133, 0, 980, 981, 3, 255, 126, 0, 981, 982, 3, 235, 116, 0, 982, 983, 3, 237, 117, 0, 983, 984, 3, 235, 116, 0, 984, 196, 1, 0, 0, 0, 985, 986, 3, 269, 133, 0, 986, 987, 3, 255, 126, 0, 987, 988, 3, 245, 121, 0, 988, 989, 3, 257, 127, 0, 989, 990, 3, 255, 126, 0, 990, 198, 1, 0, 0, 0, 991, 992, 3, 269, 133, 0, 992, 993, 3, 265, 131, 0, 993, 994, 3, 245, 121, 0, 994, 995, 3, 255, 126, 0, 995, 996, 3, 241, 119, 0, 996, 200, 1, 0, 0, 0, 997, 998, 3, 273, 135, 0, 998, 999, 3, 237, 117, 0, 999, 1000, 3, 237, 117, 0, 1000, 1001, 3, 249, 123, 0, 1001, 202, 1, 0, 0, 0, 1002, 1003, 3, 273, 135, 0, 1003, 1004, 3, 243, 120, 0, 1004, 1005, 3, 237, 117, 0, 1005, 1006, 3, 255, 126, 0, 1006, 204, 1, 0, 0, 0, 1007, 1008, 3, 273, 135, 0, 1008, 1009, 3, 243, 120, 0, 1009, 1010, 3, 237, 117, 0, 1010, 1011, 3, 263, 130, 0, 1011, 1012, 3, 237, 117, 0, 1012, 206, 1, 0, 0, 0, 1013, 1014, 3, 273, 135, 0, 1014, 1015, 3, 243, 120, 0, 1015, 1016, 3, 245, 121, 0, 1016, 1017, 3, 251, 124, 0, 1017, 1018, 3, 237, 117, 0, 1018, 208, 1, 0, 0, 0, 1019, 1020, 3, 273, 135, 0, 1020, 1021, 3, 245, 121, 0, 1021, 1022, 3, 255, 126, 0, 1022, 1023, 3, 235, 116, 0, 1023, 1024, 3, 257, 127, 0, 1024, 1025, 3, 273, 135, 0, 1025, 210, 1, 0, 0, 0, 1026, 1027, 3, 273, 135, 0, 1027, 1028, 3, 245, 121, 0, 1028, 1029, 3, 267, 132, 0, 1029, 1030, 3, 243, 120, 0, 1030, 212, 1, 0, 0, 0, 1031, 1032, 3, 277, 137, 0, 1032, 1033, 3, 237, 117, 0, 1033, 1034, 3, 229, 113, 0, 1034, 1035, 3, 263, 130, 0, 1035, 1042, 1, 0, 0, 0, 1036, 1037, 3, 277, 137, 0, 1037, 1038, 3, 277, 137, 0, 1038, 1039, 3, 277, 137, 0, 1039, 1040, 3, 277, 137, 0, 1040, 1042, 1, 0, 0, 0, 1041, 1031, 1, 0, 0, 0, 1041, 1036, 1, 0, 0, 0, 1042, 214, 1, 0, 0, 0, 1043, 1044, 3, 295, 146, 0, 1044, 1045, 3, 231, 114, 0, 1045, 1071, 1, 0, 0, 0, 1046, 1047, 3, 295, 146, 0, 1047, 1048, 3, 239, 118, 0, 1048, 1071, 1, 0, 0, 0, 1049, 1050, 3, 295, 146, 0, 1050, 1051, 3, 263, 130, 0, 1051, 1071, 1, 0, 0, 0, 1052, 1053, 3, 295, 146, 0, 1053, 1054, 3, 255, 126, 0, 1054, 1071, 1, 0, 0, 0, 1055, 1056, 3, 295, 146, 0, 1056, 1057, 3, 267, 132, 0, 1057, 1071, 1, 0, 0, 0, 1058, 1059, 3, 295, 146, 0, 1059, 1060, 5, 48, 0, 0, 1060, 1071, 1, 0, 0, 0, 1061, 1062, 3, 295, 146, 0, 1062, 1063, 3, 229, 113, 0, 1063, 1071, 1, 0, 0, 0, 1064, 1065, 3, 295, 146, 0, 1065, 1066, 3, 271, 134, 0, 1066, 1071, 1, 0, 0, 0, 1067, 1068, 3, 295, 146, 0, 1068, 1069, 3, 295, 146, 0, 1069, 1071, 1, 0, 0, 0, 1070, 1043, 1, 0, 0, 0, 1070, 1046, 1, 0, 0, 0, 1070, 1049, 1, 0, 0, 0, 1070, 1052, 1, 0, 0, 0, 1070, 1055, 1, 0, 0, 0, 1070, 1058, 1, 0, 0, 0, 1070, 1061, 1, 0, 0, 0, 1070, 1064, 1, 0, 0, 0, 1070, 1067, 1, 0, 0, 0, 1071, 216, 1, 0, 0, 0, 1072, 1076, 3, 281, 139, 0, 1073, 1076, 3, 371, 184, 0, 1074, 1076, 3, 305, 151, 0, 1075, 1072, 1, 0, 0, 0, 1075, 1073, 1, 0, 0, 0, 1075, 1074, 1, 0, 0, 0, 1076, 1083, 1, 0, 0, 0, 1077, 1082, 3, 281, 139, 0, 1078, 1082, 3, 371, 184, 0, 1079, 1082, 3, 285, 141, 0, 1080, 1082, 3, 305, 151, 0, 1081, 1077, 1, 0, 0, 0, 1081, 1078, 1, 0, 0, 0, 1081, 1079, 1, 0, 0, 0, 1081, 1080, 1, 0, 0, 0, 1082, 1085, 1, 0, 0, 0, 1083, 1081, 1, 0, 0, 0, 1083, 1084, 1, 0, 0, 0, 1084, 1119, 1, 0, 0, 0, 1085, 1083, 1, 0, 0, 0, 1086, 1097, 3, 293, 145, 0, 1087, 1096, 8, 0, 0, 0, 1088, 1096, 3, 215, 106, 0, 1089, 1090, 3, 295, 146, 0, 1090, 1091, 3, 355, 176, 0, 1091, 1096, 1, 0, 0, 0, 1092, 1093, 3, 293, 145, 0, 1093, 1094, 3, 293, 145, 0, 1094, 1096, 1, 0, 0, 0, 1095, 1087, 1, 0, 0, 0, 1095, 1088, 1, 0, 0, 0, 1095, 1089, 1, 0, 0, 0, 1095, 1092, 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, 1101, 3, 293, 145, 0, 1101, 1119, 1, 0, 0, 0, 1102, 1113, 3, 349, 173, 0, 1103, 1112, 8, 1, 0, 0, 1104, 1112, 3, 215, 106, 0, 1105, 1106, 3, 295, 146, 0, 1106, 1107, 3, 349, 173, 0, 1107, 1112, 1, 0, 0, 0, 1108, 1109, 3, 349, 173, 0, 1109, 1110, 3, 349, 173, 0, 1110, 1112, 1, 0, 0, 0, 1111, 1103, 1, 0, 0, 0, 1111, 1104, 1, 0, 0, 0, 1111, 1105, 1, 0, 0, 0, 1111, 1108, 1, 0, 0, 0, 1112, 1115, 1, 0, 0, 0, 1113, 1111, 1, 0, 0, 0, 1113, 1114, 1, 0, 0, 0, 1114, 1116, 1, 0, 0, 0, 1115, 1113, 1, 0, 0, 0, 1116, 1117, 3, 349, 173, 0, 1117, 1119, 1, 0, 0, 0, 1118, 1075, 1, 0, 0, 0, 1118, 1086, 1, 0, 0, 0, 1118, 1102, 1, 0, 0, 0, 1119, 218, 1, 0, 0, 0, 1120, 1121, 3, 225, 111, 0, 1121, 1125, 3, 307, 152, 0, 1122, 1124, 3, 287, 142, 0, 1123, 1122, 1, 0, 0, 0, 1124, 1127, 1, 0, 0, 0, 1125, 1123, 1, 0, 0, 0, 1125, 1126, 1, 0, 0, 0, 1126, 1130, 1, 0, 0, 0, 1127, 1125, 1, 0, 0, 0, 1128, 1131, 3, 259, 128, 0, 1129, 1131, 3, 237, 117, 0, 1130, 1128, 1, 0, 0, 0, 1130, 1129, 1, 0, 0, 0, 1131, 1134, 1, 0, 0, 0, 1132, 1135, 3, 345, 171, 0, 1133, 1135, 3, 303, 150, 0, 1134, 1132, 1, 0, 0, 0, 1134, 1133, 1, 0, 0, 0, 1134, 1135, 1, 0, 0, 0, 1135, 1137, 1, 0, 0, 0, 1136, 1138, 3, 285, 141, 0, 1137, 1136, 1, 0, 0, 0, 1138, 1139, 1, 0, 0, 0, 1139, 1137, 1, 0, 0, 0, 1139, 1140, 1, 0, 0, 0, 1140, 1197, 1, 0, 0, 0, 1141, 1144, 3, 225, 111, 0, 1142, 1145, 3, 259, 128, 0, 1143, 1145, 3, 237, 117, 0, 1144, 1142, 1, 0, 0, 0, 1144, 1143, 1, 0, 0, 0, 1145, 1148, 1, 0, 0, 0, 1146, 1149, 3, 345, 171, 0, 1147, 1149, 3, 303, 150, 0, 1148, 1146, 1, 0, 0, 0, 1148, 1147, 1, 0, 0, 0, 1148, 1149, 1, 0, 0, 0, 1149, 1151, 1, 0, 0, 0, 1150, 1152, 3, 285, 141, 0, 1151, 1150, 1, 0, 0, 0, 1152, 1153, 1, 0, 0, 0, 1153, 1151, 1, 0, 0, 0, 1153, 1154, 1, 0, 0, 0, 1154, 1197, 1, 0, 0, 0, 1155, 1156, 3, 223, 110, 0, 1156, 1160, 3, 307, 152, 0, 1157, 1159, 3, 285, 141, 0, 1158, 1157, 1, 0, 0, 0, 1159, 1162, 1, 0, 0, 0, 1160, 1158, 1, 0, 0, 0, 1160, 1161, 1, 0, 0, 0, 1161, 1163, 1, 0, 0, 0, 1162, 1160, 1, 0, 0, 0, 1163, 1166, 3, 237, 117, 0, 1164, 1167, 3, 345, 171, 0, 1165, 1167, 3, 303, 150, 0, 1166, 1164, 1, 0, 0, 0, 1166, 1165, 1, 0, 0, 0, 1166, 1167, 1, 0, 0, 0, 1167, 1169, 1, 0, 0, 0, 1168, 1170, 3, 285, 141, 0, 1169, 1168, 1, 0, 0, 0, 1170, 1171, 1, 0, 0, 0, 1171, 1169, 1, 0, 0, 0, 1171, 1172, 1, 0, 0, 0, 1172, 1197, 1, 0, 0, 0, 1173, 1174, 3, 307, 152, 0, 1174, 1175, 3, 223, 110, 0, 1175, 1178, 3, 237, 117, 0, 1176, 1179, 3, 345, 171, 0, 1177, 1179, 3, 303, 150, 0, 1178, 1176, 1, 0, 0, 0, 1178, 1177, 1, 0, 0, 0, 1178, 1179, 1, 0, 0, 0, 1179, 1181, 1, 0, 0, 0, 1180, 1182, 3, 285, 141, 0, 1181, 1180, 1, 0, 0, 0, 1182, 1183, 1, 0, 0, 0, 1183, 1181, 1, 0, 0, 0, 1183, 1184, 1, 0, 0, 0, 1184, 1197, 1, 0, 0, 0, 1185, 1186, 3, 223, 110, 0, 1186, 1189, 3, 237, 117, 0, 1187, 1190, 3, 345, 171, 0, 1188, 1190, 3, 303, 150, 0, 1189, 1187, 1, 0, 0, 0, 1189, 1188, 1, 0, 0, 0, 1189, 1190, 1, 0, 0, 0, 1190, 1192, 1, 0, 0, 0, 1191, 1193, 3, 285, 141, 0, 1192, 1191, 1, 0, 0, 0, 1193, 1194, 1, 0, 0, 0, 1194, 1192, 1, 0, 0, 0, 1194, 1195, 1, 0, 0, 0, 1195, 1197, 1, 0, 0, 0, 1196, 1120, 1, 0, 0, 0, 1196, 1141, 1, 0, 0, 0, 1196, 1155, 1, 0, 0, 0, 1196, 1173, 1, 0, 0, 0, 1196, 1185, 1, 0, 0, 0, 1197, 220, 1, 0, 0, 0, 1198, 1200, 5, 48, 0, 0, 1199, 1201, 3, 283, 140, 0, 1200, 1199, 1, 0, 0, 0, 1201, 1202, 1, 0, 0, 0, 1202, 1200, 1, 0, 0, 0, 1202, 1203, 1, 0, 0, 0, 1203, 222, 1, 0, 0, 0, 1204, 1206, 3, 285, 141, 0, 1205, 1204, 1, 0, 0, 0, 1206, 1207, 1, 0, 0, 0, 1207, 1205, 1, 0, 0, 0, 1207, 1208, 1, 0, 0, 0, 1208, 224, 1, 0, 0, 0, 1209, 1210, 5, 48, 0, 0, 1210, 1212, 3, 275, 136, 0, 1211, 1213, 3, 287, 142, 0, 1212, 1211, 1, 0, 0, 0, 1213, 1214, 1, 0, 0, 0, 1214, 1212, 1, 0, 0, 0, 1214, 1215, 1, 0, 0, 0, 1215, 226, 1, 0, 0, 0, 1216, 1227, 3, 355, 176, 0, 1217, 1226, 8, 2, 0, 0, 1218, 1226, 3, 215, 106, 0, 1219, 1220, 3, 295, 146, 0, 1220, 1221, 3, 355, 176, 0, 1221, 1226, 1, 0, 0, 0, 1222, 1223, 3, 355, 176, 0, 1223, 1224, 3, 355, 176, 0, 1224, 1226, 1, 0, 0, 0, 1225, 1217, 1, 0, 0, 0, 1225, 1218, 1, 0, 0, 0, 1225, 1219, 1, 0, 0, 0, 1225, 1222, 1, 0, 0, 0, 1226, 1229, 1, 0, 0, 0, 1227, 1225, 1, 0, 0, 0, 1227, 1228, 1, 0, 0, 0, 1228, 1230, 1, 0, 0, 0, 1229, 1227, 1, 0, 0, 0, 1230, 1231, 3, 355, 176, 0, 1231, 228, 1, 0, 0, 0, 1232, 1233, 7, 3, 0, 0, 1233, 230, 1, 0, 0, 0, 1234, 1235, 7, 4, 0, 0, 1235, 232, 1, 0, 0, 0, 1236, 1237, 7, 5, 0, 0, 1237, 234, 1, 0, 0, 0, 1238, 1239, 7, 6, 0, 0, 1239, 236, 1, 0, 0, 0, 1240, 1241, 7, 7, 0, 0, 1241, 238, 1, 0, 0, 0, 1242, 1243, 7, 8, 0, 0, 1243, 240, 1, 0, 0, 0, 1244, 1245, 7, 9, 0, 0, 1245, 242, 1, 0, 0, 0, 1246, 1247, 7, 10, 0, 0, 1247, 244, 1, 0, 0, 0, 1248, 1249, 7, 11, 0, 0, 1249, 246, 1, 0, 0, 0, 1250, 1251, 7, 12, 0, 0, 1251, 248, 1, 0, 0, 0, 1252, 1253, 7, 13, 0, 0, 1253, 250, 1, 0, 0, 0, 1254, 1255, 7, 14, 0, 0, 1255, 252, 1, 0, 0, 0, 1256, 1257, 7, 15, 0, 0, 1257, 254, 1, 0, 0, 0, 1258, 1259, 7, 16, 0, 0, 1259, 256, 1, 0, 0, 0, 1260, 1261, 7, 17, 0, 0, 1261, 258, 1, 0, 0, 0, 1262, 1263, 7, 18, 0, 0, 1263, 260, 1, 0, 0, 0, 1264, 1265, 7, 19, 0, 0, 1265, 262, 1, 0, 0, 0, 1266, 1267, 7, 20, 0, 0, 1267, 264, 1, 0, 0, 0, 1268, 1269, 7, 21, 0, 0, 1269, 266, 1, 0, 0, 0, 1270, 1271, 7, 22, 0, 0, 1271, 268, 1, 0, 0, 0, 1272, 1273, 7, 23, 0, 0, 1273, 270, 1, 0, 0, 0, 1274, 1275, 7, 24, 0, 0, 1275, 272, 1, 0, 0, 0, 1276, 1277, 7, 25, 0, 0, 1277, 274, 1, 0, 0, 0, 1278, 1279, 7, 26, 0, 0, 1279, 276, 1, 0, 0, 0, 1280, 1281, 7, 27, 0, 0, 1281, 278, 1, 0, 0, 0, 1282, 1283, 7, 28, 0, 0, 1283, 280, 1, 0, 0, 0, 1284, 1285, 7, 29, 0, 0, 1285, 282, 1, 0, 0, 0, 1286, 1287, 7, 30, 0, 0, 1287, 284, 1, 0, 0, 0, 1288, 1289, 7, 31, 0, 0, 1289, 286, 1, 0, 0, 0, 1290, 1291, 7, 32, 0, 0, 1291, 288, 1, 0, 0, 0, 1292, 1293, 5, 45, 0, 0, 1293, 1294, 5, 62, 0, 0, 1294, 290, 1, 0, 0, 0, 1295, 1296, 5, 42, 0, 0, 1296, 292, 1, 0, 0, 0, 1297, 1298, 5, 96, 0, 0, 1298, 294, 1, 0, 0, 0, 1299, 1300, 5, 92, 0, 0, 1300, 296, 1, 0, 0, 0, 1301, 1302, 5, 58, 0, 0, 1302, 298, 1, 0, 0, 0, 1303, 1304, 5, 44, 0, 0, 1304, 300, 1, 0, 0, 0, 1305, 1306, 5, 124, 0, 0, 1306, 1307, 5, 124, 0, 0, 1307, 302, 1, 0, 0, 0, 1308, 1309, 5, 45, 0, 0, 1309, 304, 1, 0, 0, 0, 1310, 1311, 5, 36, 0, 0, 1311, 306, 1, 0, 0, 0, 1312, 1313, 5, 46, 0, 0, 1313, 308, 1, 0, 0, 0, 1314, 1315, 5, 61, 0, 0, 1315, 1316, 5, 61, 0, 0, 1316, 310, 1, 0, 0, 0, 1317, 1318, 5, 61, 0, 0, 1318, 312, 1, 0, 0, 0, 1319, 1320, 5, 62, 0, 0, 1320, 1321, 5, 61, 0, 0, 1321, 314, 1, 0, 0, 0, 1322, 1323, 5, 62, 0, 0, 1323, 316, 1, 0, 0, 0, 1324, 1325, 5, 35, 0, 0, 1325, 318, 1, 0, 0, 0, 1326, 1327, 5, 126, 0, 0, 1327, 1328, 5, 42, 0, 0, 1328, 320, 1, 0, 0, 0, 1329, 1330, 5, 61, 0, 0, 1330, 1331, 5, 126, 0, 0, 1331, 1332, 5, 42, 0, 0, 1332, 322, 1, 0, 0, 0, 1333, 1334, 5, 123, 0, 0, 1334, 1335, 1, 0, 0, 0, 1335, 1336, 6, 160, 0, 0, 1336, 324, 1, 0, 0, 0, 1337, 1338, 5, 91, 0, 0, 1338, 326, 1, 0, 0, 0, 1339, 1340, 5, 40, 0, 0, 1340, 328, 1, 0, 0, 0, 1341, 1342, 5, 60, 0, 0, 1342, 1343, 5, 61, 0, 0, 1343, 330, 1, 0, 0, 0, 1344, 1345, 5, 60, 0, 0, 1345, 332, 1, 0, 0, 0, 1346, 1347, 5, 33, 0, 0, 1347, 1351, 5, 61, 0, 0, 1348, 1349, 5, 60, 0, 0, 1349, 1351, 5, 62, 0, 0, 1350, 1346, 1, 0, 0, 0, 1350, 1348, 1, 0, 0, 0, 1351, 334, 1, 0, 0, 0, 1352, 1353, 5, 33, 0, 0, 1353, 1354, 5, 126, 0, 0, 1354, 1355, 5, 42, 0, 0, 1355, 336, 1, 0, 0, 0, 1356, 1357, 5, 33, 0, 0, 1357, 1358, 5, 126, 0, 0, 1358, 338, 1, 0, 0, 0, 1359, 1360, 5, 63, 0, 0, 1360, 1361, 5, 46, 0, 0, 1361, 340, 1, 0, 0, 0, 1362, 1363, 5, 63, 0, 0, 1363, 1364, 5, 63, 0, 0, 1364, 342, 1, 0, 0, 0, 1365, 1366, 5, 37, 0, 0, 1366, 344, 1, 0, 0, 0, 1367, 1368, 5, 43, 0, 0, 1368, 346, 1, 0, 0, 0, 1369, 1370, 5, 63, 0, 0, 1370, 348, 1, 0, 0, 0, 1371, 1372, 5, 34, 0, 0, 1372, 350, 1, 0, 0, 0, 1373, 1374, 5, 102, 0, 0, 1374, 1375, 5, 39, 0, 0, 1375, 1376, 1, 0, 0, 0, 1376, 1377, 6, 174, 1, 0, 1377, 352, 1, 0, 0, 0, 1378, 1379, 5, 70, 0, 0, 1379, 1380, 5, 39, 0, 0, 1380, 1381, 1, 0, 0, 0, 1381, 1382, 6, 175, 2, 0, 1382, 354, 1, 0, 0, 0, 1383, 1384, 5, 39, 0, 0, 1384, 356, 1, 0, 0, 0, 1385, 1386, 5, 126, 0, 0, 1386, 358, 1, 0, 0, 0, 1387, 1388, 5, 61, 0, 0, 1388, 1389, 5, 126, 0, 0, 1389, 360, 1, 0, 0, 0, 1390, 1391, 5, 125, 0, 0, 1391, 1392, 1, 0, 0, 0, 1392, 1393, 6, 179, 3, 0, 1393, 362, 1, 0, 0, 0, 1394, 1395, 5, 93, 0, 0, 1395, 364, 1, 0, 0, 0, 1396, 1397, 5, 41, 0, 0, 1397, 366, 1, 0, 0, 0, 1398, 1399, 5, 59, 0, 0, 1399, 368, 1, 0, 0, 0, 1400, 1401, 5, 47, 0, 0, 1401, 370, 1, 0, 0, 0, 1402, 1403, 5, 95, 0, 0, 1403, 372, 1, 0, 0, 0, 1404, 1405, 5, 47, 0, 0, 1405, 1406, 5, 42, 0, 0, 1406, 1410, 1, 0, 0, 0, 1407, 1409, 9, 0, 0, 0, 1408, 1407, 1, 0, 0, 0, 1409, 1412, 1, 0, 0, 0, 1410, 1411, 1, 0, 0, 0, 1410, 1408, 1, 0, 0, 0, 1411, 1413, 1, 0, 0, 0, 1412, 1410, 1, 0, 0, 0, 1413, 1414, 5, 42, 0, 0, 1414, 1415, 5, 47, 0, 0, 1415, 1416, 1, 0, 0, 0, 1416, 1417, 6, 185, 4, 0, 1417, 374, 1, 0, 0, 0, 1418, 1419, 5, 45, 0, 0, 1419, 1423, 5, 45, 0, 0, 1420, 1421, 5, 47, 0, 0, 1421, 1423, 5, 47, 0, 0, 1422, 1418, 1, 0, 0, 0, 1422, 1420, 1, 0, 0, 0, 1423, 1427, 1, 0, 0, 0, 1424, 1426, 8, 33, 0, 0, 1425, 1424, 1, 0, 0, 0, 1426, 1429, 1, 0, 0, 0, 1427, 1425, 1, 0, 0, 0, 1427, 1428, 1, 0, 0, 0, 1428, 1431, 1, 0, 0, 0, 1429, 1427, 1, 0, 0, 0, 1430, 1432, 7, 34, 0, 0, 1431, 1430, 1, 0, 0, 0, 1432, 1433, 1, 0, 0, 0, 1433, 1434, 6, 186, 4, 0, 1434, 376, 1, 0, 0, 0, 1435, 1436, 7, 35, 0, 0, 1436, 1437, 1, 0, 0, 0, 1437, 1438, 6, 187, 5, 0, 1438, 378, 1, 0, 0, 0, 1439, 1451, 8, 36, 0, 0, 1440, 1451, 3, 215, 106, 0, 1441, 1442, 3, 295, 146, 0, 1442, 1443, 3, 355, 176, 0, 1443, 1451, 1, 0, 0, 0, 1444, 1445, 3, 295, 146, 0, 1445, 1446, 3, 323, 160, 0, 1446, 1451, 1, 0, 0, 0, 1447, 1448, 3, 355, 176, 0, 1448, 1449, 3, 355, 176, 0, 1449, 1451, 1, 0, 0, 0, 1450, 1439, 1, 0, 0, 0, 1450, 1440, 1, 0, 0, 0, 1450, 1441, 1, 0, 0, 0, 1450, 1444, 1, 0, 0, 0, 1450, 1447, 1, 0, 0, 0, 1451, 1452, 1, 0, 0, 0, 1452, 1450, 1, 0, 0, 0, 1452, 1453, 1, 0, 0, 0, 1453, 380, 1, 0, 0, 0, 1454, 1455, 3, 323, 160, 0, 1455, 1456, 1, 0, 0, 0, 1456, 1457, 6, 189, 0, 0, 1457, 382, 1, 0, 0, 0, 1458, 1459, 3, 355, 176, 0, 1459, 1460, 1, 0, 0, 0, 1460, 1461, 6, 190, 6, 0, 1461, 1462, 6, 190, 3, 0, 1462, 384, 1, 0, 0, 0, 1463, 1469, 8, 37, 0, 0, 1464, 1469, 3, 215, 106, 0, 1465, 1466, 3, 295, 146, 0, 1466, 1467, 3, 323, 160, 0, 1467, 1469, 1, 0, 0, 0, 1468, 1463, 1, 0, 0, 0, 1468, 1464, 1, 0, 0, 0, 1468, 1465, 1, 0, 0, 0, 1469, 1470, 1, 0, 0, 0, 1470, 1468, 1, 0, 0, 0, 1470, 1471, 1, 0, 0, 0, 1471, 386, 1, 0, 0, 0, 1472, 1473, 3, 323, 160, 0, 1473, 1474, 1, 0, 0, 0, 1474, 1475, 6, 192, 0, 0, 1475, 388, 1, 0, 0, 0, 44, 0, 1, 2, 429, 657, 1041, 1070, 1075, 1081, 1083, 1095, 1097, 1111, 1113, 1118, 1125, 1130, 1134, 1139, 1144, 1148, 1153, 1160, 1166, 1171, 1178, 1183, 1189, 1194, 1196, 1202, 1207, 1214, 1225, 1227, 1350, 1410, 1422, 1427, 1431, 1450, 1452, 1468, 1470, 7, 5, 0, 0, 5, 1, 0, 5, 2, 0, 4, 0, 0, 6, 0, 0, 0, 1, 0, 7, 147, 0] \ No newline at end of file diff --git a/posthog/hogql/grammar/HogQLLexer.py b/posthog/hogql/grammar/HogQLLexer.py index f234dd38975d8..2fced647ff922 100644 --- a/posthog/hogql/grammar/HogQLLexer.py +++ b/posthog/hogql/grammar/HogQLLexer.py @@ -10,7 +10,7 @@ def serializedATN(): return [ - 4,0,160,1455,6,-1,6,-1,6,-1,2,0,7,0,2,1,7,1,2,2,7,2,2,3,7,3,2,4, + 4,0,162,1476,6,-1,6,-1,6,-1,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, @@ -42,548 +42,557 @@ def serializedATN(): 2,174,7,174,2,175,7,175,2,176,7,176,2,177,7,177,2,178,7,178,2,179, 7,179,2,180,7,180,2,181,7,181,2,182,7,182,2,183,7,183,2,184,7,184, 2,185,7,185,2,186,7,186,2,187,7,187,2,188,7,188,2,189,7,189,2,190, - 7,190,1,0,1,0,1,0,1,0,1,1,1,1,1,1,1,1,1,2,1,2,1,2,1,2,1,2,1,3,1, - 3,1,3,1,3,1,4,1,4,1,4,1,4,1,4,1,4,1,5,1,5,1,5,1,6,1,6,1,6,1,6,1, - 6,1,6,1,6,1,6,1,6,1,6,1,6,1,6,1,6,1,6,3,6,426,8,6,1,7,1,7,1,7,1, - 7,1,7,1,8,1,8,1,8,1,8,1,8,1,8,1,8,1,8,1,9,1,9,1,9,1,9,1,9,1,10,1, - 10,1,10,1,11,1,11,1,11,1,11,1,11,1,12,1,12,1,12,1,12,1,12,1,13,1, - 13,1,13,1,13,1,13,1,13,1,14,1,14,1,14,1,14,1,14,1,14,1,14,1,15,1, - 15,1,15,1,15,1,15,1,15,1,15,1,15,1,16,1,16,1,16,1,16,1,16,1,16,1, - 17,1,17,1,17,1,17,1,17,1,18,1,18,1,18,1,18,1,18,1,18,1,18,1,18,1, - 19,1,19,1,19,1,19,1,19,1,20,1,20,1,20,1,20,1,21,1,21,1,21,1,21,1, - 21,1,22,1,22,1,22,1,22,1,22,1,22,1,22,1,22,1,22,1,22,1,22,1,23,1, - 23,1,23,1,23,1,23,1,23,1,23,1,23,1,23,1,24,1,24,1,24,1,24,1,24,1, - 25,1,25,1,25,1,25,1,26,1,26,1,26,1,26,1,26,1,26,1,26,1,26,1,27,1, - 27,1,27,1,27,1,27,1,27,1,28,1,28,1,28,1,28,1,28,1,28,1,28,1,28,1, - 29,1,29,1,29,1,29,1,29,1,29,1,30,1,30,1,30,1,31,1,31,1,31,1,31,1, - 31,1,31,1,31,1,31,1,31,1,31,1,32,1,32,1,32,1,32,1,33,1,33,1,33,1, - 33,1,33,1,34,1,34,1,34,1,34,1,34,1,35,1,35,1,35,1,35,1,36,1,36,1, - 36,1,36,1,36,1,36,1,37,1,37,1,37,1,37,1,37,1,37,1,37,1,38,1,38,1, - 38,1,38,1,38,1,39,1,39,1,39,1,40,1,40,1,40,1,41,1,41,1,41,1,41,1, - 41,1,41,1,42,1,42,1,42,1,43,1,43,1,43,1,43,1,43,1,43,1,43,1,43,1, - 43,1,43,1,43,1,43,1,43,3,43,647,8,43,1,44,1,44,1,44,1,44,1,44,1, - 44,1,45,1,45,1,45,1,45,1,45,1,45,1,45,1,45,1,45,1,46,1,46,1,46,1, - 47,1,47,1,47,1,47,1,47,1,48,1,48,1,48,1,48,1,49,1,49,1,49,1,49,1, - 49,1,50,1,50,1,50,1,50,1,50,1,50,1,50,1,50,1,51,1,51,1,51,1,51,1, - 51,1,52,1,52,1,52,1,52,1,53,1,53,1,53,1,53,1,53,1,54,1,54,1,54,1, - 54,1,54,1,54,1,55,1,55,1,55,1,55,1,55,1,55,1,55,1,56,1,56,1,56,1, - 56,1,56,1,56,1,57,1,57,1,57,1,57,1,58,1,58,1,58,1,58,1,59,1,59,1, - 59,1,59,1,59,1,60,1,60,1,60,1,60,1,60,1,60,1,61,1,61,1,61,1,61,1, - 61,1,61,1,61,1,62,1,62,1,62,1,63,1,63,1,63,1,64,1,64,1,64,1,64,1, - 64,1,64,1,65,1,65,1,65,1,65,1,65,1,65,1,66,1,66,1,66,1,66,1,66,1, - 67,1,67,1,67,1,67,1,67,1,67,1,67,1,67,1,67,1,67,1,68,1,68,1,68,1, - 68,1,68,1,68,1,68,1,68,1,68,1,68,1,69,1,69,1,69,1,69,1,69,1,69,1, - 69,1,69,1,69,1,70,1,70,1,70,1,70,1,70,1,70,1,70,1,70,1,71,1,71,1, - 71,1,71,1,71,1,71,1,72,1,72,1,72,1,72,1,72,1,72,1,72,1,73,1,73,1, - 73,1,73,1,73,1,73,1,74,1,74,1,74,1,74,1,74,1,74,1,74,1,75,1,75,1, - 75,1,75,1,76,1,76,1,76,1,76,1,76,1,77,1,77,1,77,1,77,1,77,1,77,1, - 77,1,78,1,78,1,78,1,78,1,78,1,78,1,78,1,79,1,79,1,79,1,79,1,79,1, - 79,1,79,1,80,1,80,1,80,1,80,1,80,1,81,1,81,1,81,1,81,1,81,1,81,1, - 81,1,81,1,81,1,82,1,82,1,82,1,82,1,82,1,82,1,82,1,82,1,82,1,82,1, - 83,1,83,1,83,1,83,1,83,1,84,1,84,1,84,1,84,1,84,1,84,1,85,1,85,1, - 85,1,85,1,85,1,86,1,86,1,86,1,86,1,86,1,86,1,86,1,86,1,86,1,86,1, - 87,1,87,1,87,1,88,1,88,1,88,1,88,1,89,1,89,1,89,1,89,1,89,1,89,1, - 89,1,90,1,90,1,90,1,90,1,90,1,90,1,90,1,90,1,90,1,91,1,91,1,91,1, - 91,1,91,1,92,1,92,1,92,1,92,1,92,1,92,1,92,1,92,1,92,1,93,1,93,1, - 93,1,93,1,94,1,94,1,94,1,94,1,94,1,94,1,94,1,94,1,94,1,94,1,95,1, - 95,1,95,1,95,1,95,1,95,1,96,1,96,1,96,1,96,1,96,1,96,1,97,1,97,1, - 97,1,97,1,97,1,98,1,98,1,98,1,98,1,98,1,99,1,99,1,99,1,99,1,99,1, - 99,1,100,1,100,1,100,1,100,1,100,1,100,1,101,1,101,1,101,1,101,1, - 101,1,101,1,101,1,102,1,102,1,102,1,102,1,102,1,103,1,103,1,103, - 1,103,1,103,1,103,1,103,1,103,1,103,1,103,3,103,1021,8,103,1,104, - 1,104,1,104,1,104,1,104,1,104,1,104,1,104,1,104,1,104,1,104,1,104, - 1,104,1,104,1,104,1,104,1,104,1,104,1,104,1,104,1,104,1,104,1,104, - 1,104,1,104,1,104,1,104,3,104,1050,8,104,1,105,1,105,1,105,3,105, - 1055,8,105,1,105,1,105,1,105,1,105,5,105,1061,8,105,10,105,12,105, - 1064,9,105,1,105,1,105,1,105,1,105,1,105,1,105,1,105,1,105,1,105, - 5,105,1075,8,105,10,105,12,105,1078,9,105,1,105,1,105,1,105,1,105, - 1,105,1,105,1,105,1,105,1,105,1,105,1,105,5,105,1091,8,105,10,105, - 12,105,1094,9,105,1,105,1,105,3,105,1098,8,105,1,106,1,106,1,106, - 5,106,1103,8,106,10,106,12,106,1106,9,106,1,106,1,106,3,106,1110, - 8,106,1,106,1,106,3,106,1114,8,106,1,106,4,106,1117,8,106,11,106, - 12,106,1118,1,106,1,106,1,106,3,106,1124,8,106,1,106,1,106,3,106, - 1128,8,106,1,106,4,106,1131,8,106,11,106,12,106,1132,1,106,1,106, - 1,106,5,106,1138,8,106,10,106,12,106,1141,9,106,1,106,1,106,1,106, - 3,106,1146,8,106,1,106,4,106,1149,8,106,11,106,12,106,1150,1,106, - 1,106,1,106,1,106,1,106,3,106,1158,8,106,1,106,4,106,1161,8,106, - 11,106,12,106,1162,1,106,1,106,1,106,1,106,3,106,1169,8,106,1,106, - 4,106,1172,8,106,11,106,12,106,1173,3,106,1176,8,106,1,107,1,107, - 4,107,1180,8,107,11,107,12,107,1181,1,108,4,108,1185,8,108,11,108, - 12,108,1186,1,109,1,109,1,109,4,109,1192,8,109,11,109,12,109,1193, - 1,110,1,110,1,110,1,110,1,110,1,110,1,110,1,110,1,110,5,110,1205, - 8,110,10,110,12,110,1208,9,110,1,110,1,110,1,111,1,111,1,112,1,112, - 1,113,1,113,1,114,1,114,1,115,1,115,1,116,1,116,1,117,1,117,1,118, - 1,118,1,119,1,119,1,120,1,120,1,121,1,121,1,122,1,122,1,123,1,123, - 1,124,1,124,1,125,1,125,1,126,1,126,1,127,1,127,1,128,1,128,1,129, - 1,129,1,130,1,130,1,131,1,131,1,132,1,132,1,133,1,133,1,134,1,134, - 1,135,1,135,1,136,1,136,1,137,1,137,1,138,1,138,1,139,1,139,1,140, - 1,140,1,141,1,141,1,141,1,142,1,142,1,143,1,143,1,144,1,144,1,145, - 1,145,1,146,1,146,1,147,1,147,1,147,1,148,1,148,1,149,1,149,1,150, - 1,150,1,151,1,151,1,151,1,152,1,152,1,153,1,153,1,153,1,154,1,154, - 1,155,1,155,1,156,1,156,1,156,1,157,1,157,1,157,1,157,1,158,1,158, - 1,158,1,158,1,159,1,159,1,160,1,160,1,161,1,161,1,161,1,162,1,162, - 1,163,1,163,1,163,1,163,3,163,1330,8,163,1,164,1,164,1,164,1,164, - 1,165,1,165,1,165,1,166,1,166,1,166,1,167,1,167,1,167,1,168,1,168, - 1,169,1,169,1,170,1,170,1,171,1,171,1,172,1,172,1,172,1,172,1,172, - 1,173,1,173,1,173,1,173,1,173,1,174,1,174,1,175,1,175,1,176,1,176, - 1,176,1,177,1,177,1,177,1,177,1,178,1,178,1,179,1,179,1,180,1,180, - 1,181,1,181,1,182,1,182,1,183,1,183,1,183,1,183,5,183,1388,8,183, - 10,183,12,183,1391,9,183,1,183,1,183,1,183,1,183,1,183,1,184,1,184, - 1,184,1,184,3,184,1402,8,184,1,184,5,184,1405,8,184,10,184,12,184, - 1408,9,184,1,184,3,184,1411,8,184,1,184,1,184,1,185,1,185,1,185, - 1,185,1,186,1,186,1,186,1,186,1,186,1,186,1,186,1,186,1,186,1,186, - 1,186,4,186,1430,8,186,11,186,12,186,1431,1,187,1,187,1,187,1,187, - 1,188,1,188,1,188,1,188,1,188,1,189,1,189,1,189,1,189,1,189,4,189, - 1448,8,189,11,189,12,189,1449,1,190,1,190,1,190,1,190,1,1389,0,191, - 3,1,5,2,7,3,9,4,11,5,13,6,15,7,17,8,19,9,21,10,23,11,25,12,27,13, - 29,14,31,15,33,16,35,17,37,18,39,19,41,20,43,21,45,22,47,23,49,24, - 51,25,53,26,55,27,57,28,59,29,61,30,63,31,65,32,67,33,69,34,71,35, - 73,36,75,37,77,38,79,39,81,40,83,41,85,42,87,43,89,44,91,45,93,46, - 95,47,97,48,99,49,101,50,103,51,105,52,107,53,109,54,111,55,113, - 56,115,57,117,58,119,59,121,60,123,61,125,62,127,63,129,64,131,65, - 133,66,135,67,137,68,139,69,141,70,143,71,145,72,147,73,149,74,151, - 75,153,76,155,77,157,78,159,79,161,80,163,81,165,82,167,83,169,84, - 171,85,173,86,175,87,177,88,179,89,181,90,183,91,185,92,187,93,189, - 94,191,95,193,96,195,97,197,98,199,99,201,100,203,101,205,102,207, - 103,209,104,211,105,213,106,215,107,217,108,219,109,221,110,223, - 111,225,0,227,0,229,0,231,0,233,0,235,0,237,0,239,0,241,0,243,0, - 245,0,247,0,249,0,251,0,253,0,255,0,257,0,259,0,261,0,263,0,265, - 0,267,0,269,0,271,0,273,0,275,0,277,0,279,0,281,0,283,0,285,112, - 287,113,289,114,291,115,293,116,295,117,297,118,299,119,301,120, - 303,121,305,122,307,123,309,124,311,125,313,126,315,127,317,128, - 319,129,321,130,323,131,325,132,327,133,329,134,331,135,333,136, - 335,137,337,138,339,139,341,140,343,141,345,142,347,143,349,144, - 351,145,353,146,355,147,357,148,359,149,361,150,363,151,365,152, - 367,153,369,154,371,155,373,156,375,157,377,158,379,0,381,159,383, - 160,3,0,1,2,38,2,0,92,92,96,96,2,0,34,34,92,92,2,0,39,39,92,92,2, - 0,65,65,97,97,2,0,66,66,98,98,2,0,67,67,99,99,2,0,68,68,100,100, - 2,0,69,69,101,101,2,0,70,70,102,102,2,0,71,71,103,103,2,0,72,72, - 104,104,2,0,73,73,105,105,2,0,74,74,106,106,2,0,75,75,107,107,2, - 0,76,76,108,108,2,0,77,77,109,109,2,0,78,78,110,110,2,0,79,79,111, - 111,2,0,80,80,112,112,2,0,81,81,113,113,2,0,82,82,114,114,2,0,83, - 83,115,115,2,0,84,84,116,116,2,0,85,85,117,117,2,0,86,86,118,118, - 2,0,87,87,119,119,2,0,88,88,120,120,2,0,89,89,121,121,2,0,90,90, - 122,122,2,0,65,90,97,122,1,0,48,55,1,0,48,57,3,0,48,57,65,70,97, - 102,2,0,10,10,13,13,2,1,10,10,13,13,2,0,9,13,32,32,3,0,39,39,92, - 92,123,123,1,0,123,123,1491,0,3,1,0,0,0,0,5,1,0,0,0,0,7,1,0,0,0, - 0,9,1,0,0,0,0,11,1,0,0,0,0,13,1,0,0,0,0,15,1,0,0,0,0,17,1,0,0,0, - 0,19,1,0,0,0,0,21,1,0,0,0,0,23,1,0,0,0,0,25,1,0,0,0,0,27,1,0,0,0, - 0,29,1,0,0,0,0,31,1,0,0,0,0,33,1,0,0,0,0,35,1,0,0,0,0,37,1,0,0,0, - 0,39,1,0,0,0,0,41,1,0,0,0,0,43,1,0,0,0,0,45,1,0,0,0,0,47,1,0,0,0, - 0,49,1,0,0,0,0,51,1,0,0,0,0,53,1,0,0,0,0,55,1,0,0,0,0,57,1,0,0,0, - 0,59,1,0,0,0,0,61,1,0,0,0,0,63,1,0,0,0,0,65,1,0,0,0,0,67,1,0,0,0, - 0,69,1,0,0,0,0,71,1,0,0,0,0,73,1,0,0,0,0,75,1,0,0,0,0,77,1,0,0,0, - 0,79,1,0,0,0,0,81,1,0,0,0,0,83,1,0,0,0,0,85,1,0,0,0,0,87,1,0,0,0, - 0,89,1,0,0,0,0,91,1,0,0,0,0,93,1,0,0,0,0,95,1,0,0,0,0,97,1,0,0,0, - 0,99,1,0,0,0,0,101,1,0,0,0,0,103,1,0,0,0,0,105,1,0,0,0,0,107,1,0, - 0,0,0,109,1,0,0,0,0,111,1,0,0,0,0,113,1,0,0,0,0,115,1,0,0,0,0,117, - 1,0,0,0,0,119,1,0,0,0,0,121,1,0,0,0,0,123,1,0,0,0,0,125,1,0,0,0, - 0,127,1,0,0,0,0,129,1,0,0,0,0,131,1,0,0,0,0,133,1,0,0,0,0,135,1, - 0,0,0,0,137,1,0,0,0,0,139,1,0,0,0,0,141,1,0,0,0,0,143,1,0,0,0,0, - 145,1,0,0,0,0,147,1,0,0,0,0,149,1,0,0,0,0,151,1,0,0,0,0,153,1,0, - 0,0,0,155,1,0,0,0,0,157,1,0,0,0,0,159,1,0,0,0,0,161,1,0,0,0,0,163, - 1,0,0,0,0,165,1,0,0,0,0,167,1,0,0,0,0,169,1,0,0,0,0,171,1,0,0,0, - 0,173,1,0,0,0,0,175,1,0,0,0,0,177,1,0,0,0,0,179,1,0,0,0,0,181,1, - 0,0,0,0,183,1,0,0,0,0,185,1,0,0,0,0,187,1,0,0,0,0,189,1,0,0,0,0, - 191,1,0,0,0,0,193,1,0,0,0,0,195,1,0,0,0,0,197,1,0,0,0,0,199,1,0, - 0,0,0,201,1,0,0,0,0,203,1,0,0,0,0,205,1,0,0,0,0,207,1,0,0,0,0,209, - 1,0,0,0,0,211,1,0,0,0,0,213,1,0,0,0,0,215,1,0,0,0,0,217,1,0,0,0, - 0,219,1,0,0,0,0,221,1,0,0,0,0,223,1,0,0,0,0,285,1,0,0,0,0,287,1, - 0,0,0,0,289,1,0,0,0,0,291,1,0,0,0,0,293,1,0,0,0,0,295,1,0,0,0,0, - 297,1,0,0,0,0,299,1,0,0,0,0,301,1,0,0,0,0,303,1,0,0,0,0,305,1,0, - 0,0,0,307,1,0,0,0,0,309,1,0,0,0,0,311,1,0,0,0,0,313,1,0,0,0,0,315, - 1,0,0,0,0,317,1,0,0,0,0,319,1,0,0,0,0,321,1,0,0,0,0,323,1,0,0,0, - 0,325,1,0,0,0,0,327,1,0,0,0,0,329,1,0,0,0,0,331,1,0,0,0,0,333,1, - 0,0,0,0,335,1,0,0,0,0,337,1,0,0,0,0,339,1,0,0,0,0,341,1,0,0,0,0, - 343,1,0,0,0,0,345,1,0,0,0,0,347,1,0,0,0,0,349,1,0,0,0,0,351,1,0, - 0,0,0,353,1,0,0,0,0,355,1,0,0,0,0,357,1,0,0,0,0,359,1,0,0,0,0,361, - 1,0,0,0,0,363,1,0,0,0,0,365,1,0,0,0,0,367,1,0,0,0,0,369,1,0,0,0, - 0,371,1,0,0,0,0,373,1,0,0,0,1,375,1,0,0,0,1,377,1,0,0,0,1,379,1, - 0,0,0,2,381,1,0,0,0,2,383,1,0,0,0,3,385,1,0,0,0,5,389,1,0,0,0,7, - 393,1,0,0,0,9,398,1,0,0,0,11,402,1,0,0,0,13,408,1,0,0,0,15,425,1, - 0,0,0,17,427,1,0,0,0,19,432,1,0,0,0,21,440,1,0,0,0,23,445,1,0,0, - 0,25,448,1,0,0,0,27,453,1,0,0,0,29,458,1,0,0,0,31,464,1,0,0,0,33, - 471,1,0,0,0,35,479,1,0,0,0,37,485,1,0,0,0,39,490,1,0,0,0,41,498, - 1,0,0,0,43,503,1,0,0,0,45,507,1,0,0,0,47,512,1,0,0,0,49,523,1,0, - 0,0,51,532,1,0,0,0,53,537,1,0,0,0,55,541,1,0,0,0,57,549,1,0,0,0, - 59,555,1,0,0,0,61,563,1,0,0,0,63,569,1,0,0,0,65,572,1,0,0,0,67,582, - 1,0,0,0,69,586,1,0,0,0,71,591,1,0,0,0,73,596,1,0,0,0,75,600,1,0, - 0,0,77,606,1,0,0,0,79,613,1,0,0,0,81,618,1,0,0,0,83,621,1,0,0,0, - 85,624,1,0,0,0,87,630,1,0,0,0,89,646,1,0,0,0,91,648,1,0,0,0,93,654, - 1,0,0,0,95,663,1,0,0,0,97,666,1,0,0,0,99,671,1,0,0,0,101,675,1,0, - 0,0,103,680,1,0,0,0,105,688,1,0,0,0,107,693,1,0,0,0,109,697,1,0, - 0,0,111,702,1,0,0,0,113,708,1,0,0,0,115,715,1,0,0,0,117,721,1,0, - 0,0,119,725,1,0,0,0,121,729,1,0,0,0,123,734,1,0,0,0,125,740,1,0, - 0,0,127,747,1,0,0,0,129,750,1,0,0,0,131,753,1,0,0,0,133,759,1,0, - 0,0,135,765,1,0,0,0,137,770,1,0,0,0,139,780,1,0,0,0,141,790,1,0, - 0,0,143,799,1,0,0,0,145,807,1,0,0,0,147,813,1,0,0,0,149,820,1,0, - 0,0,151,826,1,0,0,0,153,833,1,0,0,0,155,837,1,0,0,0,157,842,1,0, - 0,0,159,849,1,0,0,0,161,856,1,0,0,0,163,863,1,0,0,0,165,868,1,0, - 0,0,167,877,1,0,0,0,169,887,1,0,0,0,171,892,1,0,0,0,173,898,1,0, - 0,0,175,903,1,0,0,0,177,913,1,0,0,0,179,916,1,0,0,0,181,920,1,0, - 0,0,183,927,1,0,0,0,185,936,1,0,0,0,187,941,1,0,0,0,189,950,1,0, - 0,0,191,954,1,0,0,0,193,964,1,0,0,0,195,970,1,0,0,0,197,976,1,0, - 0,0,199,981,1,0,0,0,201,986,1,0,0,0,203,992,1,0,0,0,205,998,1,0, - 0,0,207,1005,1,0,0,0,209,1020,1,0,0,0,211,1049,1,0,0,0,213,1097, - 1,0,0,0,215,1175,1,0,0,0,217,1177,1,0,0,0,219,1184,1,0,0,0,221,1188, - 1,0,0,0,223,1195,1,0,0,0,225,1211,1,0,0,0,227,1213,1,0,0,0,229,1215, - 1,0,0,0,231,1217,1,0,0,0,233,1219,1,0,0,0,235,1221,1,0,0,0,237,1223, - 1,0,0,0,239,1225,1,0,0,0,241,1227,1,0,0,0,243,1229,1,0,0,0,245,1231, - 1,0,0,0,247,1233,1,0,0,0,249,1235,1,0,0,0,251,1237,1,0,0,0,253,1239, - 1,0,0,0,255,1241,1,0,0,0,257,1243,1,0,0,0,259,1245,1,0,0,0,261,1247, - 1,0,0,0,263,1249,1,0,0,0,265,1251,1,0,0,0,267,1253,1,0,0,0,269,1255, - 1,0,0,0,271,1257,1,0,0,0,273,1259,1,0,0,0,275,1261,1,0,0,0,277,1263, - 1,0,0,0,279,1265,1,0,0,0,281,1267,1,0,0,0,283,1269,1,0,0,0,285,1271, - 1,0,0,0,287,1274,1,0,0,0,289,1276,1,0,0,0,291,1278,1,0,0,0,293,1280, - 1,0,0,0,295,1282,1,0,0,0,297,1284,1,0,0,0,299,1287,1,0,0,0,301,1289, - 1,0,0,0,303,1291,1,0,0,0,305,1293,1,0,0,0,307,1296,1,0,0,0,309,1298, - 1,0,0,0,311,1301,1,0,0,0,313,1303,1,0,0,0,315,1305,1,0,0,0,317,1308, - 1,0,0,0,319,1312,1,0,0,0,321,1316,1,0,0,0,323,1318,1,0,0,0,325,1320, - 1,0,0,0,327,1323,1,0,0,0,329,1329,1,0,0,0,331,1331,1,0,0,0,333,1335, - 1,0,0,0,335,1338,1,0,0,0,337,1341,1,0,0,0,339,1344,1,0,0,0,341,1346, - 1,0,0,0,343,1348,1,0,0,0,345,1350,1,0,0,0,347,1352,1,0,0,0,349,1357, - 1,0,0,0,351,1362,1,0,0,0,353,1364,1,0,0,0,355,1366,1,0,0,0,357,1369, - 1,0,0,0,359,1373,1,0,0,0,361,1375,1,0,0,0,363,1377,1,0,0,0,365,1379, - 1,0,0,0,367,1381,1,0,0,0,369,1383,1,0,0,0,371,1401,1,0,0,0,373,1414, - 1,0,0,0,375,1429,1,0,0,0,377,1433,1,0,0,0,379,1437,1,0,0,0,381,1447, - 1,0,0,0,383,1451,1,0,0,0,385,386,3,225,111,0,386,387,3,247,122,0, - 387,388,3,247,122,0,388,4,1,0,0,0,389,390,3,225,111,0,390,391,3, - 251,124,0,391,392,3,231,114,0,392,6,1,0,0,0,393,394,3,225,111,0, - 394,395,3,251,124,0,395,396,3,263,130,0,396,397,3,241,119,0,397, - 8,1,0,0,0,398,399,3,225,111,0,399,400,3,251,124,0,400,401,3,273, - 135,0,401,10,1,0,0,0,402,403,3,225,111,0,403,404,3,259,128,0,404, - 405,3,259,128,0,405,406,3,225,111,0,406,407,3,273,135,0,407,12,1, - 0,0,0,408,409,3,225,111,0,409,410,3,261,129,0,410,14,1,0,0,0,411, - 412,3,225,111,0,412,413,3,261,129,0,413,414,3,229,113,0,414,426, - 1,0,0,0,415,416,3,225,111,0,416,417,3,261,129,0,417,418,3,229,113, - 0,418,419,3,233,115,0,419,420,3,251,124,0,420,421,3,231,114,0,421, - 422,3,241,119,0,422,423,3,251,124,0,423,424,3,237,117,0,424,426, - 1,0,0,0,425,411,1,0,0,0,425,415,1,0,0,0,426,16,1,0,0,0,427,428,3, - 225,111,0,428,429,3,261,129,0,429,430,3,253,125,0,430,431,3,235, - 116,0,431,18,1,0,0,0,432,433,3,227,112,0,433,434,3,233,115,0,434, - 435,3,263,130,0,435,436,3,269,133,0,436,437,3,233,115,0,437,438, - 3,233,115,0,438,439,3,251,124,0,439,20,1,0,0,0,440,441,3,227,112, - 0,441,442,3,253,125,0,442,443,3,263,130,0,443,444,3,239,118,0,444, - 22,1,0,0,0,445,446,3,227,112,0,446,447,3,273,135,0,447,24,1,0,0, - 0,448,449,3,229,113,0,449,450,3,225,111,0,450,451,3,261,129,0,451, - 452,3,233,115,0,452,26,1,0,0,0,453,454,3,229,113,0,454,455,3,225, - 111,0,455,456,3,261,129,0,456,457,3,263,130,0,457,28,1,0,0,0,458, - 459,3,229,113,0,459,460,3,225,111,0,460,461,3,263,130,0,461,462, - 3,229,113,0,462,463,3,239,118,0,463,30,1,0,0,0,464,465,3,229,113, - 0,465,466,3,253,125,0,466,467,3,239,118,0,467,468,3,253,125,0,468, - 469,3,259,128,0,469,470,3,263,130,0,470,32,1,0,0,0,471,472,3,229, - 113,0,472,473,3,253,125,0,473,474,3,247,122,0,474,475,3,247,122, - 0,475,476,3,225,111,0,476,477,3,263,130,0,477,478,3,233,115,0,478, - 34,1,0,0,0,479,480,3,229,113,0,480,481,3,259,128,0,481,482,3,253, - 125,0,482,483,3,261,129,0,483,484,3,261,129,0,484,36,1,0,0,0,485, - 486,3,229,113,0,486,487,3,265,131,0,487,488,3,227,112,0,488,489, - 3,233,115,0,489,38,1,0,0,0,490,491,3,229,113,0,491,492,3,265,131, - 0,492,493,3,259,128,0,493,494,3,259,128,0,494,495,3,233,115,0,495, - 496,3,251,124,0,496,497,3,263,130,0,497,40,1,0,0,0,498,499,3,231, - 114,0,499,500,3,225,111,0,500,501,3,263,130,0,501,502,3,233,115, - 0,502,42,1,0,0,0,503,504,3,231,114,0,504,505,3,225,111,0,505,506, - 3,273,135,0,506,44,1,0,0,0,507,508,3,231,114,0,508,509,3,233,115, - 0,509,510,3,261,129,0,510,511,3,229,113,0,511,46,1,0,0,0,512,513, - 3,231,114,0,513,514,3,233,115,0,514,515,3,261,129,0,515,516,3,229, - 113,0,516,517,3,233,115,0,517,518,3,251,124,0,518,519,3,231,114, - 0,519,520,3,241,119,0,520,521,3,251,124,0,521,522,3,237,117,0,522, - 48,1,0,0,0,523,524,3,231,114,0,524,525,3,241,119,0,525,526,3,261, - 129,0,526,527,3,263,130,0,527,528,3,241,119,0,528,529,3,251,124, - 0,529,530,3,229,113,0,530,531,3,263,130,0,531,50,1,0,0,0,532,533, - 3,233,115,0,533,534,3,247,122,0,534,535,3,261,129,0,535,536,3,233, - 115,0,536,52,1,0,0,0,537,538,3,233,115,0,538,539,3,251,124,0,539, - 540,3,231,114,0,540,54,1,0,0,0,541,542,3,233,115,0,542,543,3,271, - 134,0,543,544,3,263,130,0,544,545,3,259,128,0,545,546,3,225,111, - 0,546,547,3,229,113,0,547,548,3,263,130,0,548,56,1,0,0,0,549,550, - 3,235,116,0,550,551,3,241,119,0,551,552,3,251,124,0,552,553,3,225, - 111,0,553,554,3,247,122,0,554,58,1,0,0,0,555,556,3,235,116,0,556, - 557,3,241,119,0,557,558,3,251,124,0,558,559,3,225,111,0,559,560, - 3,247,122,0,560,561,3,247,122,0,561,562,3,273,135,0,562,60,1,0,0, - 0,563,564,3,235,116,0,564,565,3,241,119,0,565,566,3,259,128,0,566, - 567,3,261,129,0,567,568,3,263,130,0,568,62,1,0,0,0,569,570,3,235, - 116,0,570,571,3,251,124,0,571,64,1,0,0,0,572,573,3,235,116,0,573, - 574,3,253,125,0,574,575,3,247,122,0,575,576,3,247,122,0,576,577, - 3,253,125,0,577,578,3,269,133,0,578,579,3,241,119,0,579,580,3,251, - 124,0,580,581,3,237,117,0,581,66,1,0,0,0,582,583,3,235,116,0,583, - 584,3,253,125,0,584,585,3,259,128,0,585,68,1,0,0,0,586,587,3,235, - 116,0,587,588,3,259,128,0,588,589,3,253,125,0,589,590,3,249,123, - 0,590,70,1,0,0,0,591,592,3,235,116,0,592,593,3,265,131,0,593,594, - 3,247,122,0,594,595,3,247,122,0,595,72,1,0,0,0,596,597,3,235,116, - 0,597,598,3,265,131,0,598,599,3,251,124,0,599,74,1,0,0,0,600,601, - 3,237,117,0,601,602,3,259,128,0,602,603,3,253,125,0,603,604,3,265, - 131,0,604,605,3,255,126,0,605,76,1,0,0,0,606,607,3,239,118,0,607, - 608,3,225,111,0,608,609,3,267,132,0,609,610,3,241,119,0,610,611, - 3,251,124,0,611,612,3,237,117,0,612,78,1,0,0,0,613,614,3,239,118, - 0,614,615,3,253,125,0,615,616,3,265,131,0,616,617,3,259,128,0,617, - 80,1,0,0,0,618,619,3,241,119,0,619,620,3,231,114,0,620,82,1,0,0, - 0,621,622,3,241,119,0,622,623,3,235,116,0,623,84,1,0,0,0,624,625, - 3,241,119,0,625,626,3,247,122,0,626,627,3,241,119,0,627,628,3,245, - 121,0,628,629,3,233,115,0,629,86,1,0,0,0,630,631,3,241,119,0,631, - 632,3,251,124,0,632,88,1,0,0,0,633,634,3,241,119,0,634,635,3,251, - 124,0,635,636,3,235,116,0,636,647,1,0,0,0,637,638,3,241,119,0,638, - 639,3,251,124,0,639,640,3,235,116,0,640,641,3,241,119,0,641,642, - 3,251,124,0,642,643,3,241,119,0,643,644,3,263,130,0,644,645,3,273, - 135,0,645,647,1,0,0,0,646,633,1,0,0,0,646,637,1,0,0,0,647,90,1,0, - 0,0,648,649,3,241,119,0,649,650,3,251,124,0,650,651,3,251,124,0, - 651,652,3,233,115,0,652,653,3,259,128,0,653,92,1,0,0,0,654,655,3, - 241,119,0,655,656,3,251,124,0,656,657,3,263,130,0,657,658,3,233, - 115,0,658,659,3,259,128,0,659,660,3,267,132,0,660,661,3,225,111, - 0,661,662,3,247,122,0,662,94,1,0,0,0,663,664,3,241,119,0,664,665, - 3,261,129,0,665,96,1,0,0,0,666,667,3,243,120,0,667,668,3,253,125, - 0,668,669,3,241,119,0,669,670,3,251,124,0,670,98,1,0,0,0,671,672, - 3,245,121,0,672,673,3,233,115,0,673,674,3,273,135,0,674,100,1,0, - 0,0,675,676,3,247,122,0,676,677,3,225,111,0,677,678,3,261,129,0, - 678,679,3,263,130,0,679,102,1,0,0,0,680,681,3,247,122,0,681,682, - 3,233,115,0,682,683,3,225,111,0,683,684,3,231,114,0,684,685,3,241, - 119,0,685,686,3,251,124,0,686,687,3,237,117,0,687,104,1,0,0,0,688, - 689,3,247,122,0,689,690,3,233,115,0,690,691,3,235,116,0,691,692, - 3,263,130,0,692,106,1,0,0,0,693,694,3,247,122,0,694,695,3,233,115, - 0,695,696,3,263,130,0,696,108,1,0,0,0,697,698,3,247,122,0,698,699, - 3,241,119,0,699,700,3,245,121,0,700,701,3,233,115,0,701,110,1,0, - 0,0,702,703,3,247,122,0,703,704,3,241,119,0,704,705,3,249,123,0, - 705,706,3,241,119,0,706,707,3,263,130,0,707,112,1,0,0,0,708,709, - 3,249,123,0,709,710,3,241,119,0,710,711,3,251,124,0,711,712,3,265, - 131,0,712,713,3,263,130,0,713,714,3,233,115,0,714,114,1,0,0,0,715, - 716,3,249,123,0,716,717,3,253,125,0,717,718,3,251,124,0,718,719, - 3,263,130,0,719,720,3,239,118,0,720,116,1,0,0,0,721,722,3,251,124, - 0,722,723,3,225,111,0,723,724,3,251,124,0,724,118,1,0,0,0,725,726, - 3,251,124,0,726,727,3,253,125,0,727,728,3,263,130,0,728,120,1,0, - 0,0,729,730,3,251,124,0,730,731,3,265,131,0,731,732,3,247,122,0, - 732,733,3,247,122,0,733,122,1,0,0,0,734,735,3,251,124,0,735,736, - 3,265,131,0,736,737,3,247,122,0,737,738,3,247,122,0,738,739,3,261, - 129,0,739,124,1,0,0,0,740,741,3,253,125,0,741,742,3,235,116,0,742, - 743,3,235,116,0,743,744,3,261,129,0,744,745,3,233,115,0,745,746, - 3,263,130,0,746,126,1,0,0,0,747,748,3,253,125,0,748,749,3,251,124, - 0,749,128,1,0,0,0,750,751,3,253,125,0,751,752,3,259,128,0,752,130, - 1,0,0,0,753,754,3,253,125,0,754,755,3,259,128,0,755,756,3,231,114, - 0,756,757,3,233,115,0,757,758,3,259,128,0,758,132,1,0,0,0,759,760, - 3,253,125,0,760,761,3,265,131,0,761,762,3,263,130,0,762,763,3,233, - 115,0,763,764,3,259,128,0,764,134,1,0,0,0,765,766,3,253,125,0,766, - 767,3,267,132,0,767,768,3,233,115,0,768,769,3,259,128,0,769,136, - 1,0,0,0,770,771,3,255,126,0,771,772,3,225,111,0,772,773,3,259,128, - 0,773,774,3,263,130,0,774,775,3,241,119,0,775,776,3,263,130,0,776, - 777,3,241,119,0,777,778,3,253,125,0,778,779,3,251,124,0,779,138, - 1,0,0,0,780,781,3,255,126,0,781,782,3,259,128,0,782,783,3,233,115, - 0,783,784,3,229,113,0,784,785,3,233,115,0,785,786,3,231,114,0,786, - 787,3,241,119,0,787,788,3,251,124,0,788,789,3,237,117,0,789,140, - 1,0,0,0,790,791,3,255,126,0,791,792,3,259,128,0,792,793,3,233,115, - 0,793,794,3,269,133,0,794,795,3,239,118,0,795,796,3,233,115,0,796, - 797,3,259,128,0,797,798,3,233,115,0,798,142,1,0,0,0,799,800,3,257, - 127,0,800,801,3,265,131,0,801,802,3,225,111,0,802,803,3,259,128, - 0,803,804,3,263,130,0,804,805,3,233,115,0,805,806,3,259,128,0,806, - 144,1,0,0,0,807,808,3,259,128,0,808,809,3,225,111,0,809,810,3,251, - 124,0,810,811,3,237,117,0,811,812,3,233,115,0,812,146,1,0,0,0,813, - 814,3,259,128,0,814,815,3,233,115,0,815,816,3,263,130,0,816,817, - 3,265,131,0,817,818,3,259,128,0,818,819,3,251,124,0,819,148,1,0, - 0,0,820,821,3,259,128,0,821,822,3,241,119,0,822,823,3,237,117,0, - 823,824,3,239,118,0,824,825,3,263,130,0,825,150,1,0,0,0,826,827, - 3,259,128,0,827,828,3,253,125,0,828,829,3,247,122,0,829,830,3,247, - 122,0,830,831,3,265,131,0,831,832,3,255,126,0,832,152,1,0,0,0,833, - 834,3,259,128,0,834,835,3,253,125,0,835,836,3,269,133,0,836,154, - 1,0,0,0,837,838,3,259,128,0,838,839,3,253,125,0,839,840,3,269,133, - 0,840,841,3,261,129,0,841,156,1,0,0,0,842,843,3,261,129,0,843,844, - 3,225,111,0,844,845,3,249,123,0,845,846,3,255,126,0,846,847,3,247, - 122,0,847,848,3,233,115,0,848,158,1,0,0,0,849,850,3,261,129,0,850, - 851,3,233,115,0,851,852,3,229,113,0,852,853,3,253,125,0,853,854, - 3,251,124,0,854,855,3,231,114,0,855,160,1,0,0,0,856,857,3,261,129, - 0,857,858,3,233,115,0,858,859,3,247,122,0,859,860,3,233,115,0,860, - 861,3,229,113,0,861,862,3,263,130,0,862,162,1,0,0,0,863,864,3,261, - 129,0,864,865,3,233,115,0,865,866,3,249,123,0,866,867,3,241,119, - 0,867,164,1,0,0,0,868,869,3,261,129,0,869,870,3,233,115,0,870,871, - 3,263,130,0,871,872,3,263,130,0,872,873,3,241,119,0,873,874,3,251, - 124,0,874,875,3,237,117,0,875,876,3,261,129,0,876,166,1,0,0,0,877, - 878,3,261,129,0,878,879,3,265,131,0,879,880,3,227,112,0,880,881, - 3,261,129,0,881,882,3,263,130,0,882,883,3,259,128,0,883,884,3,241, - 119,0,884,885,3,251,124,0,885,886,3,237,117,0,886,168,1,0,0,0,887, - 888,3,263,130,0,888,889,3,239,118,0,889,890,3,233,115,0,890,891, - 3,251,124,0,891,170,1,0,0,0,892,893,3,263,130,0,893,894,3,239,118, - 0,894,895,3,259,128,0,895,896,3,253,125,0,896,897,3,269,133,0,897, - 172,1,0,0,0,898,899,3,263,130,0,899,900,3,241,119,0,900,901,3,233, - 115,0,901,902,3,261,129,0,902,174,1,0,0,0,903,904,3,263,130,0,904, - 905,3,241,119,0,905,906,3,249,123,0,906,907,3,233,115,0,907,908, - 3,261,129,0,908,909,3,263,130,0,909,910,3,225,111,0,910,911,3,249, - 123,0,911,912,3,255,126,0,912,176,1,0,0,0,913,914,3,263,130,0,914, - 915,3,253,125,0,915,178,1,0,0,0,916,917,3,263,130,0,917,918,3,253, - 125,0,918,919,3,255,126,0,919,180,1,0,0,0,920,921,3,263,130,0,921, - 922,3,253,125,0,922,923,3,263,130,0,923,924,3,225,111,0,924,925, - 3,247,122,0,925,926,3,261,129,0,926,182,1,0,0,0,927,928,3,263,130, - 0,928,929,3,259,128,0,929,930,3,225,111,0,930,931,3,241,119,0,931, - 932,3,247,122,0,932,933,3,241,119,0,933,934,3,251,124,0,934,935, - 3,237,117,0,935,184,1,0,0,0,936,937,3,263,130,0,937,938,3,259,128, - 0,938,939,3,241,119,0,939,940,3,249,123,0,940,186,1,0,0,0,941,942, - 3,263,130,0,942,943,3,259,128,0,943,944,3,265,131,0,944,945,3,251, - 124,0,945,946,3,229,113,0,946,947,3,225,111,0,947,948,3,263,130, - 0,948,949,3,233,115,0,949,188,1,0,0,0,950,951,3,263,130,0,951,952, - 3,259,128,0,952,953,3,273,135,0,953,190,1,0,0,0,954,955,3,265,131, - 0,955,956,3,251,124,0,956,957,3,227,112,0,957,958,3,253,125,0,958, - 959,3,265,131,0,959,960,3,251,124,0,960,961,3,231,114,0,961,962, - 3,233,115,0,962,963,3,231,114,0,963,192,1,0,0,0,964,965,3,265,131, - 0,965,966,3,251,124,0,966,967,3,241,119,0,967,968,3,253,125,0,968, - 969,3,251,124,0,969,194,1,0,0,0,970,971,3,265,131,0,971,972,3,261, - 129,0,972,973,3,241,119,0,973,974,3,251,124,0,974,975,3,237,117, - 0,975,196,1,0,0,0,976,977,3,269,133,0,977,978,3,233,115,0,978,979, - 3,233,115,0,979,980,3,245,121,0,980,198,1,0,0,0,981,982,3,269,133, - 0,982,983,3,239,118,0,983,984,3,233,115,0,984,985,3,251,124,0,985, - 200,1,0,0,0,986,987,3,269,133,0,987,988,3,239,118,0,988,989,3,233, - 115,0,989,990,3,259,128,0,990,991,3,233,115,0,991,202,1,0,0,0,992, - 993,3,269,133,0,993,994,3,239,118,0,994,995,3,241,119,0,995,996, - 3,247,122,0,996,997,3,233,115,0,997,204,1,0,0,0,998,999,3,269,133, - 0,999,1000,3,241,119,0,1000,1001,3,251,124,0,1001,1002,3,231,114, - 0,1002,1003,3,253,125,0,1003,1004,3,269,133,0,1004,206,1,0,0,0,1005, - 1006,3,269,133,0,1006,1007,3,241,119,0,1007,1008,3,263,130,0,1008, - 1009,3,239,118,0,1009,208,1,0,0,0,1010,1011,3,273,135,0,1011,1012, - 3,233,115,0,1012,1013,3,225,111,0,1013,1014,3,259,128,0,1014,1021, - 1,0,0,0,1015,1016,3,273,135,0,1016,1017,3,273,135,0,1017,1018,3, - 273,135,0,1018,1019,3,273,135,0,1019,1021,1,0,0,0,1020,1010,1,0, - 0,0,1020,1015,1,0,0,0,1021,210,1,0,0,0,1022,1023,3,291,144,0,1023, - 1024,3,227,112,0,1024,1050,1,0,0,0,1025,1026,3,291,144,0,1026,1027, - 3,235,116,0,1027,1050,1,0,0,0,1028,1029,3,291,144,0,1029,1030,3, - 259,128,0,1030,1050,1,0,0,0,1031,1032,3,291,144,0,1032,1033,3,251, - 124,0,1033,1050,1,0,0,0,1034,1035,3,291,144,0,1035,1036,3,263,130, - 0,1036,1050,1,0,0,0,1037,1038,3,291,144,0,1038,1039,5,48,0,0,1039, - 1050,1,0,0,0,1040,1041,3,291,144,0,1041,1042,3,225,111,0,1042,1050, - 1,0,0,0,1043,1044,3,291,144,0,1044,1045,3,267,132,0,1045,1050,1, - 0,0,0,1046,1047,3,291,144,0,1047,1048,3,291,144,0,1048,1050,1,0, - 0,0,1049,1022,1,0,0,0,1049,1025,1,0,0,0,1049,1028,1,0,0,0,1049,1031, - 1,0,0,0,1049,1034,1,0,0,0,1049,1037,1,0,0,0,1049,1040,1,0,0,0,1049, - 1043,1,0,0,0,1049,1046,1,0,0,0,1050,212,1,0,0,0,1051,1055,3,277, - 137,0,1052,1055,3,367,182,0,1053,1055,3,301,149,0,1054,1051,1,0, - 0,0,1054,1052,1,0,0,0,1054,1053,1,0,0,0,1055,1062,1,0,0,0,1056,1061, - 3,277,137,0,1057,1061,3,367,182,0,1058,1061,3,281,139,0,1059,1061, - 3,301,149,0,1060,1056,1,0,0,0,1060,1057,1,0,0,0,1060,1058,1,0,0, - 0,1060,1059,1,0,0,0,1061,1064,1,0,0,0,1062,1060,1,0,0,0,1062,1063, - 1,0,0,0,1063,1098,1,0,0,0,1064,1062,1,0,0,0,1065,1076,3,289,143, - 0,1066,1075,8,0,0,0,1067,1075,3,211,104,0,1068,1069,3,291,144,0, - 1069,1070,3,351,174,0,1070,1075,1,0,0,0,1071,1072,3,289,143,0,1072, - 1073,3,289,143,0,1073,1075,1,0,0,0,1074,1066,1,0,0,0,1074,1067,1, - 0,0,0,1074,1068,1,0,0,0,1074,1071,1,0,0,0,1075,1078,1,0,0,0,1076, - 1074,1,0,0,0,1076,1077,1,0,0,0,1077,1079,1,0,0,0,1078,1076,1,0,0, - 0,1079,1080,3,289,143,0,1080,1098,1,0,0,0,1081,1092,3,345,171,0, - 1082,1091,8,1,0,0,1083,1091,3,211,104,0,1084,1085,3,291,144,0,1085, - 1086,3,345,171,0,1086,1091,1,0,0,0,1087,1088,3,345,171,0,1088,1089, - 3,345,171,0,1089,1091,1,0,0,0,1090,1082,1,0,0,0,1090,1083,1,0,0, - 0,1090,1084,1,0,0,0,1090,1087,1,0,0,0,1091,1094,1,0,0,0,1092,1090, - 1,0,0,0,1092,1093,1,0,0,0,1093,1095,1,0,0,0,1094,1092,1,0,0,0,1095, - 1096,3,345,171,0,1096,1098,1,0,0,0,1097,1054,1,0,0,0,1097,1065,1, - 0,0,0,1097,1081,1,0,0,0,1098,214,1,0,0,0,1099,1100,3,221,109,0,1100, - 1104,3,303,150,0,1101,1103,3,283,140,0,1102,1101,1,0,0,0,1103,1106, - 1,0,0,0,1104,1102,1,0,0,0,1104,1105,1,0,0,0,1105,1109,1,0,0,0,1106, - 1104,1,0,0,0,1107,1110,3,255,126,0,1108,1110,3,233,115,0,1109,1107, - 1,0,0,0,1109,1108,1,0,0,0,1110,1113,1,0,0,0,1111,1114,3,341,169, - 0,1112,1114,3,299,148,0,1113,1111,1,0,0,0,1113,1112,1,0,0,0,1113, - 1114,1,0,0,0,1114,1116,1,0,0,0,1115,1117,3,281,139,0,1116,1115,1, - 0,0,0,1117,1118,1,0,0,0,1118,1116,1,0,0,0,1118,1119,1,0,0,0,1119, - 1176,1,0,0,0,1120,1123,3,221,109,0,1121,1124,3,255,126,0,1122,1124, - 3,233,115,0,1123,1121,1,0,0,0,1123,1122,1,0,0,0,1124,1127,1,0,0, - 0,1125,1128,3,341,169,0,1126,1128,3,299,148,0,1127,1125,1,0,0,0, - 1127,1126,1,0,0,0,1127,1128,1,0,0,0,1128,1130,1,0,0,0,1129,1131, - 3,281,139,0,1130,1129,1,0,0,0,1131,1132,1,0,0,0,1132,1130,1,0,0, - 0,1132,1133,1,0,0,0,1133,1176,1,0,0,0,1134,1135,3,219,108,0,1135, - 1139,3,303,150,0,1136,1138,3,281,139,0,1137,1136,1,0,0,0,1138,1141, - 1,0,0,0,1139,1137,1,0,0,0,1139,1140,1,0,0,0,1140,1142,1,0,0,0,1141, - 1139,1,0,0,0,1142,1145,3,233,115,0,1143,1146,3,341,169,0,1144,1146, - 3,299,148,0,1145,1143,1,0,0,0,1145,1144,1,0,0,0,1145,1146,1,0,0, - 0,1146,1148,1,0,0,0,1147,1149,3,281,139,0,1148,1147,1,0,0,0,1149, - 1150,1,0,0,0,1150,1148,1,0,0,0,1150,1151,1,0,0,0,1151,1176,1,0,0, - 0,1152,1153,3,303,150,0,1153,1154,3,219,108,0,1154,1157,3,233,115, - 0,1155,1158,3,341,169,0,1156,1158,3,299,148,0,1157,1155,1,0,0,0, - 1157,1156,1,0,0,0,1157,1158,1,0,0,0,1158,1160,1,0,0,0,1159,1161, - 3,281,139,0,1160,1159,1,0,0,0,1161,1162,1,0,0,0,1162,1160,1,0,0, - 0,1162,1163,1,0,0,0,1163,1176,1,0,0,0,1164,1165,3,219,108,0,1165, - 1168,3,233,115,0,1166,1169,3,341,169,0,1167,1169,3,299,148,0,1168, - 1166,1,0,0,0,1168,1167,1,0,0,0,1168,1169,1,0,0,0,1169,1171,1,0,0, - 0,1170,1172,3,281,139,0,1171,1170,1,0,0,0,1172,1173,1,0,0,0,1173, - 1171,1,0,0,0,1173,1174,1,0,0,0,1174,1176,1,0,0,0,1175,1099,1,0,0, - 0,1175,1120,1,0,0,0,1175,1134,1,0,0,0,1175,1152,1,0,0,0,1175,1164, - 1,0,0,0,1176,216,1,0,0,0,1177,1179,5,48,0,0,1178,1180,3,279,138, - 0,1179,1178,1,0,0,0,1180,1181,1,0,0,0,1181,1179,1,0,0,0,1181,1182, - 1,0,0,0,1182,218,1,0,0,0,1183,1185,3,281,139,0,1184,1183,1,0,0,0, - 1185,1186,1,0,0,0,1186,1184,1,0,0,0,1186,1187,1,0,0,0,1187,220,1, - 0,0,0,1188,1189,5,48,0,0,1189,1191,3,271,134,0,1190,1192,3,283,140, - 0,1191,1190,1,0,0,0,1192,1193,1,0,0,0,1193,1191,1,0,0,0,1193,1194, - 1,0,0,0,1194,222,1,0,0,0,1195,1206,3,351,174,0,1196,1205,8,2,0,0, - 1197,1205,3,211,104,0,1198,1199,3,291,144,0,1199,1200,3,351,174, - 0,1200,1205,1,0,0,0,1201,1202,3,351,174,0,1202,1203,3,351,174,0, - 1203,1205,1,0,0,0,1204,1196,1,0,0,0,1204,1197,1,0,0,0,1204,1198, - 1,0,0,0,1204,1201,1,0,0,0,1205,1208,1,0,0,0,1206,1204,1,0,0,0,1206, - 1207,1,0,0,0,1207,1209,1,0,0,0,1208,1206,1,0,0,0,1209,1210,3,351, - 174,0,1210,224,1,0,0,0,1211,1212,7,3,0,0,1212,226,1,0,0,0,1213,1214, - 7,4,0,0,1214,228,1,0,0,0,1215,1216,7,5,0,0,1216,230,1,0,0,0,1217, - 1218,7,6,0,0,1218,232,1,0,0,0,1219,1220,7,7,0,0,1220,234,1,0,0,0, - 1221,1222,7,8,0,0,1222,236,1,0,0,0,1223,1224,7,9,0,0,1224,238,1, - 0,0,0,1225,1226,7,10,0,0,1226,240,1,0,0,0,1227,1228,7,11,0,0,1228, - 242,1,0,0,0,1229,1230,7,12,0,0,1230,244,1,0,0,0,1231,1232,7,13,0, - 0,1232,246,1,0,0,0,1233,1234,7,14,0,0,1234,248,1,0,0,0,1235,1236, - 7,15,0,0,1236,250,1,0,0,0,1237,1238,7,16,0,0,1238,252,1,0,0,0,1239, - 1240,7,17,0,0,1240,254,1,0,0,0,1241,1242,7,18,0,0,1242,256,1,0,0, - 0,1243,1244,7,19,0,0,1244,258,1,0,0,0,1245,1246,7,20,0,0,1246,260, - 1,0,0,0,1247,1248,7,21,0,0,1248,262,1,0,0,0,1249,1250,7,22,0,0,1250, - 264,1,0,0,0,1251,1252,7,23,0,0,1252,266,1,0,0,0,1253,1254,7,24,0, - 0,1254,268,1,0,0,0,1255,1256,7,25,0,0,1256,270,1,0,0,0,1257,1258, - 7,26,0,0,1258,272,1,0,0,0,1259,1260,7,27,0,0,1260,274,1,0,0,0,1261, - 1262,7,28,0,0,1262,276,1,0,0,0,1263,1264,7,29,0,0,1264,278,1,0,0, - 0,1265,1266,7,30,0,0,1266,280,1,0,0,0,1267,1268,7,31,0,0,1268,282, - 1,0,0,0,1269,1270,7,32,0,0,1270,284,1,0,0,0,1271,1272,5,45,0,0,1272, - 1273,5,62,0,0,1273,286,1,0,0,0,1274,1275,5,42,0,0,1275,288,1,0,0, - 0,1276,1277,5,96,0,0,1277,290,1,0,0,0,1278,1279,5,92,0,0,1279,292, - 1,0,0,0,1280,1281,5,58,0,0,1281,294,1,0,0,0,1282,1283,5,44,0,0,1283, - 296,1,0,0,0,1284,1285,5,124,0,0,1285,1286,5,124,0,0,1286,298,1,0, - 0,0,1287,1288,5,45,0,0,1288,300,1,0,0,0,1289,1290,5,36,0,0,1290, - 302,1,0,0,0,1291,1292,5,46,0,0,1292,304,1,0,0,0,1293,1294,5,61,0, - 0,1294,1295,5,61,0,0,1295,306,1,0,0,0,1296,1297,5,61,0,0,1297,308, - 1,0,0,0,1298,1299,5,62,0,0,1299,1300,5,61,0,0,1300,310,1,0,0,0,1301, - 1302,5,62,0,0,1302,312,1,0,0,0,1303,1304,5,35,0,0,1304,314,1,0,0, - 0,1305,1306,5,126,0,0,1306,1307,5,42,0,0,1307,316,1,0,0,0,1308,1309, - 5,61,0,0,1309,1310,5,126,0,0,1310,1311,5,42,0,0,1311,318,1,0,0,0, - 1312,1313,5,123,0,0,1313,1314,1,0,0,0,1314,1315,6,158,0,0,1315,320, - 1,0,0,0,1316,1317,5,91,0,0,1317,322,1,0,0,0,1318,1319,5,40,0,0,1319, - 324,1,0,0,0,1320,1321,5,60,0,0,1321,1322,5,61,0,0,1322,326,1,0,0, - 0,1323,1324,5,60,0,0,1324,328,1,0,0,0,1325,1326,5,33,0,0,1326,1330, - 5,61,0,0,1327,1328,5,60,0,0,1328,1330,5,62,0,0,1329,1325,1,0,0,0, - 1329,1327,1,0,0,0,1330,330,1,0,0,0,1331,1332,5,33,0,0,1332,1333, - 5,126,0,0,1333,1334,5,42,0,0,1334,332,1,0,0,0,1335,1336,5,33,0,0, - 1336,1337,5,126,0,0,1337,334,1,0,0,0,1338,1339,5,63,0,0,1339,1340, - 5,46,0,0,1340,336,1,0,0,0,1341,1342,5,63,0,0,1342,1343,5,63,0,0, - 1343,338,1,0,0,0,1344,1345,5,37,0,0,1345,340,1,0,0,0,1346,1347,5, - 43,0,0,1347,342,1,0,0,0,1348,1349,5,63,0,0,1349,344,1,0,0,0,1350, - 1351,5,34,0,0,1351,346,1,0,0,0,1352,1353,5,102,0,0,1353,1354,5,39, - 0,0,1354,1355,1,0,0,0,1355,1356,6,172,1,0,1356,348,1,0,0,0,1357, - 1358,5,70,0,0,1358,1359,5,39,0,0,1359,1360,1,0,0,0,1360,1361,6,173, - 2,0,1361,350,1,0,0,0,1362,1363,5,39,0,0,1363,352,1,0,0,0,1364,1365, - 5,126,0,0,1365,354,1,0,0,0,1366,1367,5,61,0,0,1367,1368,5,126,0, - 0,1368,356,1,0,0,0,1369,1370,5,125,0,0,1370,1371,1,0,0,0,1371,1372, - 6,177,3,0,1372,358,1,0,0,0,1373,1374,5,93,0,0,1374,360,1,0,0,0,1375, - 1376,5,41,0,0,1376,362,1,0,0,0,1377,1378,5,59,0,0,1378,364,1,0,0, - 0,1379,1380,5,47,0,0,1380,366,1,0,0,0,1381,1382,5,95,0,0,1382,368, - 1,0,0,0,1383,1384,5,47,0,0,1384,1385,5,42,0,0,1385,1389,1,0,0,0, - 1386,1388,9,0,0,0,1387,1386,1,0,0,0,1388,1391,1,0,0,0,1389,1390, - 1,0,0,0,1389,1387,1,0,0,0,1390,1392,1,0,0,0,1391,1389,1,0,0,0,1392, - 1393,5,42,0,0,1393,1394,5,47,0,0,1394,1395,1,0,0,0,1395,1396,6,183, - 4,0,1396,370,1,0,0,0,1397,1398,5,45,0,0,1398,1402,5,45,0,0,1399, - 1400,5,47,0,0,1400,1402,5,47,0,0,1401,1397,1,0,0,0,1401,1399,1,0, - 0,0,1402,1406,1,0,0,0,1403,1405,8,33,0,0,1404,1403,1,0,0,0,1405, - 1408,1,0,0,0,1406,1404,1,0,0,0,1406,1407,1,0,0,0,1407,1410,1,0,0, - 0,1408,1406,1,0,0,0,1409,1411,7,34,0,0,1410,1409,1,0,0,0,1411,1412, - 1,0,0,0,1412,1413,6,184,4,0,1413,372,1,0,0,0,1414,1415,7,35,0,0, - 1415,1416,1,0,0,0,1416,1417,6,185,5,0,1417,374,1,0,0,0,1418,1430, - 8,36,0,0,1419,1430,3,211,104,0,1420,1421,3,291,144,0,1421,1422,3, - 351,174,0,1422,1430,1,0,0,0,1423,1424,3,291,144,0,1424,1425,3,319, - 158,0,1425,1430,1,0,0,0,1426,1427,3,351,174,0,1427,1428,3,351,174, - 0,1428,1430,1,0,0,0,1429,1418,1,0,0,0,1429,1419,1,0,0,0,1429,1420, - 1,0,0,0,1429,1423,1,0,0,0,1429,1426,1,0,0,0,1430,1431,1,0,0,0,1431, - 1429,1,0,0,0,1431,1432,1,0,0,0,1432,376,1,0,0,0,1433,1434,3,319, - 158,0,1434,1435,1,0,0,0,1435,1436,6,187,0,0,1436,378,1,0,0,0,1437, - 1438,3,351,174,0,1438,1439,1,0,0,0,1439,1440,6,188,6,0,1440,1441, - 6,188,3,0,1441,380,1,0,0,0,1442,1448,8,37,0,0,1443,1448,3,211,104, - 0,1444,1445,3,291,144,0,1445,1446,3,319,158,0,1446,1448,1,0,0,0, - 1447,1442,1,0,0,0,1447,1443,1,0,0,0,1447,1444,1,0,0,0,1448,1449, - 1,0,0,0,1449,1447,1,0,0,0,1449,1450,1,0,0,0,1450,382,1,0,0,0,1451, - 1452,3,319,158,0,1452,1453,1,0,0,0,1453,1454,6,190,0,0,1454,384, - 1,0,0,0,44,0,1,2,425,646,1020,1049,1054,1060,1062,1074,1076,1090, - 1092,1097,1104,1109,1113,1118,1123,1127,1132,1139,1145,1150,1157, - 1162,1168,1173,1175,1181,1186,1193,1204,1206,1329,1389,1401,1406, - 1410,1429,1431,1447,1449,7,5,0,0,5,1,0,5,2,0,4,0,0,6,0,0,0,1,0,7, - 145,0 + 7,190,2,191,7,191,2,192,7,192,1,0,1,0,1,0,1,0,1,1,1,1,1,1,1,1,1, + 2,1,2,1,2,1,2,1,2,1,3,1,3,1,3,1,3,1,4,1,4,1,4,1,4,1,4,1,4,1,5,1, + 5,1,5,1,6,1,6,1,6,1,6,1,6,1,6,1,6,1,6,1,6,1,6,1,6,1,6,1,6,1,6,3, + 6,430,8,6,1,7,1,7,1,7,1,7,1,7,1,8,1,8,1,8,1,8,1,8,1,8,1,8,1,8,1, + 9,1,9,1,9,1,9,1,9,1,10,1,10,1,10,1,11,1,11,1,11,1,11,1,11,1,12,1, + 12,1,12,1,12,1,12,1,13,1,13,1,13,1,13,1,13,1,13,1,14,1,14,1,14,1, + 14,1,14,1,14,1,14,1,15,1,15,1,15,1,15,1,15,1,15,1,15,1,15,1,16,1, + 16,1,16,1,16,1,16,1,16,1,17,1,17,1,17,1,17,1,17,1,18,1,18,1,18,1, + 18,1,18,1,18,1,18,1,18,1,19,1,19,1,19,1,19,1,19,1,20,1,20,1,20,1, + 20,1,21,1,21,1,21,1,21,1,21,1,22,1,22,1,22,1,22,1,22,1,22,1,22,1, + 22,1,22,1,22,1,22,1,23,1,23,1,23,1,23,1,23,1,23,1,23,1,23,1,23,1, + 24,1,24,1,24,1,24,1,24,1,25,1,25,1,25,1,25,1,26,1,26,1,26,1,26,1, + 26,1,26,1,26,1,27,1,27,1,27,1,27,1,27,1,27,1,27,1,27,1,28,1,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,30,1, + 30,1,30,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,1,32,1,32,1,33,1,33,1,33,1,33,1,34,1,34,1,34,1,34,1, + 34,1,35,1,35,1,35,1,35,1,35,1,36,1,36,1,36,1,36,1,37,1,37,1,37,1, + 37,1,37,1,37,1,38,1,38,1,38,1,38,1,38,1,38,1,38,1,39,1,39,1,39,1, + 39,1,39,1,40,1,40,1,40,1,41,1,41,1,41,1,42,1,42,1,42,1,42,1,42,1, + 42,1,43,1,43,1,43,1,44,1,44,1,44,1,44,1,44,1,44,1,44,1,44,1,44,1, + 44,1,44,1,44,1,44,3,44,658,8,44,1,45,1,45,1,45,1,45,1,45,1,45,1, + 46,1,46,1,46,1,46,1,46,1,46,1,46,1,46,1,46,1,46,1,47,1,47,1,47,1, + 47,1,47,1,47,1,47,1,47,1,47,1,48,1,48,1,48,1,49,1,49,1,49,1,49,1, + 49,1,50,1,50,1,50,1,50,1,51,1,51,1,51,1,51,1,51,1,52,1,52,1,52,1, + 52,1,52,1,52,1,52,1,52,1,53,1,53,1,53,1,53,1,53,1,54,1,54,1,54,1, + 54,1,55,1,55,1,55,1,55,1,55,1,56,1,56,1,56,1,56,1,56,1,56,1,57,1, + 57,1,57,1,57,1,57,1,57,1,57,1,58,1,58,1,58,1,58,1,58,1,58,1,59,1, + 59,1,59,1,59,1,60,1,60,1,60,1,60,1,61,1,61,1,61,1,61,1,61,1,62,1, + 62,1,62,1,62,1,62,1,62,1,63,1,63,1,63,1,63,1,63,1,63,1,63,1,64,1, + 64,1,64,1,65,1,65,1,65,1,66,1,66,1,66,1,66,1,66,1,66,1,67,1,67,1, + 67,1,67,1,67,1,67,1,68,1,68,1,68,1,68,1,68,1,69,1,69,1,69,1,69,1, + 69,1,69,1,69,1,69,1,69,1,69,1,70,1,70,1,70,1,70,1,70,1,70,1,70,1, + 70,1,70,1,70,1,71,1,71,1,71,1,71,1,71,1,71,1,71,1,71,1,71,1,72,1, + 72,1,72,1,72,1,72,1,72,1,72,1,72,1,73,1,73,1,73,1,73,1,73,1,73,1, + 74,1,74,1,74,1,74,1,74,1,74,1,74,1,75,1,75,1,75,1,75,1,75,1,75,1, + 76,1,76,1,76,1,76,1,76,1,76,1,76,1,77,1,77,1,77,1,77,1,78,1,78,1, + 78,1,78,1,78,1,79,1,79,1,79,1,79,1,79,1,79,1,79,1,80,1,80,1,80,1, + 80,1,80,1,80,1,80,1,81,1,81,1,81,1,81,1,81,1,81,1,81,1,82,1,82,1, + 82,1,82,1,82,1,83,1,83,1,83,1,83,1,83,1,83,1,83,1,83,1,83,1,84,1, + 84,1,84,1,84,1,84,1,84,1,84,1,84,1,84,1,84,1,85,1,85,1,85,1,85,1, + 85,1,86,1,86,1,86,1,86,1,86,1,86,1,87,1,87,1,87,1,87,1,87,1,88,1, + 88,1,88,1,88,1,88,1,88,1,88,1,88,1,88,1,88,1,89,1,89,1,89,1,90,1, + 90,1,90,1,90,1,91,1,91,1,91,1,91,1,91,1,91,1,91,1,92,1,92,1,92,1, + 92,1,92,1,92,1,92,1,92,1,92,1,93,1,93,1,93,1,93,1,93,1,94,1,94,1, + 94,1,94,1,94,1,94,1,94,1,94,1,94,1,95,1,95,1,95,1,95,1,96,1,96,1, + 96,1,96,1,96,1,96,1,96,1,96,1,96,1,96,1,97,1,97,1,97,1,97,1,97,1, + 97,1,98,1,98,1,98,1,98,1,98,1,98,1,99,1,99,1,99,1,99,1,99,1,100, + 1,100,1,100,1,100,1,100,1,101,1,101,1,101,1,101,1,101,1,101,1,102, + 1,102,1,102,1,102,1,102,1,102,1,103,1,103,1,103,1,103,1,103,1,103, + 1,103,1,104,1,104,1,104,1,104,1,104,1,105,1,105,1,105,1,105,1,105, + 1,105,1,105,1,105,1,105,1,105,3,105,1042,8,105,1,106,1,106,1,106, + 1,106,1,106,1,106,1,106,1,106,1,106,1,106,1,106,1,106,1,106,1,106, + 1,106,1,106,1,106,1,106,1,106,1,106,1,106,1,106,1,106,1,106,1,106, + 1,106,1,106,3,106,1071,8,106,1,107,1,107,1,107,3,107,1076,8,107, + 1,107,1,107,1,107,1,107,5,107,1082,8,107,10,107,12,107,1085,9,107, + 1,107,1,107,1,107,1,107,1,107,1,107,1,107,1,107,1,107,5,107,1096, + 8,107,10,107,12,107,1099,9,107,1,107,1,107,1,107,1,107,1,107,1,107, + 1,107,1,107,1,107,1,107,1,107,5,107,1112,8,107,10,107,12,107,1115, + 9,107,1,107,1,107,3,107,1119,8,107,1,108,1,108,1,108,5,108,1124, + 8,108,10,108,12,108,1127,9,108,1,108,1,108,3,108,1131,8,108,1,108, + 1,108,3,108,1135,8,108,1,108,4,108,1138,8,108,11,108,12,108,1139, + 1,108,1,108,1,108,3,108,1145,8,108,1,108,1,108,3,108,1149,8,108, + 1,108,4,108,1152,8,108,11,108,12,108,1153,1,108,1,108,1,108,5,108, + 1159,8,108,10,108,12,108,1162,9,108,1,108,1,108,1,108,3,108,1167, + 8,108,1,108,4,108,1170,8,108,11,108,12,108,1171,1,108,1,108,1,108, + 1,108,1,108,3,108,1179,8,108,1,108,4,108,1182,8,108,11,108,12,108, + 1183,1,108,1,108,1,108,1,108,3,108,1190,8,108,1,108,4,108,1193,8, + 108,11,108,12,108,1194,3,108,1197,8,108,1,109,1,109,4,109,1201,8, + 109,11,109,12,109,1202,1,110,4,110,1206,8,110,11,110,12,110,1207, + 1,111,1,111,1,111,4,111,1213,8,111,11,111,12,111,1214,1,112,1,112, + 1,112,1,112,1,112,1,112,1,112,1,112,1,112,5,112,1226,8,112,10,112, + 12,112,1229,9,112,1,112,1,112,1,113,1,113,1,114,1,114,1,115,1,115, + 1,116,1,116,1,117,1,117,1,118,1,118,1,119,1,119,1,120,1,120,1,121, + 1,121,1,122,1,122,1,123,1,123,1,124,1,124,1,125,1,125,1,126,1,126, + 1,127,1,127,1,128,1,128,1,129,1,129,1,130,1,130,1,131,1,131,1,132, + 1,132,1,133,1,133,1,134,1,134,1,135,1,135,1,136,1,136,1,137,1,137, + 1,138,1,138,1,139,1,139,1,140,1,140,1,141,1,141,1,142,1,142,1,143, + 1,143,1,143,1,144,1,144,1,145,1,145,1,146,1,146,1,147,1,147,1,148, + 1,148,1,149,1,149,1,149,1,150,1,150,1,151,1,151,1,152,1,152,1,153, + 1,153,1,153,1,154,1,154,1,155,1,155,1,155,1,156,1,156,1,157,1,157, + 1,158,1,158,1,158,1,159,1,159,1,159,1,159,1,160,1,160,1,160,1,160, + 1,161,1,161,1,162,1,162,1,163,1,163,1,163,1,164,1,164,1,165,1,165, + 1,165,1,165,3,165,1351,8,165,1,166,1,166,1,166,1,166,1,167,1,167, + 1,167,1,168,1,168,1,168,1,169,1,169,1,169,1,170,1,170,1,171,1,171, + 1,172,1,172,1,173,1,173,1,174,1,174,1,174,1,174,1,174,1,175,1,175, + 1,175,1,175,1,175,1,176,1,176,1,177,1,177,1,178,1,178,1,178,1,179, + 1,179,1,179,1,179,1,180,1,180,1,181,1,181,1,182,1,182,1,183,1,183, + 1,184,1,184,1,185,1,185,1,185,1,185,5,185,1409,8,185,10,185,12,185, + 1412,9,185,1,185,1,185,1,185,1,185,1,185,1,186,1,186,1,186,1,186, + 3,186,1423,8,186,1,186,5,186,1426,8,186,10,186,12,186,1429,9,186, + 1,186,3,186,1432,8,186,1,186,1,186,1,187,1,187,1,187,1,187,1,188, + 1,188,1,188,1,188,1,188,1,188,1,188,1,188,1,188,1,188,1,188,4,188, + 1451,8,188,11,188,12,188,1452,1,189,1,189,1,189,1,189,1,190,1,190, + 1,190,1,190,1,190,1,191,1,191,1,191,1,191,1,191,4,191,1469,8,191, + 11,191,12,191,1470,1,192,1,192,1,192,1,192,1,1410,0,193,3,1,5,2, + 7,3,9,4,11,5,13,6,15,7,17,8,19,9,21,10,23,11,25,12,27,13,29,14,31, + 15,33,16,35,17,37,18,39,19,41,20,43,21,45,22,47,23,49,24,51,25,53, + 26,55,27,57,28,59,29,61,30,63,31,65,32,67,33,69,34,71,35,73,36,75, + 37,77,38,79,39,81,40,83,41,85,42,87,43,89,44,91,45,93,46,95,47,97, + 48,99,49,101,50,103,51,105,52,107,53,109,54,111,55,113,56,115,57, + 117,58,119,59,121,60,123,61,125,62,127,63,129,64,131,65,133,66,135, + 67,137,68,139,69,141,70,143,71,145,72,147,73,149,74,151,75,153,76, + 155,77,157,78,159,79,161,80,163,81,165,82,167,83,169,84,171,85,173, + 86,175,87,177,88,179,89,181,90,183,91,185,92,187,93,189,94,191,95, + 193,96,195,97,197,98,199,99,201,100,203,101,205,102,207,103,209, + 104,211,105,213,106,215,107,217,108,219,109,221,110,223,111,225, + 112,227,113,229,0,231,0,233,0,235,0,237,0,239,0,241,0,243,0,245, + 0,247,0,249,0,251,0,253,0,255,0,257,0,259,0,261,0,263,0,265,0,267, + 0,269,0,271,0,273,0,275,0,277,0,279,0,281,0,283,0,285,0,287,0,289, + 114,291,115,293,116,295,117,297,118,299,119,301,120,303,121,305, + 122,307,123,309,124,311,125,313,126,315,127,317,128,319,129,321, + 130,323,131,325,132,327,133,329,134,331,135,333,136,335,137,337, + 138,339,139,341,140,343,141,345,142,347,143,349,144,351,145,353, + 146,355,147,357,148,359,149,361,150,363,151,365,152,367,153,369, + 154,371,155,373,156,375,157,377,158,379,159,381,160,383,0,385,161, + 387,162,3,0,1,2,38,2,0,92,92,96,96,2,0,34,34,92,92,2,0,39,39,92, + 92,2,0,65,65,97,97,2,0,66,66,98,98,2,0,67,67,99,99,2,0,68,68,100, + 100,2,0,69,69,101,101,2,0,70,70,102,102,2,0,71,71,103,103,2,0,72, + 72,104,104,2,0,73,73,105,105,2,0,74,74,106,106,2,0,75,75,107,107, + 2,0,76,76,108,108,2,0,77,77,109,109,2,0,78,78,110,110,2,0,79,79, + 111,111,2,0,80,80,112,112,2,0,81,81,113,113,2,0,82,82,114,114,2, + 0,83,83,115,115,2,0,84,84,116,116,2,0,85,85,117,117,2,0,86,86,118, + 118,2,0,87,87,119,119,2,0,88,88,120,120,2,0,89,89,121,121,2,0,90, + 90,122,122,2,0,65,90,97,122,1,0,48,55,1,0,48,57,3,0,48,57,65,70, + 97,102,2,0,10,10,13,13,2,1,10,10,13,13,2,0,9,13,32,32,3,0,39,39, + 92,92,123,123,1,0,123,123,1512,0,3,1,0,0,0,0,5,1,0,0,0,0,7,1,0,0, + 0,0,9,1,0,0,0,0,11,1,0,0,0,0,13,1,0,0,0,0,15,1,0,0,0,0,17,1,0,0, + 0,0,19,1,0,0,0,0,21,1,0,0,0,0,23,1,0,0,0,0,25,1,0,0,0,0,27,1,0,0, + 0,0,29,1,0,0,0,0,31,1,0,0,0,0,33,1,0,0,0,0,35,1,0,0,0,0,37,1,0,0, + 0,0,39,1,0,0,0,0,41,1,0,0,0,0,43,1,0,0,0,0,45,1,0,0,0,0,47,1,0,0, + 0,0,49,1,0,0,0,0,51,1,0,0,0,0,53,1,0,0,0,0,55,1,0,0,0,0,57,1,0,0, + 0,0,59,1,0,0,0,0,61,1,0,0,0,0,63,1,0,0,0,0,65,1,0,0,0,0,67,1,0,0, + 0,0,69,1,0,0,0,0,71,1,0,0,0,0,73,1,0,0,0,0,75,1,0,0,0,0,77,1,0,0, + 0,0,79,1,0,0,0,0,81,1,0,0,0,0,83,1,0,0,0,0,85,1,0,0,0,0,87,1,0,0, + 0,0,89,1,0,0,0,0,91,1,0,0,0,0,93,1,0,0,0,0,95,1,0,0,0,0,97,1,0,0, + 0,0,99,1,0,0,0,0,101,1,0,0,0,0,103,1,0,0,0,0,105,1,0,0,0,0,107,1, + 0,0,0,0,109,1,0,0,0,0,111,1,0,0,0,0,113,1,0,0,0,0,115,1,0,0,0,0, + 117,1,0,0,0,0,119,1,0,0,0,0,121,1,0,0,0,0,123,1,0,0,0,0,125,1,0, + 0,0,0,127,1,0,0,0,0,129,1,0,0,0,0,131,1,0,0,0,0,133,1,0,0,0,0,135, + 1,0,0,0,0,137,1,0,0,0,0,139,1,0,0,0,0,141,1,0,0,0,0,143,1,0,0,0, + 0,145,1,0,0,0,0,147,1,0,0,0,0,149,1,0,0,0,0,151,1,0,0,0,0,153,1, + 0,0,0,0,155,1,0,0,0,0,157,1,0,0,0,0,159,1,0,0,0,0,161,1,0,0,0,0, + 163,1,0,0,0,0,165,1,0,0,0,0,167,1,0,0,0,0,169,1,0,0,0,0,171,1,0, + 0,0,0,173,1,0,0,0,0,175,1,0,0,0,0,177,1,0,0,0,0,179,1,0,0,0,0,181, + 1,0,0,0,0,183,1,0,0,0,0,185,1,0,0,0,0,187,1,0,0,0,0,189,1,0,0,0, + 0,191,1,0,0,0,0,193,1,0,0,0,0,195,1,0,0,0,0,197,1,0,0,0,0,199,1, + 0,0,0,0,201,1,0,0,0,0,203,1,0,0,0,0,205,1,0,0,0,0,207,1,0,0,0,0, + 209,1,0,0,0,0,211,1,0,0,0,0,213,1,0,0,0,0,215,1,0,0,0,0,217,1,0, + 0,0,0,219,1,0,0,0,0,221,1,0,0,0,0,223,1,0,0,0,0,225,1,0,0,0,0,227, + 1,0,0,0,0,289,1,0,0,0,0,291,1,0,0,0,0,293,1,0,0,0,0,295,1,0,0,0, + 0,297,1,0,0,0,0,299,1,0,0,0,0,301,1,0,0,0,0,303,1,0,0,0,0,305,1, + 0,0,0,0,307,1,0,0,0,0,309,1,0,0,0,0,311,1,0,0,0,0,313,1,0,0,0,0, + 315,1,0,0,0,0,317,1,0,0,0,0,319,1,0,0,0,0,321,1,0,0,0,0,323,1,0, + 0,0,0,325,1,0,0,0,0,327,1,0,0,0,0,329,1,0,0,0,0,331,1,0,0,0,0,333, + 1,0,0,0,0,335,1,0,0,0,0,337,1,0,0,0,0,339,1,0,0,0,0,341,1,0,0,0, + 0,343,1,0,0,0,0,345,1,0,0,0,0,347,1,0,0,0,0,349,1,0,0,0,0,351,1, + 0,0,0,0,353,1,0,0,0,0,355,1,0,0,0,0,357,1,0,0,0,0,359,1,0,0,0,0, + 361,1,0,0,0,0,363,1,0,0,0,0,365,1,0,0,0,0,367,1,0,0,0,0,369,1,0, + 0,0,0,371,1,0,0,0,0,373,1,0,0,0,0,375,1,0,0,0,0,377,1,0,0,0,1,379, + 1,0,0,0,1,381,1,0,0,0,1,383,1,0,0,0,2,385,1,0,0,0,2,387,1,0,0,0, + 3,389,1,0,0,0,5,393,1,0,0,0,7,397,1,0,0,0,9,402,1,0,0,0,11,406,1, + 0,0,0,13,412,1,0,0,0,15,429,1,0,0,0,17,431,1,0,0,0,19,436,1,0,0, + 0,21,444,1,0,0,0,23,449,1,0,0,0,25,452,1,0,0,0,27,457,1,0,0,0,29, + 462,1,0,0,0,31,468,1,0,0,0,33,475,1,0,0,0,35,483,1,0,0,0,37,489, + 1,0,0,0,39,494,1,0,0,0,41,502,1,0,0,0,43,507,1,0,0,0,45,511,1,0, + 0,0,47,516,1,0,0,0,49,527,1,0,0,0,51,536,1,0,0,0,53,541,1,0,0,0, + 55,545,1,0,0,0,57,552,1,0,0,0,59,560,1,0,0,0,61,566,1,0,0,0,63,574, + 1,0,0,0,65,580,1,0,0,0,67,583,1,0,0,0,69,593,1,0,0,0,71,597,1,0, + 0,0,73,602,1,0,0,0,75,607,1,0,0,0,77,611,1,0,0,0,79,617,1,0,0,0, + 81,624,1,0,0,0,83,629,1,0,0,0,85,632,1,0,0,0,87,635,1,0,0,0,89,641, + 1,0,0,0,91,657,1,0,0,0,93,659,1,0,0,0,95,665,1,0,0,0,97,675,1,0, + 0,0,99,684,1,0,0,0,101,687,1,0,0,0,103,692,1,0,0,0,105,696,1,0,0, + 0,107,701,1,0,0,0,109,709,1,0,0,0,111,714,1,0,0,0,113,718,1,0,0, + 0,115,723,1,0,0,0,117,729,1,0,0,0,119,736,1,0,0,0,121,742,1,0,0, + 0,123,746,1,0,0,0,125,750,1,0,0,0,127,755,1,0,0,0,129,761,1,0,0, + 0,131,768,1,0,0,0,133,771,1,0,0,0,135,774,1,0,0,0,137,780,1,0,0, + 0,139,786,1,0,0,0,141,791,1,0,0,0,143,801,1,0,0,0,145,811,1,0,0, + 0,147,820,1,0,0,0,149,828,1,0,0,0,151,834,1,0,0,0,153,841,1,0,0, + 0,155,847,1,0,0,0,157,854,1,0,0,0,159,858,1,0,0,0,161,863,1,0,0, + 0,163,870,1,0,0,0,165,877,1,0,0,0,167,884,1,0,0,0,169,889,1,0,0, + 0,171,898,1,0,0,0,173,908,1,0,0,0,175,913,1,0,0,0,177,919,1,0,0, + 0,179,924,1,0,0,0,181,934,1,0,0,0,183,937,1,0,0,0,185,941,1,0,0, + 0,187,948,1,0,0,0,189,957,1,0,0,0,191,962,1,0,0,0,193,971,1,0,0, + 0,195,975,1,0,0,0,197,985,1,0,0,0,199,991,1,0,0,0,201,997,1,0,0, + 0,203,1002,1,0,0,0,205,1007,1,0,0,0,207,1013,1,0,0,0,209,1019,1, + 0,0,0,211,1026,1,0,0,0,213,1041,1,0,0,0,215,1070,1,0,0,0,217,1118, + 1,0,0,0,219,1196,1,0,0,0,221,1198,1,0,0,0,223,1205,1,0,0,0,225,1209, + 1,0,0,0,227,1216,1,0,0,0,229,1232,1,0,0,0,231,1234,1,0,0,0,233,1236, + 1,0,0,0,235,1238,1,0,0,0,237,1240,1,0,0,0,239,1242,1,0,0,0,241,1244, + 1,0,0,0,243,1246,1,0,0,0,245,1248,1,0,0,0,247,1250,1,0,0,0,249,1252, + 1,0,0,0,251,1254,1,0,0,0,253,1256,1,0,0,0,255,1258,1,0,0,0,257,1260, + 1,0,0,0,259,1262,1,0,0,0,261,1264,1,0,0,0,263,1266,1,0,0,0,265,1268, + 1,0,0,0,267,1270,1,0,0,0,269,1272,1,0,0,0,271,1274,1,0,0,0,273,1276, + 1,0,0,0,275,1278,1,0,0,0,277,1280,1,0,0,0,279,1282,1,0,0,0,281,1284, + 1,0,0,0,283,1286,1,0,0,0,285,1288,1,0,0,0,287,1290,1,0,0,0,289,1292, + 1,0,0,0,291,1295,1,0,0,0,293,1297,1,0,0,0,295,1299,1,0,0,0,297,1301, + 1,0,0,0,299,1303,1,0,0,0,301,1305,1,0,0,0,303,1308,1,0,0,0,305,1310, + 1,0,0,0,307,1312,1,0,0,0,309,1314,1,0,0,0,311,1317,1,0,0,0,313,1319, + 1,0,0,0,315,1322,1,0,0,0,317,1324,1,0,0,0,319,1326,1,0,0,0,321,1329, + 1,0,0,0,323,1333,1,0,0,0,325,1337,1,0,0,0,327,1339,1,0,0,0,329,1341, + 1,0,0,0,331,1344,1,0,0,0,333,1350,1,0,0,0,335,1352,1,0,0,0,337,1356, + 1,0,0,0,339,1359,1,0,0,0,341,1362,1,0,0,0,343,1365,1,0,0,0,345,1367, + 1,0,0,0,347,1369,1,0,0,0,349,1371,1,0,0,0,351,1373,1,0,0,0,353,1378, + 1,0,0,0,355,1383,1,0,0,0,357,1385,1,0,0,0,359,1387,1,0,0,0,361,1390, + 1,0,0,0,363,1394,1,0,0,0,365,1396,1,0,0,0,367,1398,1,0,0,0,369,1400, + 1,0,0,0,371,1402,1,0,0,0,373,1404,1,0,0,0,375,1422,1,0,0,0,377,1435, + 1,0,0,0,379,1450,1,0,0,0,381,1454,1,0,0,0,383,1458,1,0,0,0,385,1468, + 1,0,0,0,387,1472,1,0,0,0,389,390,3,229,113,0,390,391,3,251,124,0, + 391,392,3,251,124,0,392,4,1,0,0,0,393,394,3,229,113,0,394,395,3, + 255,126,0,395,396,3,235,116,0,396,6,1,0,0,0,397,398,3,229,113,0, + 398,399,3,255,126,0,399,400,3,267,132,0,400,401,3,245,121,0,401, + 8,1,0,0,0,402,403,3,229,113,0,403,404,3,255,126,0,404,405,3,277, + 137,0,405,10,1,0,0,0,406,407,3,229,113,0,407,408,3,263,130,0,408, + 409,3,263,130,0,409,410,3,229,113,0,410,411,3,277,137,0,411,12,1, + 0,0,0,412,413,3,229,113,0,413,414,3,265,131,0,414,14,1,0,0,0,415, + 416,3,229,113,0,416,417,3,265,131,0,417,418,3,233,115,0,418,430, + 1,0,0,0,419,420,3,229,113,0,420,421,3,265,131,0,421,422,3,233,115, + 0,422,423,3,237,117,0,423,424,3,255,126,0,424,425,3,235,116,0,425, + 426,3,245,121,0,426,427,3,255,126,0,427,428,3,241,119,0,428,430, + 1,0,0,0,429,415,1,0,0,0,429,419,1,0,0,0,430,16,1,0,0,0,431,432,3, + 229,113,0,432,433,3,265,131,0,433,434,3,257,127,0,434,435,3,239, + 118,0,435,18,1,0,0,0,436,437,3,231,114,0,437,438,3,237,117,0,438, + 439,3,267,132,0,439,440,3,273,135,0,440,441,3,237,117,0,441,442, + 3,237,117,0,442,443,3,255,126,0,443,20,1,0,0,0,444,445,3,231,114, + 0,445,446,3,257,127,0,446,447,3,267,132,0,447,448,3,243,120,0,448, + 22,1,0,0,0,449,450,3,231,114,0,450,451,3,277,137,0,451,24,1,0,0, + 0,452,453,3,233,115,0,453,454,3,229,113,0,454,455,3,265,131,0,455, + 456,3,237,117,0,456,26,1,0,0,0,457,458,3,233,115,0,458,459,3,229, + 113,0,459,460,3,265,131,0,460,461,3,267,132,0,461,28,1,0,0,0,462, + 463,3,233,115,0,463,464,3,229,113,0,464,465,3,267,132,0,465,466, + 3,233,115,0,466,467,3,243,120,0,467,30,1,0,0,0,468,469,3,233,115, + 0,469,470,3,257,127,0,470,471,3,243,120,0,471,472,3,257,127,0,472, + 473,3,263,130,0,473,474,3,267,132,0,474,32,1,0,0,0,475,476,3,233, + 115,0,476,477,3,257,127,0,477,478,3,251,124,0,478,479,3,251,124, + 0,479,480,3,229,113,0,480,481,3,267,132,0,481,482,3,237,117,0,482, + 34,1,0,0,0,483,484,3,233,115,0,484,485,3,263,130,0,485,486,3,257, + 127,0,486,487,3,265,131,0,487,488,3,265,131,0,488,36,1,0,0,0,489, + 490,3,233,115,0,490,491,3,269,133,0,491,492,3,231,114,0,492,493, + 3,237,117,0,493,38,1,0,0,0,494,495,3,233,115,0,495,496,3,269,133, + 0,496,497,3,263,130,0,497,498,3,263,130,0,498,499,3,237,117,0,499, + 500,3,255,126,0,500,501,3,267,132,0,501,40,1,0,0,0,502,503,3,235, + 116,0,503,504,3,229,113,0,504,505,3,267,132,0,505,506,3,237,117, + 0,506,42,1,0,0,0,507,508,3,235,116,0,508,509,3,229,113,0,509,510, + 3,277,137,0,510,44,1,0,0,0,511,512,3,235,116,0,512,513,3,237,117, + 0,513,514,3,265,131,0,514,515,3,233,115,0,515,46,1,0,0,0,516,517, + 3,235,116,0,517,518,3,237,117,0,518,519,3,265,131,0,519,520,3,233, + 115,0,520,521,3,237,117,0,521,522,3,255,126,0,522,523,3,235,116, + 0,523,524,3,245,121,0,524,525,3,255,126,0,525,526,3,241,119,0,526, + 48,1,0,0,0,527,528,3,235,116,0,528,529,3,245,121,0,529,530,3,265, + 131,0,530,531,3,267,132,0,531,532,3,245,121,0,532,533,3,255,126, + 0,533,534,3,233,115,0,534,535,3,267,132,0,535,50,1,0,0,0,536,537, + 3,237,117,0,537,538,3,251,124,0,538,539,3,265,131,0,539,540,3,237, + 117,0,540,52,1,0,0,0,541,542,3,237,117,0,542,543,3,255,126,0,543, + 544,3,235,116,0,544,54,1,0,0,0,545,546,3,237,117,0,546,547,3,275, + 136,0,547,548,3,233,115,0,548,549,3,237,117,0,549,550,3,259,128, + 0,550,551,3,267,132,0,551,56,1,0,0,0,552,553,3,237,117,0,553,554, + 3,275,136,0,554,555,3,267,132,0,555,556,3,263,130,0,556,557,3,229, + 113,0,557,558,3,233,115,0,558,559,3,267,132,0,559,58,1,0,0,0,560, + 561,3,239,118,0,561,562,3,245,121,0,562,563,3,255,126,0,563,564, + 3,229,113,0,564,565,3,251,124,0,565,60,1,0,0,0,566,567,3,239,118, + 0,567,568,3,245,121,0,568,569,3,255,126,0,569,570,3,229,113,0,570, + 571,3,251,124,0,571,572,3,251,124,0,572,573,3,277,137,0,573,62,1, + 0,0,0,574,575,3,239,118,0,575,576,3,245,121,0,576,577,3,263,130, + 0,577,578,3,265,131,0,578,579,3,267,132,0,579,64,1,0,0,0,580,581, + 3,239,118,0,581,582,3,255,126,0,582,66,1,0,0,0,583,584,3,239,118, + 0,584,585,3,257,127,0,585,586,3,251,124,0,586,587,3,251,124,0,587, + 588,3,257,127,0,588,589,3,273,135,0,589,590,3,245,121,0,590,591, + 3,255,126,0,591,592,3,241,119,0,592,68,1,0,0,0,593,594,3,239,118, + 0,594,595,3,257,127,0,595,596,3,263,130,0,596,70,1,0,0,0,597,598, + 3,239,118,0,598,599,3,263,130,0,599,600,3,257,127,0,600,601,3,253, + 125,0,601,72,1,0,0,0,602,603,3,239,118,0,603,604,3,269,133,0,604, + 605,3,251,124,0,605,606,3,251,124,0,606,74,1,0,0,0,607,608,3,239, + 118,0,608,609,3,269,133,0,609,610,3,255,126,0,610,76,1,0,0,0,611, + 612,3,241,119,0,612,613,3,263,130,0,613,614,3,257,127,0,614,615, + 3,269,133,0,615,616,3,259,128,0,616,78,1,0,0,0,617,618,3,243,120, + 0,618,619,3,229,113,0,619,620,3,271,134,0,620,621,3,245,121,0,621, + 622,3,255,126,0,622,623,3,241,119,0,623,80,1,0,0,0,624,625,3,243, + 120,0,625,626,3,257,127,0,626,627,3,269,133,0,627,628,3,263,130, + 0,628,82,1,0,0,0,629,630,3,245,121,0,630,631,3,235,116,0,631,84, + 1,0,0,0,632,633,3,245,121,0,633,634,3,239,118,0,634,86,1,0,0,0,635, + 636,3,245,121,0,636,637,3,251,124,0,637,638,3,245,121,0,638,639, + 3,249,123,0,639,640,3,237,117,0,640,88,1,0,0,0,641,642,3,245,121, + 0,642,643,3,255,126,0,643,90,1,0,0,0,644,645,3,245,121,0,645,646, + 3,255,126,0,646,647,3,239,118,0,647,658,1,0,0,0,648,649,3,245,121, + 0,649,650,3,255,126,0,650,651,3,239,118,0,651,652,3,245,121,0,652, + 653,3,255,126,0,653,654,3,245,121,0,654,655,3,267,132,0,655,656, + 3,277,137,0,656,658,1,0,0,0,657,644,1,0,0,0,657,648,1,0,0,0,658, + 92,1,0,0,0,659,660,3,245,121,0,660,661,3,255,126,0,661,662,3,255, + 126,0,662,663,3,237,117,0,663,664,3,263,130,0,664,94,1,0,0,0,665, + 666,3,245,121,0,666,667,3,255,126,0,667,668,3,267,132,0,668,669, + 3,237,117,0,669,670,3,263,130,0,670,671,3,265,131,0,671,672,3,237, + 117,0,672,673,3,233,115,0,673,674,3,267,132,0,674,96,1,0,0,0,675, + 676,3,245,121,0,676,677,3,255,126,0,677,678,3,267,132,0,678,679, + 3,237,117,0,679,680,3,263,130,0,680,681,3,271,134,0,681,682,3,229, + 113,0,682,683,3,251,124,0,683,98,1,0,0,0,684,685,3,245,121,0,685, + 686,3,265,131,0,686,100,1,0,0,0,687,688,3,247,122,0,688,689,3,257, + 127,0,689,690,3,245,121,0,690,691,3,255,126,0,691,102,1,0,0,0,692, + 693,3,249,123,0,693,694,3,237,117,0,694,695,3,277,137,0,695,104, + 1,0,0,0,696,697,3,251,124,0,697,698,3,229,113,0,698,699,3,265,131, + 0,699,700,3,267,132,0,700,106,1,0,0,0,701,702,3,251,124,0,702,703, + 3,237,117,0,703,704,3,229,113,0,704,705,3,235,116,0,705,706,3,245, + 121,0,706,707,3,255,126,0,707,708,3,241,119,0,708,108,1,0,0,0,709, + 710,3,251,124,0,710,711,3,237,117,0,711,712,3,239,118,0,712,713, + 3,267,132,0,713,110,1,0,0,0,714,715,3,251,124,0,715,716,3,237,117, + 0,716,717,3,267,132,0,717,112,1,0,0,0,718,719,3,251,124,0,719,720, + 3,245,121,0,720,721,3,249,123,0,721,722,3,237,117,0,722,114,1,0, + 0,0,723,724,3,251,124,0,724,725,3,245,121,0,725,726,3,253,125,0, + 726,727,3,245,121,0,727,728,3,267,132,0,728,116,1,0,0,0,729,730, + 3,253,125,0,730,731,3,245,121,0,731,732,3,255,126,0,732,733,3,269, + 133,0,733,734,3,267,132,0,734,735,3,237,117,0,735,118,1,0,0,0,736, + 737,3,253,125,0,737,738,3,257,127,0,738,739,3,255,126,0,739,740, + 3,267,132,0,740,741,3,243,120,0,741,120,1,0,0,0,742,743,3,255,126, + 0,743,744,3,229,113,0,744,745,3,255,126,0,745,122,1,0,0,0,746,747, + 3,255,126,0,747,748,3,257,127,0,748,749,3,267,132,0,749,124,1,0, + 0,0,750,751,3,255,126,0,751,752,3,269,133,0,752,753,3,251,124,0, + 753,754,3,251,124,0,754,126,1,0,0,0,755,756,3,255,126,0,756,757, + 3,269,133,0,757,758,3,251,124,0,758,759,3,251,124,0,759,760,3,265, + 131,0,760,128,1,0,0,0,761,762,3,257,127,0,762,763,3,239,118,0,763, + 764,3,239,118,0,764,765,3,265,131,0,765,766,3,237,117,0,766,767, + 3,267,132,0,767,130,1,0,0,0,768,769,3,257,127,0,769,770,3,255,126, + 0,770,132,1,0,0,0,771,772,3,257,127,0,772,773,3,263,130,0,773,134, + 1,0,0,0,774,775,3,257,127,0,775,776,3,263,130,0,776,777,3,235,116, + 0,777,778,3,237,117,0,778,779,3,263,130,0,779,136,1,0,0,0,780,781, + 3,257,127,0,781,782,3,269,133,0,782,783,3,267,132,0,783,784,3,237, + 117,0,784,785,3,263,130,0,785,138,1,0,0,0,786,787,3,257,127,0,787, + 788,3,271,134,0,788,789,3,237,117,0,789,790,3,263,130,0,790,140, + 1,0,0,0,791,792,3,259,128,0,792,793,3,229,113,0,793,794,3,263,130, + 0,794,795,3,267,132,0,795,796,3,245,121,0,796,797,3,267,132,0,797, + 798,3,245,121,0,798,799,3,257,127,0,799,800,3,255,126,0,800,142, + 1,0,0,0,801,802,3,259,128,0,802,803,3,263,130,0,803,804,3,237,117, + 0,804,805,3,233,115,0,805,806,3,237,117,0,806,807,3,235,116,0,807, + 808,3,245,121,0,808,809,3,255,126,0,809,810,3,241,119,0,810,144, + 1,0,0,0,811,812,3,259,128,0,812,813,3,263,130,0,813,814,3,237,117, + 0,814,815,3,273,135,0,815,816,3,243,120,0,816,817,3,237,117,0,817, + 818,3,263,130,0,818,819,3,237,117,0,819,146,1,0,0,0,820,821,3,261, + 129,0,821,822,3,269,133,0,822,823,3,229,113,0,823,824,3,263,130, + 0,824,825,3,267,132,0,825,826,3,237,117,0,826,827,3,263,130,0,827, + 148,1,0,0,0,828,829,3,263,130,0,829,830,3,229,113,0,830,831,3,255, + 126,0,831,832,3,241,119,0,832,833,3,237,117,0,833,150,1,0,0,0,834, + 835,3,263,130,0,835,836,3,237,117,0,836,837,3,267,132,0,837,838, + 3,269,133,0,838,839,3,263,130,0,839,840,3,255,126,0,840,152,1,0, + 0,0,841,842,3,263,130,0,842,843,3,245,121,0,843,844,3,241,119,0, + 844,845,3,243,120,0,845,846,3,267,132,0,846,154,1,0,0,0,847,848, + 3,263,130,0,848,849,3,257,127,0,849,850,3,251,124,0,850,851,3,251, + 124,0,851,852,3,269,133,0,852,853,3,259,128,0,853,156,1,0,0,0,854, + 855,3,263,130,0,855,856,3,257,127,0,856,857,3,273,135,0,857,158, + 1,0,0,0,858,859,3,263,130,0,859,860,3,257,127,0,860,861,3,273,135, + 0,861,862,3,265,131,0,862,160,1,0,0,0,863,864,3,265,131,0,864,865, + 3,229,113,0,865,866,3,253,125,0,866,867,3,259,128,0,867,868,3,251, + 124,0,868,869,3,237,117,0,869,162,1,0,0,0,870,871,3,265,131,0,871, + 872,3,237,117,0,872,873,3,233,115,0,873,874,3,257,127,0,874,875, + 3,255,126,0,875,876,3,235,116,0,876,164,1,0,0,0,877,878,3,265,131, + 0,878,879,3,237,117,0,879,880,3,251,124,0,880,881,3,237,117,0,881, + 882,3,233,115,0,882,883,3,267,132,0,883,166,1,0,0,0,884,885,3,265, + 131,0,885,886,3,237,117,0,886,887,3,253,125,0,887,888,3,245,121, + 0,888,168,1,0,0,0,889,890,3,265,131,0,890,891,3,237,117,0,891,892, + 3,267,132,0,892,893,3,267,132,0,893,894,3,245,121,0,894,895,3,255, + 126,0,895,896,3,241,119,0,896,897,3,265,131,0,897,170,1,0,0,0,898, + 899,3,265,131,0,899,900,3,269,133,0,900,901,3,231,114,0,901,902, + 3,265,131,0,902,903,3,267,132,0,903,904,3,263,130,0,904,905,3,245, + 121,0,905,906,3,255,126,0,906,907,3,241,119,0,907,172,1,0,0,0,908, + 909,3,267,132,0,909,910,3,243,120,0,910,911,3,237,117,0,911,912, + 3,255,126,0,912,174,1,0,0,0,913,914,3,267,132,0,914,915,3,243,120, + 0,915,916,3,263,130,0,916,917,3,257,127,0,917,918,3,273,135,0,918, + 176,1,0,0,0,919,920,3,267,132,0,920,921,3,245,121,0,921,922,3,237, + 117,0,922,923,3,265,131,0,923,178,1,0,0,0,924,925,3,267,132,0,925, + 926,3,245,121,0,926,927,3,253,125,0,927,928,3,237,117,0,928,929, + 3,265,131,0,929,930,3,267,132,0,930,931,3,229,113,0,931,932,3,253, + 125,0,932,933,3,259,128,0,933,180,1,0,0,0,934,935,3,267,132,0,935, + 936,3,257,127,0,936,182,1,0,0,0,937,938,3,267,132,0,938,939,3,257, + 127,0,939,940,3,259,128,0,940,184,1,0,0,0,941,942,3,267,132,0,942, + 943,3,257,127,0,943,944,3,267,132,0,944,945,3,229,113,0,945,946, + 3,251,124,0,946,947,3,265,131,0,947,186,1,0,0,0,948,949,3,267,132, + 0,949,950,3,263,130,0,950,951,3,229,113,0,951,952,3,245,121,0,952, + 953,3,251,124,0,953,954,3,245,121,0,954,955,3,255,126,0,955,956, + 3,241,119,0,956,188,1,0,0,0,957,958,3,267,132,0,958,959,3,263,130, + 0,959,960,3,245,121,0,960,961,3,253,125,0,961,190,1,0,0,0,962,963, + 3,267,132,0,963,964,3,263,130,0,964,965,3,269,133,0,965,966,3,255, + 126,0,966,967,3,233,115,0,967,968,3,229,113,0,968,969,3,267,132, + 0,969,970,3,237,117,0,970,192,1,0,0,0,971,972,3,267,132,0,972,973, + 3,263,130,0,973,974,3,277,137,0,974,194,1,0,0,0,975,976,3,269,133, + 0,976,977,3,255,126,0,977,978,3,231,114,0,978,979,3,257,127,0,979, + 980,3,269,133,0,980,981,3,255,126,0,981,982,3,235,116,0,982,983, + 3,237,117,0,983,984,3,235,116,0,984,196,1,0,0,0,985,986,3,269,133, + 0,986,987,3,255,126,0,987,988,3,245,121,0,988,989,3,257,127,0,989, + 990,3,255,126,0,990,198,1,0,0,0,991,992,3,269,133,0,992,993,3,265, + 131,0,993,994,3,245,121,0,994,995,3,255,126,0,995,996,3,241,119, + 0,996,200,1,0,0,0,997,998,3,273,135,0,998,999,3,237,117,0,999,1000, + 3,237,117,0,1000,1001,3,249,123,0,1001,202,1,0,0,0,1002,1003,3,273, + 135,0,1003,1004,3,243,120,0,1004,1005,3,237,117,0,1005,1006,3,255, + 126,0,1006,204,1,0,0,0,1007,1008,3,273,135,0,1008,1009,3,243,120, + 0,1009,1010,3,237,117,0,1010,1011,3,263,130,0,1011,1012,3,237,117, + 0,1012,206,1,0,0,0,1013,1014,3,273,135,0,1014,1015,3,243,120,0,1015, + 1016,3,245,121,0,1016,1017,3,251,124,0,1017,1018,3,237,117,0,1018, + 208,1,0,0,0,1019,1020,3,273,135,0,1020,1021,3,245,121,0,1021,1022, + 3,255,126,0,1022,1023,3,235,116,0,1023,1024,3,257,127,0,1024,1025, + 3,273,135,0,1025,210,1,0,0,0,1026,1027,3,273,135,0,1027,1028,3,245, + 121,0,1028,1029,3,267,132,0,1029,1030,3,243,120,0,1030,212,1,0,0, + 0,1031,1032,3,277,137,0,1032,1033,3,237,117,0,1033,1034,3,229,113, + 0,1034,1035,3,263,130,0,1035,1042,1,0,0,0,1036,1037,3,277,137,0, + 1037,1038,3,277,137,0,1038,1039,3,277,137,0,1039,1040,3,277,137, + 0,1040,1042,1,0,0,0,1041,1031,1,0,0,0,1041,1036,1,0,0,0,1042,214, + 1,0,0,0,1043,1044,3,295,146,0,1044,1045,3,231,114,0,1045,1071,1, + 0,0,0,1046,1047,3,295,146,0,1047,1048,3,239,118,0,1048,1071,1,0, + 0,0,1049,1050,3,295,146,0,1050,1051,3,263,130,0,1051,1071,1,0,0, + 0,1052,1053,3,295,146,0,1053,1054,3,255,126,0,1054,1071,1,0,0,0, + 1055,1056,3,295,146,0,1056,1057,3,267,132,0,1057,1071,1,0,0,0,1058, + 1059,3,295,146,0,1059,1060,5,48,0,0,1060,1071,1,0,0,0,1061,1062, + 3,295,146,0,1062,1063,3,229,113,0,1063,1071,1,0,0,0,1064,1065,3, + 295,146,0,1065,1066,3,271,134,0,1066,1071,1,0,0,0,1067,1068,3,295, + 146,0,1068,1069,3,295,146,0,1069,1071,1,0,0,0,1070,1043,1,0,0,0, + 1070,1046,1,0,0,0,1070,1049,1,0,0,0,1070,1052,1,0,0,0,1070,1055, + 1,0,0,0,1070,1058,1,0,0,0,1070,1061,1,0,0,0,1070,1064,1,0,0,0,1070, + 1067,1,0,0,0,1071,216,1,0,0,0,1072,1076,3,281,139,0,1073,1076,3, + 371,184,0,1074,1076,3,305,151,0,1075,1072,1,0,0,0,1075,1073,1,0, + 0,0,1075,1074,1,0,0,0,1076,1083,1,0,0,0,1077,1082,3,281,139,0,1078, + 1082,3,371,184,0,1079,1082,3,285,141,0,1080,1082,3,305,151,0,1081, + 1077,1,0,0,0,1081,1078,1,0,0,0,1081,1079,1,0,0,0,1081,1080,1,0,0, + 0,1082,1085,1,0,0,0,1083,1081,1,0,0,0,1083,1084,1,0,0,0,1084,1119, + 1,0,0,0,1085,1083,1,0,0,0,1086,1097,3,293,145,0,1087,1096,8,0,0, + 0,1088,1096,3,215,106,0,1089,1090,3,295,146,0,1090,1091,3,355,176, + 0,1091,1096,1,0,0,0,1092,1093,3,293,145,0,1093,1094,3,293,145,0, + 1094,1096,1,0,0,0,1095,1087,1,0,0,0,1095,1088,1,0,0,0,1095,1089, + 1,0,0,0,1095,1092,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,1101,3,293, + 145,0,1101,1119,1,0,0,0,1102,1113,3,349,173,0,1103,1112,8,1,0,0, + 1104,1112,3,215,106,0,1105,1106,3,295,146,0,1106,1107,3,349,173, + 0,1107,1112,1,0,0,0,1108,1109,3,349,173,0,1109,1110,3,349,173,0, + 1110,1112,1,0,0,0,1111,1103,1,0,0,0,1111,1104,1,0,0,0,1111,1105, + 1,0,0,0,1111,1108,1,0,0,0,1112,1115,1,0,0,0,1113,1111,1,0,0,0,1113, + 1114,1,0,0,0,1114,1116,1,0,0,0,1115,1113,1,0,0,0,1116,1117,3,349, + 173,0,1117,1119,1,0,0,0,1118,1075,1,0,0,0,1118,1086,1,0,0,0,1118, + 1102,1,0,0,0,1119,218,1,0,0,0,1120,1121,3,225,111,0,1121,1125,3, + 307,152,0,1122,1124,3,287,142,0,1123,1122,1,0,0,0,1124,1127,1,0, + 0,0,1125,1123,1,0,0,0,1125,1126,1,0,0,0,1126,1130,1,0,0,0,1127,1125, + 1,0,0,0,1128,1131,3,259,128,0,1129,1131,3,237,117,0,1130,1128,1, + 0,0,0,1130,1129,1,0,0,0,1131,1134,1,0,0,0,1132,1135,3,345,171,0, + 1133,1135,3,303,150,0,1134,1132,1,0,0,0,1134,1133,1,0,0,0,1134,1135, + 1,0,0,0,1135,1137,1,0,0,0,1136,1138,3,285,141,0,1137,1136,1,0,0, + 0,1138,1139,1,0,0,0,1139,1137,1,0,0,0,1139,1140,1,0,0,0,1140,1197, + 1,0,0,0,1141,1144,3,225,111,0,1142,1145,3,259,128,0,1143,1145,3, + 237,117,0,1144,1142,1,0,0,0,1144,1143,1,0,0,0,1145,1148,1,0,0,0, + 1146,1149,3,345,171,0,1147,1149,3,303,150,0,1148,1146,1,0,0,0,1148, + 1147,1,0,0,0,1148,1149,1,0,0,0,1149,1151,1,0,0,0,1150,1152,3,285, + 141,0,1151,1150,1,0,0,0,1152,1153,1,0,0,0,1153,1151,1,0,0,0,1153, + 1154,1,0,0,0,1154,1197,1,0,0,0,1155,1156,3,223,110,0,1156,1160,3, + 307,152,0,1157,1159,3,285,141,0,1158,1157,1,0,0,0,1159,1162,1,0, + 0,0,1160,1158,1,0,0,0,1160,1161,1,0,0,0,1161,1163,1,0,0,0,1162,1160, + 1,0,0,0,1163,1166,3,237,117,0,1164,1167,3,345,171,0,1165,1167,3, + 303,150,0,1166,1164,1,0,0,0,1166,1165,1,0,0,0,1166,1167,1,0,0,0, + 1167,1169,1,0,0,0,1168,1170,3,285,141,0,1169,1168,1,0,0,0,1170,1171, + 1,0,0,0,1171,1169,1,0,0,0,1171,1172,1,0,0,0,1172,1197,1,0,0,0,1173, + 1174,3,307,152,0,1174,1175,3,223,110,0,1175,1178,3,237,117,0,1176, + 1179,3,345,171,0,1177,1179,3,303,150,0,1178,1176,1,0,0,0,1178,1177, + 1,0,0,0,1178,1179,1,0,0,0,1179,1181,1,0,0,0,1180,1182,3,285,141, + 0,1181,1180,1,0,0,0,1182,1183,1,0,0,0,1183,1181,1,0,0,0,1183,1184, + 1,0,0,0,1184,1197,1,0,0,0,1185,1186,3,223,110,0,1186,1189,3,237, + 117,0,1187,1190,3,345,171,0,1188,1190,3,303,150,0,1189,1187,1,0, + 0,0,1189,1188,1,0,0,0,1189,1190,1,0,0,0,1190,1192,1,0,0,0,1191,1193, + 3,285,141,0,1192,1191,1,0,0,0,1193,1194,1,0,0,0,1194,1192,1,0,0, + 0,1194,1195,1,0,0,0,1195,1197,1,0,0,0,1196,1120,1,0,0,0,1196,1141, + 1,0,0,0,1196,1155,1,0,0,0,1196,1173,1,0,0,0,1196,1185,1,0,0,0,1197, + 220,1,0,0,0,1198,1200,5,48,0,0,1199,1201,3,283,140,0,1200,1199,1, + 0,0,0,1201,1202,1,0,0,0,1202,1200,1,0,0,0,1202,1203,1,0,0,0,1203, + 222,1,0,0,0,1204,1206,3,285,141,0,1205,1204,1,0,0,0,1206,1207,1, + 0,0,0,1207,1205,1,0,0,0,1207,1208,1,0,0,0,1208,224,1,0,0,0,1209, + 1210,5,48,0,0,1210,1212,3,275,136,0,1211,1213,3,287,142,0,1212,1211, + 1,0,0,0,1213,1214,1,0,0,0,1214,1212,1,0,0,0,1214,1215,1,0,0,0,1215, + 226,1,0,0,0,1216,1227,3,355,176,0,1217,1226,8,2,0,0,1218,1226,3, + 215,106,0,1219,1220,3,295,146,0,1220,1221,3,355,176,0,1221,1226, + 1,0,0,0,1222,1223,3,355,176,0,1223,1224,3,355,176,0,1224,1226,1, + 0,0,0,1225,1217,1,0,0,0,1225,1218,1,0,0,0,1225,1219,1,0,0,0,1225, + 1222,1,0,0,0,1226,1229,1,0,0,0,1227,1225,1,0,0,0,1227,1228,1,0,0, + 0,1228,1230,1,0,0,0,1229,1227,1,0,0,0,1230,1231,3,355,176,0,1231, + 228,1,0,0,0,1232,1233,7,3,0,0,1233,230,1,0,0,0,1234,1235,7,4,0,0, + 1235,232,1,0,0,0,1236,1237,7,5,0,0,1237,234,1,0,0,0,1238,1239,7, + 6,0,0,1239,236,1,0,0,0,1240,1241,7,7,0,0,1241,238,1,0,0,0,1242,1243, + 7,8,0,0,1243,240,1,0,0,0,1244,1245,7,9,0,0,1245,242,1,0,0,0,1246, + 1247,7,10,0,0,1247,244,1,0,0,0,1248,1249,7,11,0,0,1249,246,1,0,0, + 0,1250,1251,7,12,0,0,1251,248,1,0,0,0,1252,1253,7,13,0,0,1253,250, + 1,0,0,0,1254,1255,7,14,0,0,1255,252,1,0,0,0,1256,1257,7,15,0,0,1257, + 254,1,0,0,0,1258,1259,7,16,0,0,1259,256,1,0,0,0,1260,1261,7,17,0, + 0,1261,258,1,0,0,0,1262,1263,7,18,0,0,1263,260,1,0,0,0,1264,1265, + 7,19,0,0,1265,262,1,0,0,0,1266,1267,7,20,0,0,1267,264,1,0,0,0,1268, + 1269,7,21,0,0,1269,266,1,0,0,0,1270,1271,7,22,0,0,1271,268,1,0,0, + 0,1272,1273,7,23,0,0,1273,270,1,0,0,0,1274,1275,7,24,0,0,1275,272, + 1,0,0,0,1276,1277,7,25,0,0,1277,274,1,0,0,0,1278,1279,7,26,0,0,1279, + 276,1,0,0,0,1280,1281,7,27,0,0,1281,278,1,0,0,0,1282,1283,7,28,0, + 0,1283,280,1,0,0,0,1284,1285,7,29,0,0,1285,282,1,0,0,0,1286,1287, + 7,30,0,0,1287,284,1,0,0,0,1288,1289,7,31,0,0,1289,286,1,0,0,0,1290, + 1291,7,32,0,0,1291,288,1,0,0,0,1292,1293,5,45,0,0,1293,1294,5,62, + 0,0,1294,290,1,0,0,0,1295,1296,5,42,0,0,1296,292,1,0,0,0,1297,1298, + 5,96,0,0,1298,294,1,0,0,0,1299,1300,5,92,0,0,1300,296,1,0,0,0,1301, + 1302,5,58,0,0,1302,298,1,0,0,0,1303,1304,5,44,0,0,1304,300,1,0,0, + 0,1305,1306,5,124,0,0,1306,1307,5,124,0,0,1307,302,1,0,0,0,1308, + 1309,5,45,0,0,1309,304,1,0,0,0,1310,1311,5,36,0,0,1311,306,1,0,0, + 0,1312,1313,5,46,0,0,1313,308,1,0,0,0,1314,1315,5,61,0,0,1315,1316, + 5,61,0,0,1316,310,1,0,0,0,1317,1318,5,61,0,0,1318,312,1,0,0,0,1319, + 1320,5,62,0,0,1320,1321,5,61,0,0,1321,314,1,0,0,0,1322,1323,5,62, + 0,0,1323,316,1,0,0,0,1324,1325,5,35,0,0,1325,318,1,0,0,0,1326,1327, + 5,126,0,0,1327,1328,5,42,0,0,1328,320,1,0,0,0,1329,1330,5,61,0,0, + 1330,1331,5,126,0,0,1331,1332,5,42,0,0,1332,322,1,0,0,0,1333,1334, + 5,123,0,0,1334,1335,1,0,0,0,1335,1336,6,160,0,0,1336,324,1,0,0,0, + 1337,1338,5,91,0,0,1338,326,1,0,0,0,1339,1340,5,40,0,0,1340,328, + 1,0,0,0,1341,1342,5,60,0,0,1342,1343,5,61,0,0,1343,330,1,0,0,0,1344, + 1345,5,60,0,0,1345,332,1,0,0,0,1346,1347,5,33,0,0,1347,1351,5,61, + 0,0,1348,1349,5,60,0,0,1349,1351,5,62,0,0,1350,1346,1,0,0,0,1350, + 1348,1,0,0,0,1351,334,1,0,0,0,1352,1353,5,33,0,0,1353,1354,5,126, + 0,0,1354,1355,5,42,0,0,1355,336,1,0,0,0,1356,1357,5,33,0,0,1357, + 1358,5,126,0,0,1358,338,1,0,0,0,1359,1360,5,63,0,0,1360,1361,5,46, + 0,0,1361,340,1,0,0,0,1362,1363,5,63,0,0,1363,1364,5,63,0,0,1364, + 342,1,0,0,0,1365,1366,5,37,0,0,1366,344,1,0,0,0,1367,1368,5,43,0, + 0,1368,346,1,0,0,0,1369,1370,5,63,0,0,1370,348,1,0,0,0,1371,1372, + 5,34,0,0,1372,350,1,0,0,0,1373,1374,5,102,0,0,1374,1375,5,39,0,0, + 1375,1376,1,0,0,0,1376,1377,6,174,1,0,1377,352,1,0,0,0,1378,1379, + 5,70,0,0,1379,1380,5,39,0,0,1380,1381,1,0,0,0,1381,1382,6,175,2, + 0,1382,354,1,0,0,0,1383,1384,5,39,0,0,1384,356,1,0,0,0,1385,1386, + 5,126,0,0,1386,358,1,0,0,0,1387,1388,5,61,0,0,1388,1389,5,126,0, + 0,1389,360,1,0,0,0,1390,1391,5,125,0,0,1391,1392,1,0,0,0,1392,1393, + 6,179,3,0,1393,362,1,0,0,0,1394,1395,5,93,0,0,1395,364,1,0,0,0,1396, + 1397,5,41,0,0,1397,366,1,0,0,0,1398,1399,5,59,0,0,1399,368,1,0,0, + 0,1400,1401,5,47,0,0,1401,370,1,0,0,0,1402,1403,5,95,0,0,1403,372, + 1,0,0,0,1404,1405,5,47,0,0,1405,1406,5,42,0,0,1406,1410,1,0,0,0, + 1407,1409,9,0,0,0,1408,1407,1,0,0,0,1409,1412,1,0,0,0,1410,1411, + 1,0,0,0,1410,1408,1,0,0,0,1411,1413,1,0,0,0,1412,1410,1,0,0,0,1413, + 1414,5,42,0,0,1414,1415,5,47,0,0,1415,1416,1,0,0,0,1416,1417,6,185, + 4,0,1417,374,1,0,0,0,1418,1419,5,45,0,0,1419,1423,5,45,0,0,1420, + 1421,5,47,0,0,1421,1423,5,47,0,0,1422,1418,1,0,0,0,1422,1420,1,0, + 0,0,1423,1427,1,0,0,0,1424,1426,8,33,0,0,1425,1424,1,0,0,0,1426, + 1429,1,0,0,0,1427,1425,1,0,0,0,1427,1428,1,0,0,0,1428,1431,1,0,0, + 0,1429,1427,1,0,0,0,1430,1432,7,34,0,0,1431,1430,1,0,0,0,1432,1433, + 1,0,0,0,1433,1434,6,186,4,0,1434,376,1,0,0,0,1435,1436,7,35,0,0, + 1436,1437,1,0,0,0,1437,1438,6,187,5,0,1438,378,1,0,0,0,1439,1451, + 8,36,0,0,1440,1451,3,215,106,0,1441,1442,3,295,146,0,1442,1443,3, + 355,176,0,1443,1451,1,0,0,0,1444,1445,3,295,146,0,1445,1446,3,323, + 160,0,1446,1451,1,0,0,0,1447,1448,3,355,176,0,1448,1449,3,355,176, + 0,1449,1451,1,0,0,0,1450,1439,1,0,0,0,1450,1440,1,0,0,0,1450,1441, + 1,0,0,0,1450,1444,1,0,0,0,1450,1447,1,0,0,0,1451,1452,1,0,0,0,1452, + 1450,1,0,0,0,1452,1453,1,0,0,0,1453,380,1,0,0,0,1454,1455,3,323, + 160,0,1455,1456,1,0,0,0,1456,1457,6,189,0,0,1457,382,1,0,0,0,1458, + 1459,3,355,176,0,1459,1460,1,0,0,0,1460,1461,6,190,6,0,1461,1462, + 6,190,3,0,1462,384,1,0,0,0,1463,1469,8,37,0,0,1464,1469,3,215,106, + 0,1465,1466,3,295,146,0,1466,1467,3,323,160,0,1467,1469,1,0,0,0, + 1468,1463,1,0,0,0,1468,1464,1,0,0,0,1468,1465,1,0,0,0,1469,1470, + 1,0,0,0,1470,1468,1,0,0,0,1470,1471,1,0,0,0,1471,386,1,0,0,0,1472, + 1473,3,323,160,0,1473,1474,1,0,0,0,1474,1475,6,192,0,0,1475,388, + 1,0,0,0,44,0,1,2,429,657,1041,1070,1075,1081,1083,1095,1097,1111, + 1113,1118,1125,1130,1134,1139,1144,1148,1153,1160,1166,1171,1178, + 1183,1189,1194,1196,1202,1207,1214,1225,1227,1350,1410,1422,1427, + 1431,1450,1452,1468,1470,7,5,0,0,5,1,0,5,2,0,4,0,0,6,0,0,0,1,0,7, + 147,0 ] class HogQLLexer(Lexer): @@ -621,140 +630,142 @@ class HogQLLexer(Lexer): DISTINCT = 24 ELSE = 25 END = 26 - EXTRACT = 27 - FINAL = 28 - FINALLY = 29 - FIRST = 30 - FN = 31 - FOLLOWING = 32 - FOR = 33 - FROM = 34 - FULL = 35 - FUN = 36 - GROUP = 37 - HAVING = 38 - HOUR = 39 - ID = 40 - IF = 41 - ILIKE = 42 - IN = 43 - INF = 44 - INNER = 45 - INTERVAL = 46 - IS = 47 - JOIN = 48 - KEY = 49 - LAST = 50 - LEADING = 51 - LEFT = 52 - LET = 53 - LIKE = 54 - LIMIT = 55 - MINUTE = 56 - MONTH = 57 - NAN_SQL = 58 - NOT = 59 - NULL_SQL = 60 - NULLS = 61 - OFFSET = 62 - ON = 63 - OR = 64 - ORDER = 65 - OUTER = 66 - OVER = 67 - PARTITION = 68 - PRECEDING = 69 - PREWHERE = 70 - QUARTER = 71 - RANGE = 72 - RETURN = 73 - RIGHT = 74 - ROLLUP = 75 - ROW = 76 - ROWS = 77 - SAMPLE = 78 - SECOND = 79 - SELECT = 80 - SEMI = 81 - SETTINGS = 82 - SUBSTRING = 83 - THEN = 84 - THROW = 85 - TIES = 86 - TIMESTAMP = 87 - TO = 88 - TOP = 89 - TOTALS = 90 - TRAILING = 91 - TRIM = 92 - TRUNCATE = 93 - TRY = 94 - UNBOUNDED = 95 - UNION = 96 - USING = 97 - WEEK = 98 - WHEN = 99 - WHERE = 100 - WHILE = 101 - WINDOW = 102 - WITH = 103 - YEAR = 104 - ESCAPE_CHAR_COMMON = 105 - IDENTIFIER = 106 - FLOATING_LITERAL = 107 - OCTAL_LITERAL = 108 - DECIMAL_LITERAL = 109 - HEXADECIMAL_LITERAL = 110 - STRING_LITERAL = 111 - ARROW = 112 - ASTERISK = 113 - BACKQUOTE = 114 - BACKSLASH = 115 - COLON = 116 - COMMA = 117 - CONCAT = 118 - DASH = 119 - DOLLAR = 120 - DOT = 121 - EQ_DOUBLE = 122 - EQ_SINGLE = 123 - GT_EQ = 124 - GT = 125 - HASH = 126 - IREGEX_SINGLE = 127 - IREGEX_DOUBLE = 128 - LBRACE = 129 - LBRACKET = 130 - LPAREN = 131 - LT_EQ = 132 - LT = 133 - NOT_EQ = 134 - NOT_IREGEX = 135 - NOT_REGEX = 136 - NULL_PROPERTY = 137 - NULLISH = 138 - PERCENT = 139 - PLUS = 140 - QUERY = 141 - QUOTE_DOUBLE = 142 - QUOTE_SINGLE_TEMPLATE = 143 - QUOTE_SINGLE_TEMPLATE_FULL = 144 - QUOTE_SINGLE = 145 - REGEX_SINGLE = 146 - REGEX_DOUBLE = 147 - RBRACE = 148 - RBRACKET = 149 - RPAREN = 150 - SEMICOLON = 151 - SLASH = 152 - UNDERSCORE = 153 - MULTI_LINE_COMMENT = 154 - SINGLE_LINE_COMMENT = 155 - WHITESPACE = 156 - STRING_TEXT = 157 - STRING_ESCAPE_TRIGGER = 158 - FULL_STRING_TEXT = 159 - FULL_STRING_ESCAPE_TRIGGER = 160 + EXCEPT = 27 + EXTRACT = 28 + FINAL = 29 + FINALLY = 30 + FIRST = 31 + FN = 32 + FOLLOWING = 33 + FOR = 34 + FROM = 35 + FULL = 36 + FUN = 37 + GROUP = 38 + HAVING = 39 + HOUR = 40 + ID = 41 + IF = 42 + ILIKE = 43 + IN = 44 + INF = 45 + INNER = 46 + INTERSECT = 47 + INTERVAL = 48 + IS = 49 + JOIN = 50 + KEY = 51 + LAST = 52 + LEADING = 53 + LEFT = 54 + LET = 55 + LIKE = 56 + LIMIT = 57 + MINUTE = 58 + MONTH = 59 + NAN_SQL = 60 + NOT = 61 + NULL_SQL = 62 + NULLS = 63 + OFFSET = 64 + ON = 65 + OR = 66 + ORDER = 67 + OUTER = 68 + OVER = 69 + PARTITION = 70 + PRECEDING = 71 + PREWHERE = 72 + QUARTER = 73 + RANGE = 74 + RETURN = 75 + RIGHT = 76 + ROLLUP = 77 + ROW = 78 + ROWS = 79 + SAMPLE = 80 + SECOND = 81 + SELECT = 82 + SEMI = 83 + SETTINGS = 84 + SUBSTRING = 85 + THEN = 86 + THROW = 87 + TIES = 88 + TIMESTAMP = 89 + TO = 90 + TOP = 91 + TOTALS = 92 + TRAILING = 93 + TRIM = 94 + TRUNCATE = 95 + TRY = 96 + UNBOUNDED = 97 + UNION = 98 + USING = 99 + WEEK = 100 + WHEN = 101 + WHERE = 102 + WHILE = 103 + WINDOW = 104 + WITH = 105 + YEAR = 106 + ESCAPE_CHAR_COMMON = 107 + IDENTIFIER = 108 + FLOATING_LITERAL = 109 + OCTAL_LITERAL = 110 + DECIMAL_LITERAL = 111 + HEXADECIMAL_LITERAL = 112 + STRING_LITERAL = 113 + ARROW = 114 + ASTERISK = 115 + BACKQUOTE = 116 + BACKSLASH = 117 + COLON = 118 + COMMA = 119 + CONCAT = 120 + DASH = 121 + DOLLAR = 122 + DOT = 123 + EQ_DOUBLE = 124 + EQ_SINGLE = 125 + GT_EQ = 126 + GT = 127 + HASH = 128 + IREGEX_SINGLE = 129 + IREGEX_DOUBLE = 130 + LBRACE = 131 + LBRACKET = 132 + LPAREN = 133 + LT_EQ = 134 + LT = 135 + NOT_EQ = 136 + NOT_IREGEX = 137 + NOT_REGEX = 138 + NULL_PROPERTY = 139 + NULLISH = 140 + PERCENT = 141 + PLUS = 142 + QUERY = 143 + QUOTE_DOUBLE = 144 + QUOTE_SINGLE_TEMPLATE = 145 + QUOTE_SINGLE_TEMPLATE_FULL = 146 + QUOTE_SINGLE = 147 + REGEX_SINGLE = 148 + REGEX_DOUBLE = 149 + RBRACE = 150 + RBRACKET = 151 + RPAREN = 152 + SEMICOLON = 153 + SLASH = 154 + UNDERSCORE = 155 + MULTI_LINE_COMMENT = 156 + SINGLE_LINE_COMMENT = 157 + WHITESPACE = 158 + STRING_TEXT = 159 + STRING_ESCAPE_TRIGGER = 160 + FULL_STRING_TEXT = 161 + FULL_STRING_ESCAPE_TRIGGER = 162 channelNames = [ u"DEFAULT_TOKEN_CHANNEL", u"HIDDEN" ] @@ -771,64 +782,64 @@ class HogQLLexer(Lexer): "ALL", "AND", "ANTI", "ANY", "ARRAY", "AS", "ASCENDING", "ASOF", "BETWEEN", "BOTH", "BY", "CASE", "CAST", "CATCH", "COHORT", "COLLATE", "CROSS", "CUBE", "CURRENT", "DATE", "DAY", "DESC", - "DESCENDING", "DISTINCT", "ELSE", "END", "EXTRACT", "FINAL", - "FINALLY", "FIRST", "FN", "FOLLOWING", "FOR", "FROM", "FULL", - "FUN", "GROUP", "HAVING", "HOUR", "ID", "IF", "ILIKE", "IN", - "INF", "INNER", "INTERVAL", "IS", "JOIN", "KEY", "LAST", "LEADING", - "LEFT", "LET", "LIKE", "LIMIT", "MINUTE", "MONTH", "NAN_SQL", - "NOT", "NULL_SQL", "NULLS", "OFFSET", "ON", "OR", "ORDER", "OUTER", - "OVER", "PARTITION", "PRECEDING", "PREWHERE", "QUARTER", "RANGE", - "RETURN", "RIGHT", "ROLLUP", "ROW", "ROWS", "SAMPLE", "SECOND", - "SELECT", "SEMI", "SETTINGS", "SUBSTRING", "THEN", "THROW", - "TIES", "TIMESTAMP", "TO", "TOP", "TOTALS", "TRAILING", "TRIM", - "TRUNCATE", "TRY", "UNBOUNDED", "UNION", "USING", "WEEK", "WHEN", - "WHERE", "WHILE", "WINDOW", "WITH", "YEAR", "ESCAPE_CHAR_COMMON", - "IDENTIFIER", "FLOATING_LITERAL", "OCTAL_LITERAL", "DECIMAL_LITERAL", - "HEXADECIMAL_LITERAL", "STRING_LITERAL", "ARROW", "ASTERISK", - "BACKQUOTE", "BACKSLASH", "COLON", "COMMA", "CONCAT", "DASH", - "DOLLAR", "DOT", "EQ_DOUBLE", "EQ_SINGLE", "GT_EQ", "GT", "HASH", - "IREGEX_SINGLE", "IREGEX_DOUBLE", "LBRACE", "LBRACKET", "LPAREN", - "LT_EQ", "LT", "NOT_EQ", "NOT_IREGEX", "NOT_REGEX", "NULL_PROPERTY", - "NULLISH", "PERCENT", "PLUS", "QUERY", "QUOTE_DOUBLE", "QUOTE_SINGLE_TEMPLATE", - "QUOTE_SINGLE_TEMPLATE_FULL", "QUOTE_SINGLE", "REGEX_SINGLE", - "REGEX_DOUBLE", "RBRACE", "RBRACKET", "RPAREN", "SEMICOLON", - "SLASH", "UNDERSCORE", "MULTI_LINE_COMMENT", "SINGLE_LINE_COMMENT", - "WHITESPACE", "STRING_TEXT", "STRING_ESCAPE_TRIGGER", "FULL_STRING_TEXT", - "FULL_STRING_ESCAPE_TRIGGER" ] + "DESCENDING", "DISTINCT", "ELSE", "END", "EXCEPT", "EXTRACT", + "FINAL", "FINALLY", "FIRST", "FN", "FOLLOWING", "FOR", "FROM", + "FULL", "FUN", "GROUP", "HAVING", "HOUR", "ID", "IF", "ILIKE", + "IN", "INF", "INNER", "INTERSECT", "INTERVAL", "IS", "JOIN", + "KEY", "LAST", "LEADING", "LEFT", "LET", "LIKE", "LIMIT", "MINUTE", + "MONTH", "NAN_SQL", "NOT", "NULL_SQL", "NULLS", "OFFSET", "ON", + "OR", "ORDER", "OUTER", "OVER", "PARTITION", "PRECEDING", "PREWHERE", + "QUARTER", "RANGE", "RETURN", "RIGHT", "ROLLUP", "ROW", "ROWS", + "SAMPLE", "SECOND", "SELECT", "SEMI", "SETTINGS", "SUBSTRING", + "THEN", "THROW", "TIES", "TIMESTAMP", "TO", "TOP", "TOTALS", + "TRAILING", "TRIM", "TRUNCATE", "TRY", "UNBOUNDED", "UNION", + "USING", "WEEK", "WHEN", "WHERE", "WHILE", "WINDOW", "WITH", + "YEAR", "ESCAPE_CHAR_COMMON", "IDENTIFIER", "FLOATING_LITERAL", + "OCTAL_LITERAL", "DECIMAL_LITERAL", "HEXADECIMAL_LITERAL", "STRING_LITERAL", + "ARROW", "ASTERISK", "BACKQUOTE", "BACKSLASH", "COLON", "COMMA", + "CONCAT", "DASH", "DOLLAR", "DOT", "EQ_DOUBLE", "EQ_SINGLE", + "GT_EQ", "GT", "HASH", "IREGEX_SINGLE", "IREGEX_DOUBLE", "LBRACE", + "LBRACKET", "LPAREN", "LT_EQ", "LT", "NOT_EQ", "NOT_IREGEX", + "NOT_REGEX", "NULL_PROPERTY", "NULLISH", "PERCENT", "PLUS", + "QUERY", "QUOTE_DOUBLE", "QUOTE_SINGLE_TEMPLATE", "QUOTE_SINGLE_TEMPLATE_FULL", + "QUOTE_SINGLE", "REGEX_SINGLE", "REGEX_DOUBLE", "RBRACE", "RBRACKET", + "RPAREN", "SEMICOLON", "SLASH", "UNDERSCORE", "MULTI_LINE_COMMENT", + "SINGLE_LINE_COMMENT", "WHITESPACE", "STRING_TEXT", "STRING_ESCAPE_TRIGGER", + "FULL_STRING_TEXT", "FULL_STRING_ESCAPE_TRIGGER" ] ruleNames = [ "ALL", "AND", "ANTI", "ANY", "ARRAY", "AS", "ASCENDING", "ASOF", "BETWEEN", "BOTH", "BY", "CASE", "CAST", "CATCH", "COHORT", "COLLATE", "CROSS", "CUBE", "CURRENT", "DATE", "DAY", "DESC", "DESCENDING", "DISTINCT", "ELSE", "END", - "EXTRACT", "FINAL", "FINALLY", "FIRST", "FN", "FOLLOWING", - "FOR", "FROM", "FULL", "FUN", "GROUP", "HAVING", "HOUR", - "ID", "IF", "ILIKE", "IN", "INF", "INNER", "INTERVAL", - "IS", "JOIN", "KEY", "LAST", "LEADING", "LEFT", "LET", - "LIKE", "LIMIT", "MINUTE", "MONTH", "NAN_SQL", "NOT", - "NULL_SQL", "NULLS", "OFFSET", "ON", "OR", "ORDER", "OUTER", - "OVER", "PARTITION", "PRECEDING", "PREWHERE", "QUARTER", - "RANGE", "RETURN", "RIGHT", "ROLLUP", "ROW", "ROWS", "SAMPLE", - "SECOND", "SELECT", "SEMI", "SETTINGS", "SUBSTRING", "THEN", - "THROW", "TIES", "TIMESTAMP", "TO", "TOP", "TOTALS", "TRAILING", - "TRIM", "TRUNCATE", "TRY", "UNBOUNDED", "UNION", "USING", - "WEEK", "WHEN", "WHERE", "WHILE", "WINDOW", "WITH", "YEAR", - "ESCAPE_CHAR_COMMON", "IDENTIFIER", "FLOATING_LITERAL", - "OCTAL_LITERAL", "DECIMAL_LITERAL", "HEXADECIMAL_LITERAL", - "STRING_LITERAL", "A", "B", "C", "D", "E", "F", "G", "H", - "I", "J", "K", "L", "M", "N", "O", "P", "Q", "R", "S", - "T", "U", "V", "W", "X", "Y", "Z", "LETTER", "OCT_DIGIT", - "DEC_DIGIT", "HEX_DIGIT", "ARROW", "ASTERISK", "BACKQUOTE", - "BACKSLASH", "COLON", "COMMA", "CONCAT", "DASH", "DOLLAR", - "DOT", "EQ_DOUBLE", "EQ_SINGLE", "GT_EQ", "GT", "HASH", - "IREGEX_SINGLE", "IREGEX_DOUBLE", "LBRACE", "LBRACKET", - "LPAREN", "LT_EQ", "LT", "NOT_EQ", "NOT_IREGEX", "NOT_REGEX", - "NULL_PROPERTY", "NULLISH", "PERCENT", "PLUS", "QUERY", - "QUOTE_DOUBLE", "QUOTE_SINGLE_TEMPLATE", "QUOTE_SINGLE_TEMPLATE_FULL", - "QUOTE_SINGLE", "REGEX_SINGLE", "REGEX_DOUBLE", "RBRACE", - "RBRACKET", "RPAREN", "SEMICOLON", "SLASH", "UNDERSCORE", - "MULTI_LINE_COMMENT", "SINGLE_LINE_COMMENT", "WHITESPACE", - "STRING_TEXT", "STRING_ESCAPE_TRIGGER", "STRING_QUOTE_SINGLE", - "FULL_STRING_TEXT", "FULL_STRING_ESCAPE_TRIGGER" ] + "EXCEPT", "EXTRACT", "FINAL", "FINALLY", "FIRST", "FN", + "FOLLOWING", "FOR", "FROM", "FULL", "FUN", "GROUP", "HAVING", + "HOUR", "ID", "IF", "ILIKE", "IN", "INF", "INNER", "INTERSECT", + "INTERVAL", "IS", "JOIN", "KEY", "LAST", "LEADING", "LEFT", + "LET", "LIKE", "LIMIT", "MINUTE", "MONTH", "NAN_SQL", + "NOT", "NULL_SQL", "NULLS", "OFFSET", "ON", "OR", "ORDER", + "OUTER", "OVER", "PARTITION", "PRECEDING", "PREWHERE", + "QUARTER", "RANGE", "RETURN", "RIGHT", "ROLLUP", "ROW", + "ROWS", "SAMPLE", "SECOND", "SELECT", "SEMI", "SETTINGS", + "SUBSTRING", "THEN", "THROW", "TIES", "TIMESTAMP", "TO", + "TOP", "TOTALS", "TRAILING", "TRIM", "TRUNCATE", "TRY", + "UNBOUNDED", "UNION", "USING", "WEEK", "WHEN", "WHERE", + "WHILE", "WINDOW", "WITH", "YEAR", "ESCAPE_CHAR_COMMON", + "IDENTIFIER", "FLOATING_LITERAL", "OCTAL_LITERAL", "DECIMAL_LITERAL", + "HEXADECIMAL_LITERAL", "STRING_LITERAL", "A", "B", "C", + "D", "E", "F", "G", "H", "I", "J", "K", "L", "M", "N", + "O", "P", "Q", "R", "S", "T", "U", "V", "W", "X", "Y", + "Z", "LETTER", "OCT_DIGIT", "DEC_DIGIT", "HEX_DIGIT", + "ARROW", "ASTERISK", "BACKQUOTE", "BACKSLASH", "COLON", + "COMMA", "CONCAT", "DASH", "DOLLAR", "DOT", "EQ_DOUBLE", + "EQ_SINGLE", "GT_EQ", "GT", "HASH", "IREGEX_SINGLE", "IREGEX_DOUBLE", + "LBRACE", "LBRACKET", "LPAREN", "LT_EQ", "LT", "NOT_EQ", + "NOT_IREGEX", "NOT_REGEX", "NULL_PROPERTY", "NULLISH", + "PERCENT", "PLUS", "QUERY", "QUOTE_DOUBLE", "QUOTE_SINGLE_TEMPLATE", + "QUOTE_SINGLE_TEMPLATE_FULL", "QUOTE_SINGLE", "REGEX_SINGLE", + "REGEX_DOUBLE", "RBRACE", "RBRACKET", "RPAREN", "SEMICOLON", + "SLASH", "UNDERSCORE", "MULTI_LINE_COMMENT", "SINGLE_LINE_COMMENT", + "WHITESPACE", "STRING_TEXT", "STRING_ESCAPE_TRIGGER", + "STRING_QUOTE_SINGLE", "FULL_STRING_TEXT", "FULL_STRING_ESCAPE_TRIGGER" ] grammarFileName = "HogQLLexer.g4" diff --git a/posthog/hogql/grammar/HogQLLexer.tokens b/posthog/hogql/grammar/HogQLLexer.tokens index 8658dc473b899..f370b819d5a0d 100644 --- a/posthog/hogql/grammar/HogQLLexer.tokens +++ b/posthog/hogql/grammar/HogQLLexer.tokens @@ -24,178 +24,180 @@ DESCENDING=23 DISTINCT=24 ELSE=25 END=26 -EXTRACT=27 -FINAL=28 -FINALLY=29 -FIRST=30 -FN=31 -FOLLOWING=32 -FOR=33 -FROM=34 -FULL=35 -FUN=36 -GROUP=37 -HAVING=38 -HOUR=39 -ID=40 -IF=41 -ILIKE=42 -IN=43 -INF=44 -INNER=45 -INTERVAL=46 -IS=47 -JOIN=48 -KEY=49 -LAST=50 -LEADING=51 -LEFT=52 -LET=53 -LIKE=54 -LIMIT=55 -MINUTE=56 -MONTH=57 -NAN_SQL=58 -NOT=59 -NULL_SQL=60 -NULLS=61 -OFFSET=62 -ON=63 -OR=64 -ORDER=65 -OUTER=66 -OVER=67 -PARTITION=68 -PRECEDING=69 -PREWHERE=70 -QUARTER=71 -RANGE=72 -RETURN=73 -RIGHT=74 -ROLLUP=75 -ROW=76 -ROWS=77 -SAMPLE=78 -SECOND=79 -SELECT=80 -SEMI=81 -SETTINGS=82 -SUBSTRING=83 -THEN=84 -THROW=85 -TIES=86 -TIMESTAMP=87 -TO=88 -TOP=89 -TOTALS=90 -TRAILING=91 -TRIM=92 -TRUNCATE=93 -TRY=94 -UNBOUNDED=95 -UNION=96 -USING=97 -WEEK=98 -WHEN=99 -WHERE=100 -WHILE=101 -WINDOW=102 -WITH=103 -YEAR=104 -ESCAPE_CHAR_COMMON=105 -IDENTIFIER=106 -FLOATING_LITERAL=107 -OCTAL_LITERAL=108 -DECIMAL_LITERAL=109 -HEXADECIMAL_LITERAL=110 -STRING_LITERAL=111 -ARROW=112 -ASTERISK=113 -BACKQUOTE=114 -BACKSLASH=115 -COLON=116 -COMMA=117 -CONCAT=118 -DASH=119 -DOLLAR=120 -DOT=121 -EQ_DOUBLE=122 -EQ_SINGLE=123 -GT_EQ=124 -GT=125 -HASH=126 -IREGEX_SINGLE=127 -IREGEX_DOUBLE=128 -LBRACE=129 -LBRACKET=130 -LPAREN=131 -LT_EQ=132 -LT=133 -NOT_EQ=134 -NOT_IREGEX=135 -NOT_REGEX=136 -NULL_PROPERTY=137 -NULLISH=138 -PERCENT=139 -PLUS=140 -QUERY=141 -QUOTE_DOUBLE=142 -QUOTE_SINGLE_TEMPLATE=143 -QUOTE_SINGLE_TEMPLATE_FULL=144 -QUOTE_SINGLE=145 -REGEX_SINGLE=146 -REGEX_DOUBLE=147 -RBRACE=148 -RBRACKET=149 -RPAREN=150 -SEMICOLON=151 -SLASH=152 -UNDERSCORE=153 -MULTI_LINE_COMMENT=154 -SINGLE_LINE_COMMENT=155 -WHITESPACE=156 -STRING_TEXT=157 -STRING_ESCAPE_TRIGGER=158 -FULL_STRING_TEXT=159 -FULL_STRING_ESCAPE_TRIGGER=160 -'->'=112 -'*'=113 -'`'=114 -'\\'=115 -':'=116 -','=117 -'||'=118 -'-'=119 -'$'=120 -'.'=121 -'=='=122 -'='=123 -'>='=124 -'>'=125 -'#'=126 -'~*'=127 -'=~*'=128 -'{'=129 -'['=130 -'('=131 -'<='=132 -'<'=133 -'!~*'=135 -'!~'=136 -'?.'=137 -'??'=138 -'%'=139 -'+'=140 -'?'=141 -'"'=142 -'f\''=143 -'F\''=144 -'\''=145 -'~'=146 -'=~'=147 -'}'=148 -']'=149 -')'=150 -';'=151 -'/'=152 -'_'=153 +EXCEPT=27 +EXTRACT=28 +FINAL=29 +FINALLY=30 +FIRST=31 +FN=32 +FOLLOWING=33 +FOR=34 +FROM=35 +FULL=36 +FUN=37 +GROUP=38 +HAVING=39 +HOUR=40 +ID=41 +IF=42 +ILIKE=43 +IN=44 +INF=45 +INNER=46 +INTERSECT=47 +INTERVAL=48 +IS=49 +JOIN=50 +KEY=51 +LAST=52 +LEADING=53 +LEFT=54 +LET=55 +LIKE=56 +LIMIT=57 +MINUTE=58 +MONTH=59 +NAN_SQL=60 +NOT=61 +NULL_SQL=62 +NULLS=63 +OFFSET=64 +ON=65 +OR=66 +ORDER=67 +OUTER=68 +OVER=69 +PARTITION=70 +PRECEDING=71 +PREWHERE=72 +QUARTER=73 +RANGE=74 +RETURN=75 +RIGHT=76 +ROLLUP=77 +ROW=78 +ROWS=79 +SAMPLE=80 +SECOND=81 +SELECT=82 +SEMI=83 +SETTINGS=84 +SUBSTRING=85 +THEN=86 +THROW=87 +TIES=88 +TIMESTAMP=89 +TO=90 +TOP=91 +TOTALS=92 +TRAILING=93 +TRIM=94 +TRUNCATE=95 +TRY=96 +UNBOUNDED=97 +UNION=98 +USING=99 +WEEK=100 +WHEN=101 +WHERE=102 +WHILE=103 +WINDOW=104 +WITH=105 +YEAR=106 +ESCAPE_CHAR_COMMON=107 +IDENTIFIER=108 +FLOATING_LITERAL=109 +OCTAL_LITERAL=110 +DECIMAL_LITERAL=111 +HEXADECIMAL_LITERAL=112 +STRING_LITERAL=113 +ARROW=114 +ASTERISK=115 +BACKQUOTE=116 +BACKSLASH=117 +COLON=118 +COMMA=119 +CONCAT=120 +DASH=121 +DOLLAR=122 +DOT=123 +EQ_DOUBLE=124 +EQ_SINGLE=125 +GT_EQ=126 +GT=127 +HASH=128 +IREGEX_SINGLE=129 +IREGEX_DOUBLE=130 +LBRACE=131 +LBRACKET=132 +LPAREN=133 +LT_EQ=134 +LT=135 +NOT_EQ=136 +NOT_IREGEX=137 +NOT_REGEX=138 +NULL_PROPERTY=139 +NULLISH=140 +PERCENT=141 +PLUS=142 +QUERY=143 +QUOTE_DOUBLE=144 +QUOTE_SINGLE_TEMPLATE=145 +QUOTE_SINGLE_TEMPLATE_FULL=146 +QUOTE_SINGLE=147 +REGEX_SINGLE=148 +REGEX_DOUBLE=149 +RBRACE=150 +RBRACKET=151 +RPAREN=152 +SEMICOLON=153 +SLASH=154 +UNDERSCORE=155 +MULTI_LINE_COMMENT=156 +SINGLE_LINE_COMMENT=157 +WHITESPACE=158 +STRING_TEXT=159 +STRING_ESCAPE_TRIGGER=160 +FULL_STRING_TEXT=161 +FULL_STRING_ESCAPE_TRIGGER=162 +'->'=114 +'*'=115 +'`'=116 +'\\'=117 +':'=118 +','=119 +'||'=120 +'-'=121 +'$'=122 +'.'=123 +'=='=124 +'='=125 +'>='=126 +'>'=127 +'#'=128 +'~*'=129 +'=~*'=130 +'{'=131 +'['=132 +'('=133 +'<='=134 +'<'=135 +'!~*'=137 +'!~'=138 +'?.'=139 +'??'=140 +'%'=141 +'+'=142 +'?'=143 +'"'=144 +'f\''=145 +'F\''=146 +'\''=147 +'~'=148 +'=~'=149 +'}'=150 +']'=151 +')'=152 +';'=153 +'/'=154 +'_'=155 diff --git a/posthog/hogql/grammar/HogQLParser.g4 b/posthog/hogql/grammar/HogQLParser.g4 index ecc89c4eb5543..7f0e482e31498 100644 --- a/posthog/hogql/grammar/HogQLParser.g4 +++ b/posthog/hogql/grammar/HogQLParser.g4 @@ -51,10 +51,12 @@ kvPairList: kvPair (COMMA kvPair)* COMMA?; // SELECT statement -select: (selectUnionStmt | selectStmt | hogqlxTagElement) EOF; +select: (selectSetStmt | selectStmt | hogqlxTagElement) EOF; -selectUnionStmt: selectStmtWithParens (UNION ALL selectStmtWithParens)*; -selectStmtWithParens: selectStmt | LPAREN selectUnionStmt RPAREN | placeholder; +selectStmtWithParens: selectStmt | LPAREN selectSetStmt RPAREN | placeholder; + +subsequentSelectSetClause: (EXCEPT | UNION ALL | INTERSECT) selectStmtWithParens; +selectSetStmt: selectStmtWithParens (subsequentSelectSetClause)*; selectStmt: with=withClause? @@ -201,7 +203,7 @@ columnExpr | columnExpr QUERY columnExpr COLON columnExpr # ColumnExprTernaryOp | columnExpr (AS identifier | AS STRING_LITERAL) # ColumnExprAlias | (tableIdentifier DOT)? ASTERISK # ColumnExprAsterisk // single-column only - | LPAREN selectUnionStmt RPAREN # ColumnExprSubquery // single-column only + | LPAREN selectSetStmt RPAREN # ColumnExprSubquery // single-column only | LPAREN columnExpr RPAREN # ColumnExprParens // single-column only | LPAREN columnExprList RPAREN # ColumnExprTuple | LBRACKET columnExprList? RBRACKET # ColumnExprArray @@ -231,7 +233,7 @@ hogqlxTagAttribute withExprList: withExpr (COMMA withExpr)* COMMA?; withExpr - : identifier AS LPAREN selectUnionStmt RPAREN # WithExprSubquery + : identifier AS LPAREN selectSetStmt RPAREN # WithExprSubquery // NOTE: asterisk and subquery goes before |columnExpr| so that we can mark them as multi-column expressions. | columnExpr AS identifier # WithExprColumn ; @@ -246,7 +248,7 @@ nestedIdentifier: identifier (DOT identifier)*; tableExpr : tableIdentifier # TableExprIdentifier | tableFunctionExpr # TableExprFunction - | LPAREN selectUnionStmt RPAREN # TableExprSubquery + | LPAREN selectSetStmt RPAREN # TableExprSubquery | tableExpr (alias | AS identifier) # TableExprAlias | hogqlxTagElement # TableExprTag | placeholder # TableExprPlaceholder diff --git a/posthog/hogql/grammar/HogQLParser.interp b/posthog/hogql/grammar/HogQLParser.interp index 86b5777f1ff22..4308ee42ae9b9 100644 --- a/posthog/hogql/grammar/HogQLParser.interp +++ b/posthog/hogql/grammar/HogQLParser.interp @@ -111,6 +111,8 @@ null null null null +null +null '->' '*' '`' @@ -189,6 +191,7 @@ DESCENDING DISTINCT ELSE END +EXCEPT EXTRACT FINAL FINALLY @@ -208,6 +211,7 @@ ILIKE IN INF INNER +INTERSECT INTERVAL IS JOIN @@ -347,8 +351,9 @@ block kvPair kvPairList select -selectUnionStmt selectStmtWithParens +subsequentSelectSetClause +selectSetStmt selectStmt withClause topClause @@ -414,4 +419,4 @@ stringContentsFull atn: -[4, 1, 160, 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, 17, 2, 0, 31, 31, 36, 36, 2, 0, 18, 18, 75, 75, 2, 0, 45, 45, 52, 52, 3, 0, 1, 1, 4, 4, 8, 8, 4, 0, 1, 1, 3, 4, 8, 8, 81, 81, 2, 0, 52, 52, 74, 74, 2, 0, 1, 1, 4, 4, 2, 0, 7, 7, 22, 23, 2, 0, 30, 30, 50, 50, 2, 0, 72, 72, 77, 77, 3, 0, 10, 10, 51, 51, 91, 91, 2, 0, 42, 42, 54, 54, 1, 0, 108, 109, 2, 0, 119, 119, 140, 140, 7, 0, 21, 21, 39, 39, 56, 57, 71, 71, 79, 79, 98, 98, 104, 104, 17, 0, 1, 13, 15, 20, 22, 28, 30, 30, 32, 35, 37, 38, 40, 43, 45, 52, 54, 55, 59, 59, 61, 70, 72, 78, 80, 84, 86, 93, 95, 97, 99, 100, 102, 103, 4, 0, 20, 20, 30, 30, 40, 40, 49, 49, 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, 53, 0, 0, 187, 191, 3, 156, 78, 0, 188, 189, 5, 116, 0, 0, 189, 190, 5, 123, 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, 117, 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, 117, 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, 73, 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, 151, 0, 0, 223, 222, 1, 0, 0, 0, 223, 224, 1, 0, 0, 0, 224, 13, 1, 0, 0, 0, 225, 227, 5, 85, 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, 151, 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, 131, 0, 0, 234, 237, 3, 156, 78, 0, 235, 236, 5, 116, 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, 150, 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, 94, 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, 41, 0, 0, 258, 259, 5, 131, 0, 0, 259, 260, 3, 4, 2, 0, 260, 261, 5, 150, 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, 101, 0, 0, 267, 268, 5, 131, 0, 0, 268, 269, 3, 4, 2, 0, 269, 270, 5, 150, 0, 0, 270, 272, 3, 10, 5, 0, 271, 273, 5, 151, 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, 131, 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, 151, 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, 151, 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, 150, 0, 0, 292, 294, 3, 10, 5, 0, 293, 295, 5, 151, 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, 131, 0, 0, 298, 299, 5, 53, 0, 0, 299, 302, 3, 156, 78, 0, 300, 301, 5, 117, 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, 43, 0, 0, 305, 306, 3, 4, 2, 0, 306, 307, 5, 150, 0, 0, 307, 309, 3, 10, 5, 0, 308, 310, 5, 151, 0, 0, 309, 308, 1, 0, 0, 0, 309, 310, 1, 0, 0, 0, 310, 27, 1, 0, 0, 0, 311, 312, 7, 0, 0, 0, 312, 313, 3, 156, 78, 0, 313, 315, 5, 131, 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, 150, 0, 0, 318, 319, 3, 36, 18, 0, 319, 29, 1, 0, 0, 0, 320, 321, 3, 4, 2, 0, 321, 322, 5, 116, 0, 0, 322, 323, 5, 123, 0, 0, 323, 324, 3, 4, 2, 0, 324, 31, 1, 0, 0, 0, 325, 327, 3, 4, 2, 0, 326, 328, 5, 151, 0, 0, 327, 326, 1, 0, 0, 0, 327, 328, 1, 0, 0, 0, 328, 33, 1, 0, 0, 0, 329, 330, 5, 151, 0, 0, 330, 35, 1, 0, 0, 0, 331, 335, 5, 129, 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, 148, 0, 0, 339, 37, 1, 0, 0, 0, 340, 341, 3, 4, 2, 0, 341, 342, 5, 116, 0, 0, 342, 343, 3, 4, 2, 0, 343, 39, 1, 0, 0, 0, 344, 349, 3, 38, 19, 0, 345, 346, 5, 117, 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, 117, 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, 96, 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, 131, 0, 0, 373, 374, 3, 44, 22, 0, 374, 375, 5, 150, 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, 80, 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, 103, 0, 0, 406, 408, 7, 1, 0, 0, 407, 405, 1, 0, 0, 0, 407, 408, 1, 0, 0, 0, 408, 411, 1, 0, 0, 0, 409, 410, 5, 103, 0, 0, 410, 412, 5, 90, 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, 103, 0, 0, 430, 431, 3, 124, 62, 0, 431, 51, 1, 0, 0, 0, 432, 433, 5, 89, 0, 0, 433, 436, 5, 109, 0, 0, 434, 435, 5, 103, 0, 0, 435, 437, 5, 86, 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, 2, 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, 48, 0, 0, 446, 447, 3, 114, 57, 0, 447, 57, 1, 0, 0, 0, 448, 449, 5, 102, 0, 0, 449, 450, 3, 156, 78, 0, 450, 451, 5, 6, 0, 0, 451, 452, 5, 131, 0, 0, 452, 453, 3, 98, 49, 0, 453, 463, 5, 150, 0, 0, 454, 455, 5, 117, 0, 0, 455, 456, 3, 156, 78, 0, 456, 457, 5, 6, 0, 0, 457, 458, 5, 131, 0, 0, 458, 459, 3, 98, 49, 0, 459, 460, 5, 150, 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, 70, 0, 0, 467, 468, 3, 116, 58, 0, 468, 61, 1, 0, 0, 0, 469, 470, 5, 100, 0, 0, 470, 471, 3, 116, 58, 0, 471, 63, 1, 0, 0, 0, 472, 473, 5, 37, 0, 0, 473, 480, 5, 11, 0, 0, 474, 475, 7, 1, 0, 0, 475, 476, 5, 131, 0, 0, 476, 477, 3, 114, 57, 0, 477, 478, 5, 150, 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, 38, 0, 0, 483, 484, 3, 116, 58, 0, 484, 67, 1, 0, 0, 0, 485, 486, 5, 65, 0, 0, 486, 487, 5, 11, 0, 0, 487, 488, 3, 88, 44, 0, 488, 69, 1, 0, 0, 0, 489, 490, 5, 65, 0, 0, 490, 491, 5, 11, 0, 0, 491, 492, 3, 114, 57, 0, 492, 71, 1, 0, 0, 0, 493, 494, 5, 55, 0, 0, 494, 497, 3, 116, 58, 0, 495, 496, 5, 117, 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, 103, 0, 0, 500, 504, 5, 86, 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, 55, 0, 0, 506, 509, 3, 116, 58, 0, 507, 508, 5, 103, 0, 0, 508, 510, 5, 86, 0, 0, 509, 507, 1, 0, 0, 0, 509, 510, 1, 0, 0, 0, 510, 511, 1, 0, 0, 0, 511, 512, 5, 62, 0, 0, 512, 513, 3, 116, 58, 0, 513, 523, 1, 0, 0, 0, 514, 515, 5, 55, 0, 0, 515, 516, 3, 116, 58, 0, 516, 517, 5, 62, 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, 62, 0, 0, 525, 526, 3, 116, 58, 0, 526, 75, 1, 0, 0, 0, 527, 528, 5, 82, 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, 131, 0, 0, 539, 540, 3, 78, 39, 0, 540, 541, 5, 150, 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, 48, 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, 3, 0, 0, 562, 561, 1, 0, 0, 0, 562, 563, 1, 0, 0, 0, 563, 564, 1, 0, 0, 0, 564, 571, 5, 45, 0, 0, 565, 567, 5, 45, 0, 0, 566, 568, 7, 3, 0, 0, 567, 566, 1, 0, 0, 0, 567, 568, 1, 0, 0, 0, 568, 571, 1, 0, 0, 0, 569, 571, 7, 3, 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, 4, 0, 0, 573, 572, 1, 0, 0, 0, 573, 574, 1, 0, 0, 0, 574, 575, 1, 0, 0, 0, 575, 577, 7, 5, 0, 0, 576, 578, 5, 66, 0, 0, 577, 576, 1, 0, 0, 0, 577, 578, 1, 0, 0, 0, 578, 587, 1, 0, 0, 0, 579, 581, 7, 5, 0, 0, 580, 582, 5, 66, 0, 0, 581, 580, 1, 0, 0, 0, 581, 582, 1, 0, 0, 0, 582, 584, 1, 0, 0, 0, 583, 585, 7, 4, 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, 6, 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, 66, 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, 66, 0, 0, 597, 596, 1, 0, 0, 0, 597, 598, 1, 0, 0, 0, 598, 600, 1, 0, 0, 0, 599, 601, 7, 6, 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, 48, 0, 0, 608, 610, 5, 117, 0, 0, 609, 606, 1, 0, 0, 0, 609, 608, 1, 0, 0, 0, 610, 83, 1, 0, 0, 0, 611, 612, 5, 63, 0, 0, 612, 621, 3, 114, 57, 0, 613, 614, 5, 97, 0, 0, 614, 615, 5, 131, 0, 0, 615, 616, 3, 114, 57, 0, 616, 617, 5, 150, 0, 0, 617, 621, 1, 0, 0, 0, 618, 619, 5, 97, 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, 78, 0, 0, 623, 626, 3, 92, 46, 0, 624, 625, 5, 62, 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, 117, 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, 7, 0, 0, 638, 637, 1, 0, 0, 0, 638, 639, 1, 0, 0, 0, 639, 642, 1, 0, 0, 0, 640, 641, 5, 61, 0, 0, 641, 643, 7, 8, 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, 111, 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, 152, 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, 117, 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, 123, 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, 68, 0, 0, 678, 679, 5, 11, 0, 0, 679, 680, 3, 114, 57, 0, 680, 101, 1, 0, 0, 0, 681, 682, 5, 65, 0, 0, 682, 683, 5, 11, 0, 0, 683, 684, 3, 88, 44, 0, 684, 103, 1, 0, 0, 0, 685, 686, 7, 9, 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, 76, 0, 0, 698, 699, 5, 95, 0, 0, 699, 709, 5, 69, 0, 0, 700, 701, 5, 95, 0, 0, 701, 709, 5, 32, 0, 0, 702, 703, 3, 144, 72, 0, 703, 704, 5, 69, 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, 131, 0, 0, 716, 717, 3, 156, 78, 0, 717, 724, 3, 112, 56, 0, 718, 719, 5, 117, 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, 117, 0, 0, 728, 727, 1, 0, 0, 0, 728, 729, 1, 0, 0, 0, 729, 730, 1, 0, 0, 0, 730, 731, 5, 150, 0, 0, 731, 770, 1, 0, 0, 0, 732, 733, 3, 156, 78, 0, 733, 734, 5, 131, 0, 0, 734, 739, 3, 158, 79, 0, 735, 736, 5, 117, 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, 117, 0, 0, 743, 742, 1, 0, 0, 0, 743, 744, 1, 0, 0, 0, 744, 745, 1, 0, 0, 0, 745, 746, 5, 150, 0, 0, 746, 770, 1, 0, 0, 0, 747, 748, 3, 156, 78, 0, 748, 749, 5, 131, 0, 0, 749, 754, 3, 112, 56, 0, 750, 751, 5, 117, 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, 117, 0, 0, 758, 757, 1, 0, 0, 0, 758, 759, 1, 0, 0, 0, 759, 760, 1, 0, 0, 0, 760, 761, 5, 150, 0, 0, 761, 770, 1, 0, 0, 0, 762, 763, 3, 156, 78, 0, 763, 765, 5, 131, 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, 150, 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, 117, 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, 117, 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, 99, 0, 0, 788, 789, 3, 116, 58, 0, 789, 790, 5, 84, 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, 131, 0, 0, 804, 805, 3, 116, 58, 0, 805, 806, 5, 6, 0, 0, 806, 807, 3, 112, 56, 0, 807, 808, 5, 150, 0, 0, 808, 933, 1, 0, 0, 0, 809, 810, 5, 20, 0, 0, 810, 933, 5, 111, 0, 0, 811, 812, 5, 46, 0, 0, 812, 813, 3, 116, 58, 0, 813, 814, 3, 148, 74, 0, 814, 933, 1, 0, 0, 0, 815, 816, 5, 83, 0, 0, 816, 817, 5, 131, 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, 150, 0, 0, 825, 933, 1, 0, 0, 0, 826, 827, 5, 87, 0, 0, 827, 933, 5, 111, 0, 0, 828, 829, 5, 92, 0, 0, 829, 830, 5, 131, 0, 0, 830, 831, 7, 10, 0, 0, 831, 832, 3, 162, 81, 0, 832, 833, 5, 34, 0, 0, 833, 834, 3, 116, 58, 0, 834, 835, 5, 150, 0, 0, 835, 933, 1, 0, 0, 0, 836, 837, 3, 156, 78, 0, 837, 839, 5, 131, 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, 150, 0, 0, 842, 851, 1, 0, 0, 0, 843, 845, 5, 131, 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, 150, 0, 0, 851, 843, 1, 0, 0, 0, 851, 852, 1, 0, 0, 0, 852, 853, 1, 0, 0, 0, 853, 854, 5, 67, 0, 0, 854, 855, 5, 131, 0, 0, 855, 856, 3, 98, 49, 0, 856, 857, 5, 150, 0, 0, 857, 933, 1, 0, 0, 0, 858, 859, 3, 156, 78, 0, 859, 861, 5, 131, 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, 150, 0, 0, 864, 873, 1, 0, 0, 0, 865, 867, 5, 131, 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, 150, 0, 0, 873, 865, 1, 0, 0, 0, 873, 874, 1, 0, 0, 0, 874, 875, 1, 0, 0, 0, 875, 876, 5, 67, 0, 0, 876, 877, 3, 156, 78, 0, 877, 933, 1, 0, 0, 0, 878, 884, 3, 156, 78, 0, 879, 881, 5, 131, 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, 150, 0, 0, 884, 879, 1, 0, 0, 0, 884, 885, 1, 0, 0, 0, 885, 886, 1, 0, 0, 0, 886, 888, 5, 131, 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, 150, 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, 119, 0, 0, 899, 933, 3, 116, 58, 20, 900, 901, 5, 59, 0, 0, 901, 933, 3, 116, 58, 14, 902, 903, 3, 136, 68, 0, 903, 904, 5, 121, 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, 113, 0, 0, 908, 909, 5, 131, 0, 0, 909, 910, 3, 44, 22, 0, 910, 911, 5, 150, 0, 0, 911, 933, 1, 0, 0, 0, 912, 913, 5, 131, 0, 0, 913, 914, 3, 116, 58, 0, 914, 915, 5, 150, 0, 0, 915, 933, 1, 0, 0, 0, 916, 917, 5, 131, 0, 0, 917, 918, 3, 114, 57, 0, 918, 919, 5, 150, 0, 0, 919, 933, 1, 0, 0, 0, 920, 922, 5, 130, 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, 149, 0, 0, 925, 927, 5, 129, 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, 148, 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, 113, 0, 0, 936, 939, 5, 152, 0, 0, 937, 939, 5, 139, 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, 140, 0, 0, 943, 946, 5, 119, 0, 0, 944, 946, 5, 118, 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, 122, 0, 0, 950, 974, 5, 123, 0, 0, 951, 974, 5, 134, 0, 0, 952, 974, 5, 132, 0, 0, 953, 974, 5, 133, 0, 0, 954, 974, 5, 124, 0, 0, 955, 974, 5, 125, 0, 0, 956, 958, 5, 59, 0, 0, 957, 956, 1, 0, 0, 0, 957, 958, 1, 0, 0, 0, 958, 959, 1, 0, 0, 0, 959, 961, 5, 43, 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, 59, 0, 0, 964, 963, 1, 0, 0, 0, 964, 965, 1, 0, 0, 0, 965, 966, 1, 0, 0, 0, 966, 974, 7, 11, 0, 0, 967, 974, 5, 146, 0, 0, 968, 974, 5, 147, 0, 0, 969, 974, 5, 136, 0, 0, 970, 974, 5, 127, 0, 0, 971, 974, 5, 128, 0, 0, 972, 974, 5, 135, 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, 138, 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, 64, 0, 0, 984, 1043, 3, 116, 58, 13, 985, 987, 10, 11, 0, 0, 986, 988, 5, 59, 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, 141, 0, 0, 996, 997, 3, 116, 58, 0, 997, 998, 5, 116, 0, 0, 998, 999, 3, 116, 58, 10, 999, 1043, 1, 0, 0, 0, 1000, 1001, 10, 30, 0, 0, 1001, 1003, 5, 131, 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, 150, 0, 0, 1006, 1007, 10, 26, 0, 0, 1007, 1008, 5, 130, 0, 0, 1008, 1009, 3, 116, 58, 0, 1009, 1010, 5, 149, 0, 0, 1010, 1043, 1, 0, 0, 0, 1011, 1012, 10, 25, 0, 0, 1012, 1013, 5, 121, 0, 0, 1013, 1043, 5, 109, 0, 0, 1014, 1015, 10, 24, 0, 0, 1015, 1016, 5, 121, 0, 0, 1016, 1043, 3, 156, 78, 0, 1017, 1018, 10, 23, 0, 0, 1018, 1019, 5, 137, 0, 0, 1019, 1020, 5, 130, 0, 0, 1020, 1021, 3, 116, 58, 0, 1021, 1022, 5, 149, 0, 0, 1022, 1043, 1, 0, 0, 0, 1023, 1024, 10, 22, 0, 0, 1024, 1025, 5, 137, 0, 0, 1025, 1043, 5, 109, 0, 0, 1026, 1027, 10, 21, 0, 0, 1027, 1028, 5, 137, 0, 0, 1028, 1043, 3, 156, 78, 0, 1029, 1030, 10, 16, 0, 0, 1030, 1032, 5, 47, 0, 0, 1031, 1033, 5, 59, 0, 0, 1032, 1031, 1, 0, 0, 0, 1032, 1033, 1, 0, 0, 0, 1033, 1034, 1, 0, 0, 0, 1034, 1043, 5, 60, 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, 111, 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, 131, 0, 0, 1048, 1053, 3, 156, 78, 0, 1049, 1050, 5, 117, 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, 117, 0, 0, 1057, 1056, 1, 0, 0, 0, 1057, 1058, 1, 0, 0, 0, 1058, 1059, 1, 0, 0, 0, 1059, 1060, 5, 150, 0, 0, 1060, 1075, 1, 0, 0, 0, 1061, 1066, 3, 156, 78, 0, 1062, 1063, 5, 117, 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, 117, 0, 0, 1070, 1069, 1, 0, 0, 0, 1070, 1071, 1, 0, 0, 0, 1071, 1075, 1, 0, 0, 0, 1072, 1073, 5, 131, 0, 0, 1073, 1075, 5, 150, 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, 112, 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, 133, 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, 152, 0, 0, 1090, 1091, 5, 125, 0, 0, 1091, 1114, 1, 0, 0, 0, 1092, 1093, 5, 133, 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, 125, 0, 0, 1101, 1107, 3, 120, 60, 0, 1102, 1103, 5, 129, 0, 0, 1103, 1104, 3, 116, 58, 0, 1104, 1105, 5, 148, 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, 133, 0, 0, 1109, 1110, 5, 152, 0, 0, 1110, 1111, 3, 156, 78, 0, 1111, 1112, 5, 125, 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, 123, 0, 0, 1117, 1118, 3, 162, 81, 0, 1118, 1127, 1, 0, 0, 0, 1119, 1120, 3, 156, 78, 0, 1120, 1121, 5, 123, 0, 0, 1121, 1122, 5, 129, 0, 0, 1122, 1123, 3, 116, 58, 0, 1123, 1124, 5, 148, 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, 117, 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, 117, 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, 131, 0, 0, 1142, 1143, 3, 44, 22, 0, 1143, 1144, 5, 150, 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, 121, 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, 121, 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, 131, 0, 0, 1172, 1173, 3, 44, 22, 0, 1173, 1174, 5, 150, 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, 131, 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, 150, 0, 0, 1196, 135, 1, 0, 0, 0, 1197, 1198, 3, 140, 70, 0, 1198, 1199, 5, 121, 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, 117, 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, 117, 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, 107, 0, 0, 1218, 1219, 5, 121, 0, 0, 1219, 1226, 7, 12, 0, 0, 1220, 1221, 5, 109, 0, 0, 1221, 1223, 5, 121, 0, 0, 1222, 1224, 7, 12, 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, 13, 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, 108, 0, 0, 1232, 1237, 5, 109, 0, 0, 1233, 1237, 5, 110, 0, 0, 1234, 1237, 5, 44, 0, 0, 1235, 1237, 5, 58, 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, 111, 0, 0, 1240, 1242, 5, 60, 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, 14, 0, 0, 1244, 149, 1, 0, 0, 0, 1245, 1246, 7, 15, 0, 0, 1246, 151, 1, 0, 0, 0, 1247, 1248, 7, 16, 0, 0, 1248, 153, 1, 0, 0, 0, 1249, 1252, 5, 106, 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, 106, 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, 123, 0, 0, 1260, 1261, 3, 144, 72, 0, 1261, 159, 1, 0, 0, 0, 1262, 1263, 5, 129, 0, 0, 1263, 1264, 3, 116, 58, 0, 1264, 1265, 5, 148, 0, 0, 1265, 161, 1, 0, 0, 0, 1266, 1269, 5, 111, 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, 143, 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, 145, 0, 0, 1278, 165, 1, 0, 0, 0, 1279, 1280, 5, 158, 0, 0, 1280, 1281, 3, 116, 58, 0, 1281, 1282, 5, 148, 0, 0, 1282, 1285, 1, 0, 0, 0, 1283, 1285, 5, 157, 0, 0, 1284, 1279, 1, 0, 0, 0, 1284, 1283, 1, 0, 0, 0, 1285, 167, 1, 0, 0, 0, 1286, 1290, 5, 144, 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, 160, 0, 0, 1296, 1297, 3, 116, 58, 0, 1297, 1298, 5, 148, 0, 0, 1298, 1301, 1, 0, 0, 0, 1299, 1301, 5, 159, 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 +[4, 1, 162, 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, 1, 0, 5, 0, 176, 8, 0, 10, 0, 12, 0, 179, 9, 0, 1, 0, 1, 0, 1, 1, 1, 1, 3, 1, 185, 8, 1, 1, 2, 1, 2, 1, 3, 1, 3, 1, 3, 1, 3, 1, 3, 3, 3, 194, 8, 3, 1, 4, 1, 4, 1, 4, 5, 4, 199, 8, 4, 10, 4, 12, 4, 202, 9, 4, 1, 4, 3, 4, 205, 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, 219, 8, 5, 1, 6, 1, 6, 3, 6, 223, 8, 6, 1, 6, 3, 6, 226, 8, 6, 1, 7, 1, 7, 3, 7, 230, 8, 7, 1, 7, 3, 7, 233, 8, 7, 1, 8, 1, 8, 1, 8, 1, 8, 1, 8, 3, 8, 240, 8, 8, 1, 8, 1, 8, 3, 8, 244, 8, 8, 1, 8, 1, 8, 1, 9, 1, 9, 1, 9, 5, 9, 251, 8, 9, 10, 9, 12, 9, 254, 9, 9, 1, 9, 1, 9, 3, 9, 258, 8, 9, 1, 10, 1, 10, 1, 10, 1, 10, 1, 10, 1, 10, 1, 10, 3, 10, 267, 8, 10, 1, 11, 1, 11, 1, 11, 1, 11, 1, 11, 1, 11, 3, 11, 275, 8, 11, 1, 12, 1, 12, 1, 12, 1, 12, 1, 12, 3, 12, 282, 8, 12, 1, 12, 1, 12, 3, 12, 286, 8, 12, 1, 12, 1, 12, 1, 12, 1, 12, 3, 12, 292, 8, 12, 1, 12, 1, 12, 1, 12, 3, 12, 297, 8, 12, 1, 13, 1, 13, 1, 13, 1, 13, 1, 13, 1, 13, 3, 13, 305, 8, 13, 1, 13, 1, 13, 1, 13, 1, 13, 1, 13, 3, 13, 312, 8, 13, 1, 14, 1, 14, 1, 14, 1, 14, 3, 14, 318, 8, 14, 1, 14, 1, 14, 1, 14, 1, 15, 1, 15, 1, 15, 1, 15, 1, 15, 1, 16, 1, 16, 3, 16, 330, 8, 16, 1, 17, 1, 17, 1, 18, 1, 18, 5, 18, 336, 8, 18, 10, 18, 12, 18, 339, 9, 18, 1, 18, 1, 18, 1, 19, 1, 19, 1, 19, 1, 19, 1, 20, 1, 20, 1, 20, 5, 20, 350, 8, 20, 10, 20, 12, 20, 353, 9, 20, 1, 20, 3, 20, 356, 8, 20, 1, 21, 1, 21, 1, 21, 3, 21, 361, 8, 21, 1, 21, 1, 21, 1, 22, 1, 22, 1, 22, 1, 22, 1, 22, 1, 22, 3, 22, 371, 8, 22, 1, 23, 1, 23, 1, 23, 1, 23, 3, 23, 377, 8, 23, 1, 23, 1, 23, 1, 24, 1, 24, 5, 24, 383, 8, 24, 10, 24, 12, 24, 386, 9, 24, 1, 25, 3, 25, 389, 8, 25, 1, 25, 1, 25, 3, 25, 393, 8, 25, 1, 25, 3, 25, 396, 8, 25, 1, 25, 1, 25, 3, 25, 400, 8, 25, 1, 25, 3, 25, 403, 8, 25, 1, 25, 3, 25, 406, 8, 25, 1, 25, 3, 25, 409, 8, 25, 1, 25, 3, 25, 412, 8, 25, 1, 25, 1, 25, 3, 25, 416, 8, 25, 1, 25, 1, 25, 3, 25, 420, 8, 25, 1, 25, 3, 25, 423, 8, 25, 1, 25, 3, 25, 426, 8, 25, 1, 25, 3, 25, 429, 8, 25, 1, 25, 1, 25, 3, 25, 433, 8, 25, 1, 25, 3, 25, 436, 8, 25, 1, 26, 1, 26, 1, 26, 1, 27, 1, 27, 1, 27, 1, 27, 3, 27, 445, 8, 27, 1, 28, 1, 28, 1, 28, 1, 29, 3, 29, 451, 8, 29, 1, 29, 1, 29, 1, 29, 1, 29, 1, 30, 1, 30, 1, 30, 1, 30, 1, 30, 1, 30, 1, 30, 1, 30, 1, 30, 1, 30, 1, 30, 1, 30, 1, 30, 5, 30, 470, 8, 30, 10, 30, 12, 30, 473, 9, 30, 1, 31, 1, 31, 1, 31, 1, 32, 1, 32, 1, 32, 1, 33, 1, 33, 1, 33, 1, 33, 1, 33, 1, 33, 1, 33, 1, 33, 3, 33, 489, 8, 33, 1, 34, 1, 34, 1, 34, 1, 35, 1, 35, 1, 35, 1, 35, 1, 36, 1, 36, 1, 36, 1, 36, 1, 37, 1, 37, 1, 37, 1, 37, 3, 37, 506, 8, 37, 1, 37, 1, 37, 1, 37, 1, 37, 3, 37, 512, 8, 37, 1, 37, 1, 37, 1, 37, 1, 37, 3, 37, 518, 8, 37, 1, 37, 1, 37, 1, 37, 1, 37, 1, 37, 1, 37, 1, 37, 1, 37, 1, 37, 3, 37, 529, 8, 37, 3, 37, 531, 8, 37, 1, 38, 1, 38, 1, 38, 1, 39, 1, 39, 1, 39, 1, 40, 1, 40, 1, 40, 3, 40, 542, 8, 40, 1, 40, 3, 40, 545, 8, 40, 1, 40, 1, 40, 1, 40, 1, 40, 3, 40, 551, 8, 40, 1, 40, 1, 40, 1, 40, 1, 40, 1, 40, 1, 40, 3, 40, 559, 8, 40, 1, 40, 1, 40, 1, 40, 1, 40, 5, 40, 565, 8, 40, 10, 40, 12, 40, 568, 9, 40, 1, 41, 3, 41, 571, 8, 41, 1, 41, 1, 41, 1, 41, 3, 41, 576, 8, 41, 1, 41, 3, 41, 579, 8, 41, 1, 41, 3, 41, 582, 8, 41, 1, 41, 1, 41, 3, 41, 586, 8, 41, 1, 41, 1, 41, 3, 41, 590, 8, 41, 1, 41, 3, 41, 593, 8, 41, 3, 41, 595, 8, 41, 1, 41, 3, 41, 598, 8, 41, 1, 41, 1, 41, 3, 41, 602, 8, 41, 1, 41, 1, 41, 3, 41, 606, 8, 41, 1, 41, 3, 41, 609, 8, 41, 3, 41, 611, 8, 41, 3, 41, 613, 8, 41, 1, 42, 1, 42, 1, 42, 3, 42, 618, 8, 42, 1, 43, 1, 43, 1, 43, 1, 43, 1, 43, 1, 43, 1, 43, 1, 43, 1, 43, 3, 43, 629, 8, 43, 1, 44, 1, 44, 1, 44, 1, 44, 3, 44, 635, 8, 44, 1, 45, 1, 45, 1, 45, 5, 45, 640, 8, 45, 10, 45, 12, 45, 643, 9, 45, 1, 46, 1, 46, 3, 46, 647, 8, 46, 1, 46, 1, 46, 3, 46, 651, 8, 46, 1, 46, 1, 46, 3, 46, 655, 8, 46, 1, 47, 1, 47, 1, 47, 1, 47, 3, 47, 661, 8, 47, 3, 47, 663, 8, 47, 1, 48, 1, 48, 1, 48, 5, 48, 668, 8, 48, 10, 48, 12, 48, 671, 9, 48, 1, 49, 1, 49, 1, 49, 1, 49, 1, 50, 3, 50, 678, 8, 50, 1, 50, 3, 50, 681, 8, 50, 1, 50, 3, 50, 684, 8, 50, 1, 51, 1, 51, 1, 51, 1, 51, 1, 52, 1, 52, 1, 52, 1, 52, 1, 53, 1, 53, 1, 53, 1, 54, 1, 54, 1, 54, 1, 54, 1, 54, 1, 54, 3, 54, 703, 8, 54, 1, 55, 1, 55, 1, 55, 1, 55, 1, 55, 1, 55, 1, 55, 1, 55, 1, 55, 1, 55, 1, 55, 1, 55, 3, 55, 717, 8, 55, 1, 56, 1, 56, 1, 56, 1, 57, 1, 57, 1, 57, 1, 57, 1, 57, 1, 57, 1, 57, 1, 57, 1, 57, 5, 57, 731, 8, 57, 10, 57, 12, 57, 734, 9, 57, 1, 57, 3, 57, 737, 8, 57, 1, 57, 1, 57, 1, 57, 1, 57, 1, 57, 1, 57, 1, 57, 5, 57, 746, 8, 57, 10, 57, 12, 57, 749, 9, 57, 1, 57, 3, 57, 752, 8, 57, 1, 57, 1, 57, 1, 57, 1, 57, 1, 57, 1, 57, 1, 57, 5, 57, 761, 8, 57, 10, 57, 12, 57, 764, 9, 57, 1, 57, 3, 57, 767, 8, 57, 1, 57, 1, 57, 1, 57, 1, 57, 1, 57, 3, 57, 774, 8, 57, 1, 57, 1, 57, 3, 57, 778, 8, 57, 1, 58, 1, 58, 1, 58, 5, 58, 783, 8, 58, 10, 58, 12, 58, 786, 9, 58, 1, 58, 3, 58, 789, 8, 58, 1, 59, 1, 59, 1, 59, 3, 59, 794, 8, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 4, 59, 801, 8, 59, 11, 59, 12, 59, 802, 1, 59, 1, 59, 3, 59, 807, 8, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 3, 59, 831, 8, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 3, 59, 848, 8, 59, 1, 59, 1, 59, 1, 59, 1, 59, 3, 59, 854, 8, 59, 1, 59, 3, 59, 857, 8, 59, 1, 59, 3, 59, 860, 8, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 3, 59, 870, 8, 59, 1, 59, 1, 59, 1, 59, 1, 59, 3, 59, 876, 8, 59, 1, 59, 3, 59, 879, 8, 59, 1, 59, 3, 59, 882, 8, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 3, 59, 890, 8, 59, 1, 59, 3, 59, 893, 8, 59, 1, 59, 1, 59, 3, 59, 897, 8, 59, 1, 59, 3, 59, 900, 8, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 3, 59, 914, 8, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 3, 59, 931, 8, 59, 1, 59, 1, 59, 1, 59, 3, 59, 936, 8, 59, 1, 59, 1, 59, 1, 59, 3, 59, 941, 8, 59, 1, 59, 1, 59, 1, 59, 1, 59, 3, 59, 947, 8, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 3, 59, 954, 8, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 3, 59, 966, 8, 59, 1, 59, 1, 59, 3, 59, 970, 8, 59, 1, 59, 3, 59, 973, 8, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 3, 59, 982, 8, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 3, 59, 996, 8, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 3, 59, 1012, 8, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 3, 59, 1041, 8, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 1, 59, 3, 59, 1049, 8, 59, 5, 59, 1051, 8, 59, 10, 59, 12, 59, 1054, 9, 59, 1, 60, 1, 60, 1, 60, 1, 60, 5, 60, 1060, 8, 60, 10, 60, 12, 60, 1063, 9, 60, 1, 60, 3, 60, 1066, 8, 60, 1, 60, 1, 60, 1, 60, 1, 60, 1, 60, 5, 60, 1073, 8, 60, 10, 60, 12, 60, 1076, 9, 60, 1, 60, 3, 60, 1079, 8, 60, 1, 60, 1, 60, 3, 60, 1083, 8, 60, 1, 60, 1, 60, 1, 60, 3, 60, 1088, 8, 60, 1, 61, 1, 61, 1, 61, 5, 61, 1093, 8, 61, 10, 61, 12, 61, 1096, 9, 61, 1, 61, 1, 61, 1, 61, 1, 61, 1, 61, 1, 61, 5, 61, 1104, 8, 61, 10, 61, 12, 61, 1107, 9, 61, 1, 61, 1, 61, 1, 61, 1, 61, 1, 61, 1, 61, 3, 61, 1115, 8, 61, 1, 61, 1, 61, 1, 61, 1, 61, 1, 61, 3, 61, 1122, 8, 61, 1, 62, 1, 62, 1, 62, 1, 62, 1, 62, 1, 62, 1, 62, 1, 62, 1, 62, 1, 62, 1, 62, 3, 62, 1135, 8, 62, 1, 63, 1, 63, 1, 63, 5, 63, 1140, 8, 63, 10, 63, 12, 63, 1143, 9, 63, 1, 63, 3, 63, 1146, 8, 63, 1, 64, 1, 64, 1, 64, 1, 64, 1, 64, 1, 64, 1, 64, 1, 64, 1, 64, 1, 64, 3, 64, 1158, 8, 64, 1, 65, 1, 65, 1, 65, 1, 65, 3, 65, 1164, 8, 65, 1, 65, 3, 65, 1167, 8, 65, 1, 66, 1, 66, 1, 66, 5, 66, 1172, 8, 66, 10, 66, 12, 66, 1175, 9, 66, 1, 67, 1, 67, 1, 67, 1, 67, 1, 67, 1, 67, 1, 67, 1, 67, 1, 67, 3, 67, 1186, 8, 67, 1, 67, 1, 67, 1, 67, 1, 67, 3, 67, 1192, 8, 67, 5, 67, 1194, 8, 67, 10, 67, 12, 67, 1197, 9, 67, 1, 68, 1, 68, 1, 68, 3, 68, 1202, 8, 68, 1, 68, 1, 68, 1, 69, 1, 69, 1, 69, 3, 69, 1209, 8, 69, 1, 69, 1, 69, 1, 70, 1, 70, 1, 70, 5, 70, 1216, 8, 70, 10, 70, 12, 70, 1219, 9, 70, 1, 70, 3, 70, 1222, 8, 70, 1, 71, 1, 71, 1, 72, 1, 72, 1, 72, 1, 72, 1, 72, 1, 72, 3, 72, 1232, 8, 72, 3, 72, 1234, 8, 72, 1, 73, 3, 73, 1237, 8, 73, 1, 73, 1, 73, 1, 73, 1, 73, 1, 73, 1, 73, 3, 73, 1245, 8, 73, 1, 74, 1, 74, 1, 74, 3, 74, 1250, 8, 74, 1, 75, 1, 75, 1, 76, 1, 76, 1, 77, 1, 77, 1, 78, 1, 78, 3, 78, 1260, 8, 78, 1, 79, 1, 79, 1, 79, 3, 79, 1265, 8, 79, 1, 80, 1, 80, 1, 80, 1, 80, 1, 81, 1, 81, 1, 81, 1, 81, 1, 82, 1, 82, 3, 82, 1277, 8, 82, 1, 83, 1, 83, 5, 83, 1281, 8, 83, 10, 83, 12, 83, 1284, 9, 83, 1, 83, 1, 83, 1, 84, 1, 84, 1, 84, 1, 84, 1, 84, 3, 84, 1293, 8, 84, 1, 85, 1, 85, 5, 85, 1297, 8, 85, 10, 85, 12, 85, 1300, 9, 85, 1, 85, 1, 85, 1, 86, 1, 86, 1, 86, 1, 86, 1, 86, 3, 86, 1309, 8, 86, 1, 86, 0, 3, 80, 118, 134, 87, 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, 0, 17, 2, 0, 32, 32, 37, 37, 2, 0, 18, 18, 77, 77, 2, 0, 46, 46, 54, 54, 3, 0, 1, 1, 4, 4, 8, 8, 4, 0, 1, 1, 3, 4, 8, 8, 83, 83, 2, 0, 54, 54, 76, 76, 2, 0, 1, 1, 4, 4, 2, 0, 7, 7, 22, 23, 2, 0, 31, 31, 52, 52, 2, 0, 74, 74, 79, 79, 3, 0, 10, 10, 53, 53, 93, 93, 2, 0, 43, 43, 56, 56, 1, 0, 110, 111, 2, 0, 121, 121, 142, 142, 7, 0, 21, 21, 40, 40, 58, 59, 73, 73, 81, 81, 100, 100, 106, 106, 19, 0, 1, 13, 15, 20, 22, 26, 28, 29, 31, 31, 33, 36, 38, 39, 41, 44, 46, 46, 48, 54, 56, 57, 61, 61, 63, 72, 74, 80, 82, 86, 88, 95, 97, 99, 101, 102, 104, 105, 4, 0, 20, 20, 31, 31, 41, 41, 51, 51, 1484, 0, 177, 1, 0, 0, 0, 2, 184, 1, 0, 0, 0, 4, 186, 1, 0, 0, 0, 6, 188, 1, 0, 0, 0, 8, 195, 1, 0, 0, 0, 10, 218, 1, 0, 0, 0, 12, 220, 1, 0, 0, 0, 14, 227, 1, 0, 0, 0, 16, 234, 1, 0, 0, 0, 18, 247, 1, 0, 0, 0, 20, 259, 1, 0, 0, 0, 22, 268, 1, 0, 0, 0, 24, 276, 1, 0, 0, 0, 26, 298, 1, 0, 0, 0, 28, 313, 1, 0, 0, 0, 30, 322, 1, 0, 0, 0, 32, 327, 1, 0, 0, 0, 34, 331, 1, 0, 0, 0, 36, 333, 1, 0, 0, 0, 38, 342, 1, 0, 0, 0, 40, 346, 1, 0, 0, 0, 42, 360, 1, 0, 0, 0, 44, 370, 1, 0, 0, 0, 46, 376, 1, 0, 0, 0, 48, 380, 1, 0, 0, 0, 50, 388, 1, 0, 0, 0, 52, 437, 1, 0, 0, 0, 54, 440, 1, 0, 0, 0, 56, 446, 1, 0, 0, 0, 58, 450, 1, 0, 0, 0, 60, 456, 1, 0, 0, 0, 62, 474, 1, 0, 0, 0, 64, 477, 1, 0, 0, 0, 66, 480, 1, 0, 0, 0, 68, 490, 1, 0, 0, 0, 70, 493, 1, 0, 0, 0, 72, 497, 1, 0, 0, 0, 74, 530, 1, 0, 0, 0, 76, 532, 1, 0, 0, 0, 78, 535, 1, 0, 0, 0, 80, 550, 1, 0, 0, 0, 82, 612, 1, 0, 0, 0, 84, 617, 1, 0, 0, 0, 86, 628, 1, 0, 0, 0, 88, 630, 1, 0, 0, 0, 90, 636, 1, 0, 0, 0, 92, 644, 1, 0, 0, 0, 94, 662, 1, 0, 0, 0, 96, 664, 1, 0, 0, 0, 98, 672, 1, 0, 0, 0, 100, 677, 1, 0, 0, 0, 102, 685, 1, 0, 0, 0, 104, 689, 1, 0, 0, 0, 106, 693, 1, 0, 0, 0, 108, 702, 1, 0, 0, 0, 110, 716, 1, 0, 0, 0, 112, 718, 1, 0, 0, 0, 114, 777, 1, 0, 0, 0, 116, 779, 1, 0, 0, 0, 118, 940, 1, 0, 0, 0, 120, 1082, 1, 0, 0, 0, 122, 1121, 1, 0, 0, 0, 124, 1134, 1, 0, 0, 0, 126, 1136, 1, 0, 0, 0, 128, 1157, 1, 0, 0, 0, 130, 1166, 1, 0, 0, 0, 132, 1168, 1, 0, 0, 0, 134, 1185, 1, 0, 0, 0, 136, 1198, 1, 0, 0, 0, 138, 1208, 1, 0, 0, 0, 140, 1212, 1, 0, 0, 0, 142, 1223, 1, 0, 0, 0, 144, 1233, 1, 0, 0, 0, 146, 1236, 1, 0, 0, 0, 148, 1249, 1, 0, 0, 0, 150, 1251, 1, 0, 0, 0, 152, 1253, 1, 0, 0, 0, 154, 1255, 1, 0, 0, 0, 156, 1259, 1, 0, 0, 0, 158, 1264, 1, 0, 0, 0, 160, 1266, 1, 0, 0, 0, 162, 1270, 1, 0, 0, 0, 164, 1276, 1, 0, 0, 0, 166, 1278, 1, 0, 0, 0, 168, 1292, 1, 0, 0, 0, 170, 1294, 1, 0, 0, 0, 172, 1308, 1, 0, 0, 0, 174, 176, 3, 2, 1, 0, 175, 174, 1, 0, 0, 0, 176, 179, 1, 0, 0, 0, 177, 175, 1, 0, 0, 0, 177, 178, 1, 0, 0, 0, 178, 180, 1, 0, 0, 0, 179, 177, 1, 0, 0, 0, 180, 181, 5, 0, 0, 1, 181, 1, 1, 0, 0, 0, 182, 185, 3, 6, 3, 0, 183, 185, 3, 10, 5, 0, 184, 182, 1, 0, 0, 0, 184, 183, 1, 0, 0, 0, 185, 3, 1, 0, 0, 0, 186, 187, 3, 118, 59, 0, 187, 5, 1, 0, 0, 0, 188, 189, 5, 55, 0, 0, 189, 193, 3, 158, 79, 0, 190, 191, 5, 118, 0, 0, 191, 192, 5, 125, 0, 0, 192, 194, 3, 4, 2, 0, 193, 190, 1, 0, 0, 0, 193, 194, 1, 0, 0, 0, 194, 7, 1, 0, 0, 0, 195, 200, 3, 158, 79, 0, 196, 197, 5, 119, 0, 0, 197, 199, 3, 158, 79, 0, 198, 196, 1, 0, 0, 0, 199, 202, 1, 0, 0, 0, 200, 198, 1, 0, 0, 0, 200, 201, 1, 0, 0, 0, 201, 204, 1, 0, 0, 0, 202, 200, 1, 0, 0, 0, 203, 205, 5, 119, 0, 0, 204, 203, 1, 0, 0, 0, 204, 205, 1, 0, 0, 0, 205, 9, 1, 0, 0, 0, 206, 219, 3, 12, 6, 0, 207, 219, 3, 14, 7, 0, 208, 219, 3, 18, 9, 0, 209, 219, 3, 20, 10, 0, 210, 219, 3, 22, 11, 0, 211, 219, 3, 26, 13, 0, 212, 219, 3, 24, 12, 0, 213, 219, 3, 28, 14, 0, 214, 219, 3, 30, 15, 0, 215, 219, 3, 36, 18, 0, 216, 219, 3, 32, 16, 0, 217, 219, 3, 34, 17, 0, 218, 206, 1, 0, 0, 0, 218, 207, 1, 0, 0, 0, 218, 208, 1, 0, 0, 0, 218, 209, 1, 0, 0, 0, 218, 210, 1, 0, 0, 0, 218, 211, 1, 0, 0, 0, 218, 212, 1, 0, 0, 0, 218, 213, 1, 0, 0, 0, 218, 214, 1, 0, 0, 0, 218, 215, 1, 0, 0, 0, 218, 216, 1, 0, 0, 0, 218, 217, 1, 0, 0, 0, 219, 11, 1, 0, 0, 0, 220, 222, 5, 75, 0, 0, 221, 223, 3, 4, 2, 0, 222, 221, 1, 0, 0, 0, 222, 223, 1, 0, 0, 0, 223, 225, 1, 0, 0, 0, 224, 226, 5, 153, 0, 0, 225, 224, 1, 0, 0, 0, 225, 226, 1, 0, 0, 0, 226, 13, 1, 0, 0, 0, 227, 229, 5, 87, 0, 0, 228, 230, 3, 4, 2, 0, 229, 228, 1, 0, 0, 0, 229, 230, 1, 0, 0, 0, 230, 232, 1, 0, 0, 0, 231, 233, 5, 153, 0, 0, 232, 231, 1, 0, 0, 0, 232, 233, 1, 0, 0, 0, 233, 15, 1, 0, 0, 0, 234, 243, 5, 14, 0, 0, 235, 236, 5, 133, 0, 0, 236, 239, 3, 158, 79, 0, 237, 238, 5, 118, 0, 0, 238, 240, 3, 158, 79, 0, 239, 237, 1, 0, 0, 0, 239, 240, 1, 0, 0, 0, 240, 241, 1, 0, 0, 0, 241, 242, 5, 152, 0, 0, 242, 244, 1, 0, 0, 0, 243, 235, 1, 0, 0, 0, 243, 244, 1, 0, 0, 0, 244, 245, 1, 0, 0, 0, 245, 246, 3, 36, 18, 0, 246, 17, 1, 0, 0, 0, 247, 248, 5, 96, 0, 0, 248, 252, 3, 36, 18, 0, 249, 251, 3, 16, 8, 0, 250, 249, 1, 0, 0, 0, 251, 254, 1, 0, 0, 0, 252, 250, 1, 0, 0, 0, 252, 253, 1, 0, 0, 0, 253, 257, 1, 0, 0, 0, 254, 252, 1, 0, 0, 0, 255, 256, 5, 30, 0, 0, 256, 258, 3, 36, 18, 0, 257, 255, 1, 0, 0, 0, 257, 258, 1, 0, 0, 0, 258, 19, 1, 0, 0, 0, 259, 260, 5, 42, 0, 0, 260, 261, 5, 133, 0, 0, 261, 262, 3, 4, 2, 0, 262, 263, 5, 152, 0, 0, 263, 266, 3, 10, 5, 0, 264, 265, 5, 25, 0, 0, 265, 267, 3, 10, 5, 0, 266, 264, 1, 0, 0, 0, 266, 267, 1, 0, 0, 0, 267, 21, 1, 0, 0, 0, 268, 269, 5, 103, 0, 0, 269, 270, 5, 133, 0, 0, 270, 271, 3, 4, 2, 0, 271, 272, 5, 152, 0, 0, 272, 274, 3, 10, 5, 0, 273, 275, 5, 153, 0, 0, 274, 273, 1, 0, 0, 0, 274, 275, 1, 0, 0, 0, 275, 23, 1, 0, 0, 0, 276, 277, 5, 34, 0, 0, 277, 281, 5, 133, 0, 0, 278, 282, 3, 6, 3, 0, 279, 282, 3, 30, 15, 0, 280, 282, 3, 4, 2, 0, 281, 278, 1, 0, 0, 0, 281, 279, 1, 0, 0, 0, 281, 280, 1, 0, 0, 0, 281, 282, 1, 0, 0, 0, 282, 283, 1, 0, 0, 0, 283, 285, 5, 153, 0, 0, 284, 286, 3, 4, 2, 0, 285, 284, 1, 0, 0, 0, 285, 286, 1, 0, 0, 0, 286, 287, 1, 0, 0, 0, 287, 291, 5, 153, 0, 0, 288, 292, 3, 6, 3, 0, 289, 292, 3, 30, 15, 0, 290, 292, 3, 4, 2, 0, 291, 288, 1, 0, 0, 0, 291, 289, 1, 0, 0, 0, 291, 290, 1, 0, 0, 0, 291, 292, 1, 0, 0, 0, 292, 293, 1, 0, 0, 0, 293, 294, 5, 152, 0, 0, 294, 296, 3, 10, 5, 0, 295, 297, 5, 153, 0, 0, 296, 295, 1, 0, 0, 0, 296, 297, 1, 0, 0, 0, 297, 25, 1, 0, 0, 0, 298, 299, 5, 34, 0, 0, 299, 300, 5, 133, 0, 0, 300, 301, 5, 55, 0, 0, 301, 304, 3, 158, 79, 0, 302, 303, 5, 119, 0, 0, 303, 305, 3, 158, 79, 0, 304, 302, 1, 0, 0, 0, 304, 305, 1, 0, 0, 0, 305, 306, 1, 0, 0, 0, 306, 307, 5, 44, 0, 0, 307, 308, 3, 4, 2, 0, 308, 309, 5, 152, 0, 0, 309, 311, 3, 10, 5, 0, 310, 312, 5, 153, 0, 0, 311, 310, 1, 0, 0, 0, 311, 312, 1, 0, 0, 0, 312, 27, 1, 0, 0, 0, 313, 314, 7, 0, 0, 0, 314, 315, 3, 158, 79, 0, 315, 317, 5, 133, 0, 0, 316, 318, 3, 8, 4, 0, 317, 316, 1, 0, 0, 0, 317, 318, 1, 0, 0, 0, 318, 319, 1, 0, 0, 0, 319, 320, 5, 152, 0, 0, 320, 321, 3, 36, 18, 0, 321, 29, 1, 0, 0, 0, 322, 323, 3, 4, 2, 0, 323, 324, 5, 118, 0, 0, 324, 325, 5, 125, 0, 0, 325, 326, 3, 4, 2, 0, 326, 31, 1, 0, 0, 0, 327, 329, 3, 4, 2, 0, 328, 330, 5, 153, 0, 0, 329, 328, 1, 0, 0, 0, 329, 330, 1, 0, 0, 0, 330, 33, 1, 0, 0, 0, 331, 332, 5, 153, 0, 0, 332, 35, 1, 0, 0, 0, 333, 337, 5, 131, 0, 0, 334, 336, 3, 2, 1, 0, 335, 334, 1, 0, 0, 0, 336, 339, 1, 0, 0, 0, 337, 335, 1, 0, 0, 0, 337, 338, 1, 0, 0, 0, 338, 340, 1, 0, 0, 0, 339, 337, 1, 0, 0, 0, 340, 341, 5, 150, 0, 0, 341, 37, 1, 0, 0, 0, 342, 343, 3, 4, 2, 0, 343, 344, 5, 118, 0, 0, 344, 345, 3, 4, 2, 0, 345, 39, 1, 0, 0, 0, 346, 351, 3, 38, 19, 0, 347, 348, 5, 119, 0, 0, 348, 350, 3, 38, 19, 0, 349, 347, 1, 0, 0, 0, 350, 353, 1, 0, 0, 0, 351, 349, 1, 0, 0, 0, 351, 352, 1, 0, 0, 0, 352, 355, 1, 0, 0, 0, 353, 351, 1, 0, 0, 0, 354, 356, 5, 119, 0, 0, 355, 354, 1, 0, 0, 0, 355, 356, 1, 0, 0, 0, 356, 41, 1, 0, 0, 0, 357, 361, 3, 48, 24, 0, 358, 361, 3, 50, 25, 0, 359, 361, 3, 122, 61, 0, 360, 357, 1, 0, 0, 0, 360, 358, 1, 0, 0, 0, 360, 359, 1, 0, 0, 0, 361, 362, 1, 0, 0, 0, 362, 363, 5, 0, 0, 1, 363, 43, 1, 0, 0, 0, 364, 371, 3, 50, 25, 0, 365, 366, 5, 133, 0, 0, 366, 367, 3, 48, 24, 0, 367, 368, 5, 152, 0, 0, 368, 371, 1, 0, 0, 0, 369, 371, 3, 162, 81, 0, 370, 364, 1, 0, 0, 0, 370, 365, 1, 0, 0, 0, 370, 369, 1, 0, 0, 0, 371, 45, 1, 0, 0, 0, 372, 377, 5, 27, 0, 0, 373, 374, 5, 98, 0, 0, 374, 377, 5, 1, 0, 0, 375, 377, 5, 47, 0, 0, 376, 372, 1, 0, 0, 0, 376, 373, 1, 0, 0, 0, 376, 375, 1, 0, 0, 0, 377, 378, 1, 0, 0, 0, 378, 379, 3, 44, 22, 0, 379, 47, 1, 0, 0, 0, 380, 384, 3, 44, 22, 0, 381, 383, 3, 46, 23, 0, 382, 381, 1, 0, 0, 0, 383, 386, 1, 0, 0, 0, 384, 382, 1, 0, 0, 0, 384, 385, 1, 0, 0, 0, 385, 49, 1, 0, 0, 0, 386, 384, 1, 0, 0, 0, 387, 389, 3, 52, 26, 0, 388, 387, 1, 0, 0, 0, 388, 389, 1, 0, 0, 0, 389, 390, 1, 0, 0, 0, 390, 392, 5, 82, 0, 0, 391, 393, 5, 24, 0, 0, 392, 391, 1, 0, 0, 0, 392, 393, 1, 0, 0, 0, 393, 395, 1, 0, 0, 0, 394, 396, 3, 54, 27, 0, 395, 394, 1, 0, 0, 0, 395, 396, 1, 0, 0, 0, 396, 397, 1, 0, 0, 0, 397, 399, 3, 116, 58, 0, 398, 400, 3, 56, 28, 0, 399, 398, 1, 0, 0, 0, 399, 400, 1, 0, 0, 0, 400, 402, 1, 0, 0, 0, 401, 403, 3, 58, 29, 0, 402, 401, 1, 0, 0, 0, 402, 403, 1, 0, 0, 0, 403, 405, 1, 0, 0, 0, 404, 406, 3, 62, 31, 0, 405, 404, 1, 0, 0, 0, 405, 406, 1, 0, 0, 0, 406, 408, 1, 0, 0, 0, 407, 409, 3, 64, 32, 0, 408, 407, 1, 0, 0, 0, 408, 409, 1, 0, 0, 0, 409, 411, 1, 0, 0, 0, 410, 412, 3, 66, 33, 0, 411, 410, 1, 0, 0, 0, 411, 412, 1, 0, 0, 0, 412, 415, 1, 0, 0, 0, 413, 414, 5, 105, 0, 0, 414, 416, 7, 1, 0, 0, 415, 413, 1, 0, 0, 0, 415, 416, 1, 0, 0, 0, 416, 419, 1, 0, 0, 0, 417, 418, 5, 105, 0, 0, 418, 420, 5, 92, 0, 0, 419, 417, 1, 0, 0, 0, 419, 420, 1, 0, 0, 0, 420, 422, 1, 0, 0, 0, 421, 423, 3, 68, 34, 0, 422, 421, 1, 0, 0, 0, 422, 423, 1, 0, 0, 0, 423, 425, 1, 0, 0, 0, 424, 426, 3, 60, 30, 0, 425, 424, 1, 0, 0, 0, 425, 426, 1, 0, 0, 0, 426, 428, 1, 0, 0, 0, 427, 429, 3, 70, 35, 0, 428, 427, 1, 0, 0, 0, 428, 429, 1, 0, 0, 0, 429, 432, 1, 0, 0, 0, 430, 433, 3, 74, 37, 0, 431, 433, 3, 76, 38, 0, 432, 430, 1, 0, 0, 0, 432, 431, 1, 0, 0, 0, 432, 433, 1, 0, 0, 0, 433, 435, 1, 0, 0, 0, 434, 436, 3, 78, 39, 0, 435, 434, 1, 0, 0, 0, 435, 436, 1, 0, 0, 0, 436, 51, 1, 0, 0, 0, 437, 438, 5, 105, 0, 0, 438, 439, 3, 126, 63, 0, 439, 53, 1, 0, 0, 0, 440, 441, 5, 91, 0, 0, 441, 444, 5, 111, 0, 0, 442, 443, 5, 105, 0, 0, 443, 445, 5, 88, 0, 0, 444, 442, 1, 0, 0, 0, 444, 445, 1, 0, 0, 0, 445, 55, 1, 0, 0, 0, 446, 447, 5, 35, 0, 0, 447, 448, 3, 80, 40, 0, 448, 57, 1, 0, 0, 0, 449, 451, 7, 2, 0, 0, 450, 449, 1, 0, 0, 0, 450, 451, 1, 0, 0, 0, 451, 452, 1, 0, 0, 0, 452, 453, 5, 5, 0, 0, 453, 454, 5, 50, 0, 0, 454, 455, 3, 116, 58, 0, 455, 59, 1, 0, 0, 0, 456, 457, 5, 104, 0, 0, 457, 458, 3, 158, 79, 0, 458, 459, 5, 6, 0, 0, 459, 460, 5, 133, 0, 0, 460, 461, 3, 100, 50, 0, 461, 471, 5, 152, 0, 0, 462, 463, 5, 119, 0, 0, 463, 464, 3, 158, 79, 0, 464, 465, 5, 6, 0, 0, 465, 466, 5, 133, 0, 0, 466, 467, 3, 100, 50, 0, 467, 468, 5, 152, 0, 0, 468, 470, 1, 0, 0, 0, 469, 462, 1, 0, 0, 0, 470, 473, 1, 0, 0, 0, 471, 469, 1, 0, 0, 0, 471, 472, 1, 0, 0, 0, 472, 61, 1, 0, 0, 0, 473, 471, 1, 0, 0, 0, 474, 475, 5, 72, 0, 0, 475, 476, 3, 118, 59, 0, 476, 63, 1, 0, 0, 0, 477, 478, 5, 102, 0, 0, 478, 479, 3, 118, 59, 0, 479, 65, 1, 0, 0, 0, 480, 481, 5, 38, 0, 0, 481, 488, 5, 11, 0, 0, 482, 483, 7, 1, 0, 0, 483, 484, 5, 133, 0, 0, 484, 485, 3, 116, 58, 0, 485, 486, 5, 152, 0, 0, 486, 489, 1, 0, 0, 0, 487, 489, 3, 116, 58, 0, 488, 482, 1, 0, 0, 0, 488, 487, 1, 0, 0, 0, 489, 67, 1, 0, 0, 0, 490, 491, 5, 39, 0, 0, 491, 492, 3, 118, 59, 0, 492, 69, 1, 0, 0, 0, 493, 494, 5, 67, 0, 0, 494, 495, 5, 11, 0, 0, 495, 496, 3, 90, 45, 0, 496, 71, 1, 0, 0, 0, 497, 498, 5, 67, 0, 0, 498, 499, 5, 11, 0, 0, 499, 500, 3, 116, 58, 0, 500, 73, 1, 0, 0, 0, 501, 502, 5, 57, 0, 0, 502, 505, 3, 118, 59, 0, 503, 504, 5, 119, 0, 0, 504, 506, 3, 118, 59, 0, 505, 503, 1, 0, 0, 0, 505, 506, 1, 0, 0, 0, 506, 511, 1, 0, 0, 0, 507, 508, 5, 105, 0, 0, 508, 512, 5, 88, 0, 0, 509, 510, 5, 11, 0, 0, 510, 512, 3, 116, 58, 0, 511, 507, 1, 0, 0, 0, 511, 509, 1, 0, 0, 0, 511, 512, 1, 0, 0, 0, 512, 531, 1, 0, 0, 0, 513, 514, 5, 57, 0, 0, 514, 517, 3, 118, 59, 0, 515, 516, 5, 105, 0, 0, 516, 518, 5, 88, 0, 0, 517, 515, 1, 0, 0, 0, 517, 518, 1, 0, 0, 0, 518, 519, 1, 0, 0, 0, 519, 520, 5, 64, 0, 0, 520, 521, 3, 118, 59, 0, 521, 531, 1, 0, 0, 0, 522, 523, 5, 57, 0, 0, 523, 524, 3, 118, 59, 0, 524, 525, 5, 64, 0, 0, 525, 528, 3, 118, 59, 0, 526, 527, 5, 11, 0, 0, 527, 529, 3, 116, 58, 0, 528, 526, 1, 0, 0, 0, 528, 529, 1, 0, 0, 0, 529, 531, 1, 0, 0, 0, 530, 501, 1, 0, 0, 0, 530, 513, 1, 0, 0, 0, 530, 522, 1, 0, 0, 0, 531, 75, 1, 0, 0, 0, 532, 533, 5, 64, 0, 0, 533, 534, 3, 118, 59, 0, 534, 77, 1, 0, 0, 0, 535, 536, 5, 84, 0, 0, 536, 537, 3, 96, 48, 0, 537, 79, 1, 0, 0, 0, 538, 539, 6, 40, -1, 0, 539, 541, 3, 134, 67, 0, 540, 542, 5, 29, 0, 0, 541, 540, 1, 0, 0, 0, 541, 542, 1, 0, 0, 0, 542, 544, 1, 0, 0, 0, 543, 545, 3, 88, 44, 0, 544, 543, 1, 0, 0, 0, 544, 545, 1, 0, 0, 0, 545, 551, 1, 0, 0, 0, 546, 547, 5, 133, 0, 0, 547, 548, 3, 80, 40, 0, 548, 549, 5, 152, 0, 0, 549, 551, 1, 0, 0, 0, 550, 538, 1, 0, 0, 0, 550, 546, 1, 0, 0, 0, 551, 566, 1, 0, 0, 0, 552, 553, 10, 3, 0, 0, 553, 554, 3, 84, 42, 0, 554, 555, 3, 80, 40, 4, 555, 565, 1, 0, 0, 0, 556, 558, 10, 4, 0, 0, 557, 559, 3, 82, 41, 0, 558, 557, 1, 0, 0, 0, 558, 559, 1, 0, 0, 0, 559, 560, 1, 0, 0, 0, 560, 561, 5, 50, 0, 0, 561, 562, 3, 80, 40, 0, 562, 563, 3, 86, 43, 0, 563, 565, 1, 0, 0, 0, 564, 552, 1, 0, 0, 0, 564, 556, 1, 0, 0, 0, 565, 568, 1, 0, 0, 0, 566, 564, 1, 0, 0, 0, 566, 567, 1, 0, 0, 0, 567, 81, 1, 0, 0, 0, 568, 566, 1, 0, 0, 0, 569, 571, 7, 3, 0, 0, 570, 569, 1, 0, 0, 0, 570, 571, 1, 0, 0, 0, 571, 572, 1, 0, 0, 0, 572, 579, 5, 46, 0, 0, 573, 575, 5, 46, 0, 0, 574, 576, 7, 3, 0, 0, 575, 574, 1, 0, 0, 0, 575, 576, 1, 0, 0, 0, 576, 579, 1, 0, 0, 0, 577, 579, 7, 3, 0, 0, 578, 570, 1, 0, 0, 0, 578, 573, 1, 0, 0, 0, 578, 577, 1, 0, 0, 0, 579, 613, 1, 0, 0, 0, 580, 582, 7, 4, 0, 0, 581, 580, 1, 0, 0, 0, 581, 582, 1, 0, 0, 0, 582, 583, 1, 0, 0, 0, 583, 585, 7, 5, 0, 0, 584, 586, 5, 68, 0, 0, 585, 584, 1, 0, 0, 0, 585, 586, 1, 0, 0, 0, 586, 595, 1, 0, 0, 0, 587, 589, 7, 5, 0, 0, 588, 590, 5, 68, 0, 0, 589, 588, 1, 0, 0, 0, 589, 590, 1, 0, 0, 0, 590, 592, 1, 0, 0, 0, 591, 593, 7, 4, 0, 0, 592, 591, 1, 0, 0, 0, 592, 593, 1, 0, 0, 0, 593, 595, 1, 0, 0, 0, 594, 581, 1, 0, 0, 0, 594, 587, 1, 0, 0, 0, 595, 613, 1, 0, 0, 0, 596, 598, 7, 6, 0, 0, 597, 596, 1, 0, 0, 0, 597, 598, 1, 0, 0, 0, 598, 599, 1, 0, 0, 0, 599, 601, 5, 36, 0, 0, 600, 602, 5, 68, 0, 0, 601, 600, 1, 0, 0, 0, 601, 602, 1, 0, 0, 0, 602, 611, 1, 0, 0, 0, 603, 605, 5, 36, 0, 0, 604, 606, 5, 68, 0, 0, 605, 604, 1, 0, 0, 0, 605, 606, 1, 0, 0, 0, 606, 608, 1, 0, 0, 0, 607, 609, 7, 6, 0, 0, 608, 607, 1, 0, 0, 0, 608, 609, 1, 0, 0, 0, 609, 611, 1, 0, 0, 0, 610, 597, 1, 0, 0, 0, 610, 603, 1, 0, 0, 0, 611, 613, 1, 0, 0, 0, 612, 578, 1, 0, 0, 0, 612, 594, 1, 0, 0, 0, 612, 610, 1, 0, 0, 0, 613, 83, 1, 0, 0, 0, 614, 615, 5, 17, 0, 0, 615, 618, 5, 50, 0, 0, 616, 618, 5, 119, 0, 0, 617, 614, 1, 0, 0, 0, 617, 616, 1, 0, 0, 0, 618, 85, 1, 0, 0, 0, 619, 620, 5, 65, 0, 0, 620, 629, 3, 116, 58, 0, 621, 622, 5, 99, 0, 0, 622, 623, 5, 133, 0, 0, 623, 624, 3, 116, 58, 0, 624, 625, 5, 152, 0, 0, 625, 629, 1, 0, 0, 0, 626, 627, 5, 99, 0, 0, 627, 629, 3, 116, 58, 0, 628, 619, 1, 0, 0, 0, 628, 621, 1, 0, 0, 0, 628, 626, 1, 0, 0, 0, 629, 87, 1, 0, 0, 0, 630, 631, 5, 80, 0, 0, 631, 634, 3, 94, 47, 0, 632, 633, 5, 64, 0, 0, 633, 635, 3, 94, 47, 0, 634, 632, 1, 0, 0, 0, 634, 635, 1, 0, 0, 0, 635, 89, 1, 0, 0, 0, 636, 641, 3, 92, 46, 0, 637, 638, 5, 119, 0, 0, 638, 640, 3, 92, 46, 0, 639, 637, 1, 0, 0, 0, 640, 643, 1, 0, 0, 0, 641, 639, 1, 0, 0, 0, 641, 642, 1, 0, 0, 0, 642, 91, 1, 0, 0, 0, 643, 641, 1, 0, 0, 0, 644, 646, 3, 118, 59, 0, 645, 647, 7, 7, 0, 0, 646, 645, 1, 0, 0, 0, 646, 647, 1, 0, 0, 0, 647, 650, 1, 0, 0, 0, 648, 649, 5, 63, 0, 0, 649, 651, 7, 8, 0, 0, 650, 648, 1, 0, 0, 0, 650, 651, 1, 0, 0, 0, 651, 654, 1, 0, 0, 0, 652, 653, 5, 16, 0, 0, 653, 655, 5, 113, 0, 0, 654, 652, 1, 0, 0, 0, 654, 655, 1, 0, 0, 0, 655, 93, 1, 0, 0, 0, 656, 663, 3, 162, 81, 0, 657, 660, 3, 146, 73, 0, 658, 659, 5, 154, 0, 0, 659, 661, 3, 146, 73, 0, 660, 658, 1, 0, 0, 0, 660, 661, 1, 0, 0, 0, 661, 663, 1, 0, 0, 0, 662, 656, 1, 0, 0, 0, 662, 657, 1, 0, 0, 0, 663, 95, 1, 0, 0, 0, 664, 669, 3, 98, 49, 0, 665, 666, 5, 119, 0, 0, 666, 668, 3, 98, 49, 0, 667, 665, 1, 0, 0, 0, 668, 671, 1, 0, 0, 0, 669, 667, 1, 0, 0, 0, 669, 670, 1, 0, 0, 0, 670, 97, 1, 0, 0, 0, 671, 669, 1, 0, 0, 0, 672, 673, 3, 158, 79, 0, 673, 674, 5, 125, 0, 0, 674, 675, 3, 148, 74, 0, 675, 99, 1, 0, 0, 0, 676, 678, 3, 102, 51, 0, 677, 676, 1, 0, 0, 0, 677, 678, 1, 0, 0, 0, 678, 680, 1, 0, 0, 0, 679, 681, 3, 104, 52, 0, 680, 679, 1, 0, 0, 0, 680, 681, 1, 0, 0, 0, 681, 683, 1, 0, 0, 0, 682, 684, 3, 106, 53, 0, 683, 682, 1, 0, 0, 0, 683, 684, 1, 0, 0, 0, 684, 101, 1, 0, 0, 0, 685, 686, 5, 70, 0, 0, 686, 687, 5, 11, 0, 0, 687, 688, 3, 116, 58, 0, 688, 103, 1, 0, 0, 0, 689, 690, 5, 67, 0, 0, 690, 691, 5, 11, 0, 0, 691, 692, 3, 90, 45, 0, 692, 105, 1, 0, 0, 0, 693, 694, 7, 9, 0, 0, 694, 695, 3, 108, 54, 0, 695, 107, 1, 0, 0, 0, 696, 703, 3, 110, 55, 0, 697, 698, 5, 9, 0, 0, 698, 699, 3, 110, 55, 0, 699, 700, 5, 2, 0, 0, 700, 701, 3, 110, 55, 0, 701, 703, 1, 0, 0, 0, 702, 696, 1, 0, 0, 0, 702, 697, 1, 0, 0, 0, 703, 109, 1, 0, 0, 0, 704, 705, 5, 19, 0, 0, 705, 717, 5, 78, 0, 0, 706, 707, 5, 97, 0, 0, 707, 717, 5, 71, 0, 0, 708, 709, 5, 97, 0, 0, 709, 717, 5, 33, 0, 0, 710, 711, 3, 146, 73, 0, 711, 712, 5, 71, 0, 0, 712, 717, 1, 0, 0, 0, 713, 714, 3, 146, 73, 0, 714, 715, 5, 33, 0, 0, 715, 717, 1, 0, 0, 0, 716, 704, 1, 0, 0, 0, 716, 706, 1, 0, 0, 0, 716, 708, 1, 0, 0, 0, 716, 710, 1, 0, 0, 0, 716, 713, 1, 0, 0, 0, 717, 111, 1, 0, 0, 0, 718, 719, 3, 118, 59, 0, 719, 720, 5, 0, 0, 1, 720, 113, 1, 0, 0, 0, 721, 778, 3, 158, 79, 0, 722, 723, 3, 158, 79, 0, 723, 724, 5, 133, 0, 0, 724, 725, 3, 158, 79, 0, 725, 732, 3, 114, 57, 0, 726, 727, 5, 119, 0, 0, 727, 728, 3, 158, 79, 0, 728, 729, 3, 114, 57, 0, 729, 731, 1, 0, 0, 0, 730, 726, 1, 0, 0, 0, 731, 734, 1, 0, 0, 0, 732, 730, 1, 0, 0, 0, 732, 733, 1, 0, 0, 0, 733, 736, 1, 0, 0, 0, 734, 732, 1, 0, 0, 0, 735, 737, 5, 119, 0, 0, 736, 735, 1, 0, 0, 0, 736, 737, 1, 0, 0, 0, 737, 738, 1, 0, 0, 0, 738, 739, 5, 152, 0, 0, 739, 778, 1, 0, 0, 0, 740, 741, 3, 158, 79, 0, 741, 742, 5, 133, 0, 0, 742, 747, 3, 160, 80, 0, 743, 744, 5, 119, 0, 0, 744, 746, 3, 160, 80, 0, 745, 743, 1, 0, 0, 0, 746, 749, 1, 0, 0, 0, 747, 745, 1, 0, 0, 0, 747, 748, 1, 0, 0, 0, 748, 751, 1, 0, 0, 0, 749, 747, 1, 0, 0, 0, 750, 752, 5, 119, 0, 0, 751, 750, 1, 0, 0, 0, 751, 752, 1, 0, 0, 0, 752, 753, 1, 0, 0, 0, 753, 754, 5, 152, 0, 0, 754, 778, 1, 0, 0, 0, 755, 756, 3, 158, 79, 0, 756, 757, 5, 133, 0, 0, 757, 762, 3, 114, 57, 0, 758, 759, 5, 119, 0, 0, 759, 761, 3, 114, 57, 0, 760, 758, 1, 0, 0, 0, 761, 764, 1, 0, 0, 0, 762, 760, 1, 0, 0, 0, 762, 763, 1, 0, 0, 0, 763, 766, 1, 0, 0, 0, 764, 762, 1, 0, 0, 0, 765, 767, 5, 119, 0, 0, 766, 765, 1, 0, 0, 0, 766, 767, 1, 0, 0, 0, 767, 768, 1, 0, 0, 0, 768, 769, 5, 152, 0, 0, 769, 778, 1, 0, 0, 0, 770, 771, 3, 158, 79, 0, 771, 773, 5, 133, 0, 0, 772, 774, 3, 116, 58, 0, 773, 772, 1, 0, 0, 0, 773, 774, 1, 0, 0, 0, 774, 775, 1, 0, 0, 0, 775, 776, 5, 152, 0, 0, 776, 778, 1, 0, 0, 0, 777, 721, 1, 0, 0, 0, 777, 722, 1, 0, 0, 0, 777, 740, 1, 0, 0, 0, 777, 755, 1, 0, 0, 0, 777, 770, 1, 0, 0, 0, 778, 115, 1, 0, 0, 0, 779, 784, 3, 118, 59, 0, 780, 781, 5, 119, 0, 0, 781, 783, 3, 118, 59, 0, 782, 780, 1, 0, 0, 0, 783, 786, 1, 0, 0, 0, 784, 782, 1, 0, 0, 0, 784, 785, 1, 0, 0, 0, 785, 788, 1, 0, 0, 0, 786, 784, 1, 0, 0, 0, 787, 789, 5, 119, 0, 0, 788, 787, 1, 0, 0, 0, 788, 789, 1, 0, 0, 0, 789, 117, 1, 0, 0, 0, 790, 791, 6, 59, -1, 0, 791, 793, 5, 12, 0, 0, 792, 794, 3, 118, 59, 0, 793, 792, 1, 0, 0, 0, 793, 794, 1, 0, 0, 0, 794, 800, 1, 0, 0, 0, 795, 796, 5, 101, 0, 0, 796, 797, 3, 118, 59, 0, 797, 798, 5, 86, 0, 0, 798, 799, 3, 118, 59, 0, 799, 801, 1, 0, 0, 0, 800, 795, 1, 0, 0, 0, 801, 802, 1, 0, 0, 0, 802, 800, 1, 0, 0, 0, 802, 803, 1, 0, 0, 0, 803, 806, 1, 0, 0, 0, 804, 805, 5, 25, 0, 0, 805, 807, 3, 118, 59, 0, 806, 804, 1, 0, 0, 0, 806, 807, 1, 0, 0, 0, 807, 808, 1, 0, 0, 0, 808, 809, 5, 26, 0, 0, 809, 941, 1, 0, 0, 0, 810, 811, 5, 13, 0, 0, 811, 812, 5, 133, 0, 0, 812, 813, 3, 118, 59, 0, 813, 814, 5, 6, 0, 0, 814, 815, 3, 114, 57, 0, 815, 816, 5, 152, 0, 0, 816, 941, 1, 0, 0, 0, 817, 818, 5, 20, 0, 0, 818, 941, 5, 113, 0, 0, 819, 820, 5, 48, 0, 0, 820, 821, 3, 118, 59, 0, 821, 822, 3, 150, 75, 0, 822, 941, 1, 0, 0, 0, 823, 824, 5, 85, 0, 0, 824, 825, 5, 133, 0, 0, 825, 826, 3, 118, 59, 0, 826, 827, 5, 35, 0, 0, 827, 830, 3, 118, 59, 0, 828, 829, 5, 34, 0, 0, 829, 831, 3, 118, 59, 0, 830, 828, 1, 0, 0, 0, 830, 831, 1, 0, 0, 0, 831, 832, 1, 0, 0, 0, 832, 833, 5, 152, 0, 0, 833, 941, 1, 0, 0, 0, 834, 835, 5, 89, 0, 0, 835, 941, 5, 113, 0, 0, 836, 837, 5, 94, 0, 0, 837, 838, 5, 133, 0, 0, 838, 839, 7, 10, 0, 0, 839, 840, 3, 164, 82, 0, 840, 841, 5, 35, 0, 0, 841, 842, 3, 118, 59, 0, 842, 843, 5, 152, 0, 0, 843, 941, 1, 0, 0, 0, 844, 845, 3, 158, 79, 0, 845, 847, 5, 133, 0, 0, 846, 848, 3, 116, 58, 0, 847, 846, 1, 0, 0, 0, 847, 848, 1, 0, 0, 0, 848, 849, 1, 0, 0, 0, 849, 850, 5, 152, 0, 0, 850, 859, 1, 0, 0, 0, 851, 853, 5, 133, 0, 0, 852, 854, 5, 24, 0, 0, 853, 852, 1, 0, 0, 0, 853, 854, 1, 0, 0, 0, 854, 856, 1, 0, 0, 0, 855, 857, 3, 116, 58, 0, 856, 855, 1, 0, 0, 0, 856, 857, 1, 0, 0, 0, 857, 858, 1, 0, 0, 0, 858, 860, 5, 152, 0, 0, 859, 851, 1, 0, 0, 0, 859, 860, 1, 0, 0, 0, 860, 861, 1, 0, 0, 0, 861, 862, 5, 69, 0, 0, 862, 863, 5, 133, 0, 0, 863, 864, 3, 100, 50, 0, 864, 865, 5, 152, 0, 0, 865, 941, 1, 0, 0, 0, 866, 867, 3, 158, 79, 0, 867, 869, 5, 133, 0, 0, 868, 870, 3, 116, 58, 0, 869, 868, 1, 0, 0, 0, 869, 870, 1, 0, 0, 0, 870, 871, 1, 0, 0, 0, 871, 872, 5, 152, 0, 0, 872, 881, 1, 0, 0, 0, 873, 875, 5, 133, 0, 0, 874, 876, 5, 24, 0, 0, 875, 874, 1, 0, 0, 0, 875, 876, 1, 0, 0, 0, 876, 878, 1, 0, 0, 0, 877, 879, 3, 116, 58, 0, 878, 877, 1, 0, 0, 0, 878, 879, 1, 0, 0, 0, 879, 880, 1, 0, 0, 0, 880, 882, 5, 152, 0, 0, 881, 873, 1, 0, 0, 0, 881, 882, 1, 0, 0, 0, 882, 883, 1, 0, 0, 0, 883, 884, 5, 69, 0, 0, 884, 885, 3, 158, 79, 0, 885, 941, 1, 0, 0, 0, 886, 892, 3, 158, 79, 0, 887, 889, 5, 133, 0, 0, 888, 890, 3, 116, 58, 0, 889, 888, 1, 0, 0, 0, 889, 890, 1, 0, 0, 0, 890, 891, 1, 0, 0, 0, 891, 893, 5, 152, 0, 0, 892, 887, 1, 0, 0, 0, 892, 893, 1, 0, 0, 0, 893, 894, 1, 0, 0, 0, 894, 896, 5, 133, 0, 0, 895, 897, 5, 24, 0, 0, 896, 895, 1, 0, 0, 0, 896, 897, 1, 0, 0, 0, 897, 899, 1, 0, 0, 0, 898, 900, 3, 116, 58, 0, 899, 898, 1, 0, 0, 0, 899, 900, 1, 0, 0, 0, 900, 901, 1, 0, 0, 0, 901, 902, 5, 152, 0, 0, 902, 941, 1, 0, 0, 0, 903, 941, 3, 122, 61, 0, 904, 941, 3, 166, 83, 0, 905, 941, 3, 148, 74, 0, 906, 907, 5, 121, 0, 0, 907, 941, 3, 118, 59, 20, 908, 909, 5, 61, 0, 0, 909, 941, 3, 118, 59, 14, 910, 911, 3, 138, 69, 0, 911, 912, 5, 123, 0, 0, 912, 914, 1, 0, 0, 0, 913, 910, 1, 0, 0, 0, 913, 914, 1, 0, 0, 0, 914, 915, 1, 0, 0, 0, 915, 941, 5, 115, 0, 0, 916, 917, 5, 133, 0, 0, 917, 918, 3, 48, 24, 0, 918, 919, 5, 152, 0, 0, 919, 941, 1, 0, 0, 0, 920, 921, 5, 133, 0, 0, 921, 922, 3, 118, 59, 0, 922, 923, 5, 152, 0, 0, 923, 941, 1, 0, 0, 0, 924, 925, 5, 133, 0, 0, 925, 926, 3, 116, 58, 0, 926, 927, 5, 152, 0, 0, 927, 941, 1, 0, 0, 0, 928, 930, 5, 132, 0, 0, 929, 931, 3, 116, 58, 0, 930, 929, 1, 0, 0, 0, 930, 931, 1, 0, 0, 0, 931, 932, 1, 0, 0, 0, 932, 941, 5, 151, 0, 0, 933, 935, 5, 131, 0, 0, 934, 936, 3, 40, 20, 0, 935, 934, 1, 0, 0, 0, 935, 936, 1, 0, 0, 0, 936, 937, 1, 0, 0, 0, 937, 941, 5, 150, 0, 0, 938, 941, 3, 120, 60, 0, 939, 941, 3, 130, 65, 0, 940, 790, 1, 0, 0, 0, 940, 810, 1, 0, 0, 0, 940, 817, 1, 0, 0, 0, 940, 819, 1, 0, 0, 0, 940, 823, 1, 0, 0, 0, 940, 834, 1, 0, 0, 0, 940, 836, 1, 0, 0, 0, 940, 844, 1, 0, 0, 0, 940, 866, 1, 0, 0, 0, 940, 886, 1, 0, 0, 0, 940, 903, 1, 0, 0, 0, 940, 904, 1, 0, 0, 0, 940, 905, 1, 0, 0, 0, 940, 906, 1, 0, 0, 0, 940, 908, 1, 0, 0, 0, 940, 913, 1, 0, 0, 0, 940, 916, 1, 0, 0, 0, 940, 920, 1, 0, 0, 0, 940, 924, 1, 0, 0, 0, 940, 928, 1, 0, 0, 0, 940, 933, 1, 0, 0, 0, 940, 938, 1, 0, 0, 0, 940, 939, 1, 0, 0, 0, 941, 1052, 1, 0, 0, 0, 942, 946, 10, 19, 0, 0, 943, 947, 5, 115, 0, 0, 944, 947, 5, 154, 0, 0, 945, 947, 5, 141, 0, 0, 946, 943, 1, 0, 0, 0, 946, 944, 1, 0, 0, 0, 946, 945, 1, 0, 0, 0, 947, 948, 1, 0, 0, 0, 948, 1051, 3, 118, 59, 20, 949, 953, 10, 18, 0, 0, 950, 954, 5, 142, 0, 0, 951, 954, 5, 121, 0, 0, 952, 954, 5, 120, 0, 0, 953, 950, 1, 0, 0, 0, 953, 951, 1, 0, 0, 0, 953, 952, 1, 0, 0, 0, 954, 955, 1, 0, 0, 0, 955, 1051, 3, 118, 59, 19, 956, 981, 10, 17, 0, 0, 957, 982, 5, 124, 0, 0, 958, 982, 5, 125, 0, 0, 959, 982, 5, 136, 0, 0, 960, 982, 5, 134, 0, 0, 961, 982, 5, 135, 0, 0, 962, 982, 5, 126, 0, 0, 963, 982, 5, 127, 0, 0, 964, 966, 5, 61, 0, 0, 965, 964, 1, 0, 0, 0, 965, 966, 1, 0, 0, 0, 966, 967, 1, 0, 0, 0, 967, 969, 5, 44, 0, 0, 968, 970, 5, 15, 0, 0, 969, 968, 1, 0, 0, 0, 969, 970, 1, 0, 0, 0, 970, 982, 1, 0, 0, 0, 971, 973, 5, 61, 0, 0, 972, 971, 1, 0, 0, 0, 972, 973, 1, 0, 0, 0, 973, 974, 1, 0, 0, 0, 974, 982, 7, 11, 0, 0, 975, 982, 5, 148, 0, 0, 976, 982, 5, 149, 0, 0, 977, 982, 5, 138, 0, 0, 978, 982, 5, 129, 0, 0, 979, 982, 5, 130, 0, 0, 980, 982, 5, 137, 0, 0, 981, 957, 1, 0, 0, 0, 981, 958, 1, 0, 0, 0, 981, 959, 1, 0, 0, 0, 981, 960, 1, 0, 0, 0, 981, 961, 1, 0, 0, 0, 981, 962, 1, 0, 0, 0, 981, 963, 1, 0, 0, 0, 981, 965, 1, 0, 0, 0, 981, 972, 1, 0, 0, 0, 981, 975, 1, 0, 0, 0, 981, 976, 1, 0, 0, 0, 981, 977, 1, 0, 0, 0, 981, 978, 1, 0, 0, 0, 981, 979, 1, 0, 0, 0, 981, 980, 1, 0, 0, 0, 982, 983, 1, 0, 0, 0, 983, 1051, 3, 118, 59, 18, 984, 985, 10, 15, 0, 0, 985, 986, 5, 140, 0, 0, 986, 1051, 3, 118, 59, 16, 987, 988, 10, 13, 0, 0, 988, 989, 5, 2, 0, 0, 989, 1051, 3, 118, 59, 14, 990, 991, 10, 12, 0, 0, 991, 992, 5, 66, 0, 0, 992, 1051, 3, 118, 59, 13, 993, 995, 10, 11, 0, 0, 994, 996, 5, 61, 0, 0, 995, 994, 1, 0, 0, 0, 995, 996, 1, 0, 0, 0, 996, 997, 1, 0, 0, 0, 997, 998, 5, 9, 0, 0, 998, 999, 3, 118, 59, 0, 999, 1000, 5, 2, 0, 0, 1000, 1001, 3, 118, 59, 12, 1001, 1051, 1, 0, 0, 0, 1002, 1003, 10, 10, 0, 0, 1003, 1004, 5, 143, 0, 0, 1004, 1005, 3, 118, 59, 0, 1005, 1006, 5, 118, 0, 0, 1006, 1007, 3, 118, 59, 10, 1007, 1051, 1, 0, 0, 0, 1008, 1009, 10, 30, 0, 0, 1009, 1011, 5, 133, 0, 0, 1010, 1012, 3, 116, 58, 0, 1011, 1010, 1, 0, 0, 0, 1011, 1012, 1, 0, 0, 0, 1012, 1013, 1, 0, 0, 0, 1013, 1051, 5, 152, 0, 0, 1014, 1015, 10, 26, 0, 0, 1015, 1016, 5, 132, 0, 0, 1016, 1017, 3, 118, 59, 0, 1017, 1018, 5, 151, 0, 0, 1018, 1051, 1, 0, 0, 0, 1019, 1020, 10, 25, 0, 0, 1020, 1021, 5, 123, 0, 0, 1021, 1051, 5, 111, 0, 0, 1022, 1023, 10, 24, 0, 0, 1023, 1024, 5, 123, 0, 0, 1024, 1051, 3, 158, 79, 0, 1025, 1026, 10, 23, 0, 0, 1026, 1027, 5, 139, 0, 0, 1027, 1028, 5, 132, 0, 0, 1028, 1029, 3, 118, 59, 0, 1029, 1030, 5, 151, 0, 0, 1030, 1051, 1, 0, 0, 0, 1031, 1032, 10, 22, 0, 0, 1032, 1033, 5, 139, 0, 0, 1033, 1051, 5, 111, 0, 0, 1034, 1035, 10, 21, 0, 0, 1035, 1036, 5, 139, 0, 0, 1036, 1051, 3, 158, 79, 0, 1037, 1038, 10, 16, 0, 0, 1038, 1040, 5, 49, 0, 0, 1039, 1041, 5, 61, 0, 0, 1040, 1039, 1, 0, 0, 0, 1040, 1041, 1, 0, 0, 0, 1041, 1042, 1, 0, 0, 0, 1042, 1051, 5, 62, 0, 0, 1043, 1048, 10, 9, 0, 0, 1044, 1045, 5, 6, 0, 0, 1045, 1049, 3, 158, 79, 0, 1046, 1047, 5, 6, 0, 0, 1047, 1049, 5, 113, 0, 0, 1048, 1044, 1, 0, 0, 0, 1048, 1046, 1, 0, 0, 0, 1049, 1051, 1, 0, 0, 0, 1050, 942, 1, 0, 0, 0, 1050, 949, 1, 0, 0, 0, 1050, 956, 1, 0, 0, 0, 1050, 984, 1, 0, 0, 0, 1050, 987, 1, 0, 0, 0, 1050, 990, 1, 0, 0, 0, 1050, 993, 1, 0, 0, 0, 1050, 1002, 1, 0, 0, 0, 1050, 1008, 1, 0, 0, 0, 1050, 1014, 1, 0, 0, 0, 1050, 1019, 1, 0, 0, 0, 1050, 1022, 1, 0, 0, 0, 1050, 1025, 1, 0, 0, 0, 1050, 1031, 1, 0, 0, 0, 1050, 1034, 1, 0, 0, 0, 1050, 1037, 1, 0, 0, 0, 1050, 1043, 1, 0, 0, 0, 1051, 1054, 1, 0, 0, 0, 1052, 1050, 1, 0, 0, 0, 1052, 1053, 1, 0, 0, 0, 1053, 119, 1, 0, 0, 0, 1054, 1052, 1, 0, 0, 0, 1055, 1056, 5, 133, 0, 0, 1056, 1061, 3, 158, 79, 0, 1057, 1058, 5, 119, 0, 0, 1058, 1060, 3, 158, 79, 0, 1059, 1057, 1, 0, 0, 0, 1060, 1063, 1, 0, 0, 0, 1061, 1059, 1, 0, 0, 0, 1061, 1062, 1, 0, 0, 0, 1062, 1065, 1, 0, 0, 0, 1063, 1061, 1, 0, 0, 0, 1064, 1066, 5, 119, 0, 0, 1065, 1064, 1, 0, 0, 0, 1065, 1066, 1, 0, 0, 0, 1066, 1067, 1, 0, 0, 0, 1067, 1068, 5, 152, 0, 0, 1068, 1083, 1, 0, 0, 0, 1069, 1074, 3, 158, 79, 0, 1070, 1071, 5, 119, 0, 0, 1071, 1073, 3, 158, 79, 0, 1072, 1070, 1, 0, 0, 0, 1073, 1076, 1, 0, 0, 0, 1074, 1072, 1, 0, 0, 0, 1074, 1075, 1, 0, 0, 0, 1075, 1078, 1, 0, 0, 0, 1076, 1074, 1, 0, 0, 0, 1077, 1079, 5, 119, 0, 0, 1078, 1077, 1, 0, 0, 0, 1078, 1079, 1, 0, 0, 0, 1079, 1083, 1, 0, 0, 0, 1080, 1081, 5, 133, 0, 0, 1081, 1083, 5, 152, 0, 0, 1082, 1055, 1, 0, 0, 0, 1082, 1069, 1, 0, 0, 0, 1082, 1080, 1, 0, 0, 0, 1083, 1084, 1, 0, 0, 0, 1084, 1087, 5, 114, 0, 0, 1085, 1088, 3, 118, 59, 0, 1086, 1088, 3, 36, 18, 0, 1087, 1085, 1, 0, 0, 0, 1087, 1086, 1, 0, 0, 0, 1088, 121, 1, 0, 0, 0, 1089, 1090, 5, 135, 0, 0, 1090, 1094, 3, 158, 79, 0, 1091, 1093, 3, 124, 62, 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, 154, 0, 0, 1098, 1099, 5, 127, 0, 0, 1099, 1122, 1, 0, 0, 0, 1100, 1101, 5, 135, 0, 0, 1101, 1105, 3, 158, 79, 0, 1102, 1104, 3, 124, 62, 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, 127, 0, 0, 1109, 1115, 3, 122, 61, 0, 1110, 1111, 5, 131, 0, 0, 1111, 1112, 3, 118, 59, 0, 1112, 1113, 5, 150, 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, 135, 0, 0, 1117, 1118, 5, 154, 0, 0, 1118, 1119, 3, 158, 79, 0, 1119, 1120, 5, 127, 0, 0, 1120, 1122, 1, 0, 0, 0, 1121, 1089, 1, 0, 0, 0, 1121, 1100, 1, 0, 0, 0, 1122, 123, 1, 0, 0, 0, 1123, 1124, 3, 158, 79, 0, 1124, 1125, 5, 125, 0, 0, 1125, 1126, 3, 164, 82, 0, 1126, 1135, 1, 0, 0, 0, 1127, 1128, 3, 158, 79, 0, 1128, 1129, 5, 125, 0, 0, 1129, 1130, 5, 131, 0, 0, 1130, 1131, 3, 118, 59, 0, 1131, 1132, 5, 150, 0, 0, 1132, 1135, 1, 0, 0, 0, 1133, 1135, 3, 158, 79, 0, 1134, 1123, 1, 0, 0, 0, 1134, 1127, 1, 0, 0, 0, 1134, 1133, 1, 0, 0, 0, 1135, 125, 1, 0, 0, 0, 1136, 1141, 3, 128, 64, 0, 1137, 1138, 5, 119, 0, 0, 1138, 1140, 3, 128, 64, 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, 119, 0, 0, 1145, 1144, 1, 0, 0, 0, 1145, 1146, 1, 0, 0, 0, 1146, 127, 1, 0, 0, 0, 1147, 1148, 3, 158, 79, 0, 1148, 1149, 5, 6, 0, 0, 1149, 1150, 5, 133, 0, 0, 1150, 1151, 3, 48, 24, 0, 1151, 1152, 5, 152, 0, 0, 1152, 1158, 1, 0, 0, 0, 1153, 1154, 3, 118, 59, 0, 1154, 1155, 5, 6, 0, 0, 1155, 1156, 3, 158, 79, 0, 1156, 1158, 1, 0, 0, 0, 1157, 1147, 1, 0, 0, 0, 1157, 1153, 1, 0, 0, 0, 1158, 129, 1, 0, 0, 0, 1159, 1167, 3, 162, 81, 0, 1160, 1161, 3, 138, 69, 0, 1161, 1162, 5, 123, 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, 132, 66, 0, 1166, 1159, 1, 0, 0, 0, 1166, 1163, 1, 0, 0, 0, 1167, 131, 1, 0, 0, 0, 1168, 1173, 3, 158, 79, 0, 1169, 1170, 5, 123, 0, 0, 1170, 1172, 3, 158, 79, 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, 133, 1, 0, 0, 0, 1175, 1173, 1, 0, 0, 0, 1176, 1177, 6, 67, -1, 0, 1177, 1186, 3, 138, 69, 0, 1178, 1186, 3, 136, 68, 0, 1179, 1180, 5, 133, 0, 0, 1180, 1181, 3, 48, 24, 0, 1181, 1182, 5, 152, 0, 0, 1182, 1186, 1, 0, 0, 0, 1183, 1186, 3, 122, 61, 0, 1184, 1186, 3, 162, 81, 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, 156, 78, 0, 1189, 1190, 5, 6, 0, 0, 1190, 1192, 3, 158, 79, 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, 135, 1, 0, 0, 0, 1197, 1195, 1, 0, 0, 0, 1198, 1199, 3, 158, 79, 0, 1199, 1201, 5, 133, 0, 0, 1200, 1202, 3, 140, 70, 0, 1201, 1200, 1, 0, 0, 0, 1201, 1202, 1, 0, 0, 0, 1202, 1203, 1, 0, 0, 0, 1203, 1204, 5, 152, 0, 0, 1204, 137, 1, 0, 0, 0, 1205, 1206, 3, 142, 71, 0, 1206, 1207, 5, 123, 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, 158, 79, 0, 1211, 139, 1, 0, 0, 0, 1212, 1217, 3, 118, 59, 0, 1213, 1214, 5, 119, 0, 0, 1214, 1216, 3, 118, 59, 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, 119, 0, 0, 1221, 1220, 1, 0, 0, 0, 1221, 1222, 1, 0, 0, 0, 1222, 141, 1, 0, 0, 0, 1223, 1224, 3, 158, 79, 0, 1224, 143, 1, 0, 0, 0, 1225, 1234, 5, 109, 0, 0, 1226, 1227, 5, 123, 0, 0, 1227, 1234, 7, 12, 0, 0, 1228, 1229, 5, 111, 0, 0, 1229, 1231, 5, 123, 0, 0, 1230, 1232, 7, 12, 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, 145, 1, 0, 0, 0, 1235, 1237, 7, 13, 0, 0, 1236, 1235, 1, 0, 0, 0, 1236, 1237, 1, 0, 0, 0, 1237, 1244, 1, 0, 0, 0, 1238, 1245, 3, 144, 72, 0, 1239, 1245, 5, 110, 0, 0, 1240, 1245, 5, 111, 0, 0, 1241, 1245, 5, 112, 0, 0, 1242, 1245, 5, 45, 0, 0, 1243, 1245, 5, 60, 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, 147, 1, 0, 0, 0, 1246, 1250, 3, 146, 73, 0, 1247, 1250, 5, 113, 0, 0, 1248, 1250, 5, 62, 0, 0, 1249, 1246, 1, 0, 0, 0, 1249, 1247, 1, 0, 0, 0, 1249, 1248, 1, 0, 0, 0, 1250, 149, 1, 0, 0, 0, 1251, 1252, 7, 14, 0, 0, 1252, 151, 1, 0, 0, 0, 1253, 1254, 7, 15, 0, 0, 1254, 153, 1, 0, 0, 0, 1255, 1256, 7, 16, 0, 0, 1256, 155, 1, 0, 0, 0, 1257, 1260, 5, 108, 0, 0, 1258, 1260, 3, 154, 77, 0, 1259, 1257, 1, 0, 0, 0, 1259, 1258, 1, 0, 0, 0, 1260, 157, 1, 0, 0, 0, 1261, 1265, 5, 108, 0, 0, 1262, 1265, 3, 150, 75, 0, 1263, 1265, 3, 152, 76, 0, 1264, 1261, 1, 0, 0, 0, 1264, 1262, 1, 0, 0, 0, 1264, 1263, 1, 0, 0, 0, 1265, 159, 1, 0, 0, 0, 1266, 1267, 3, 164, 82, 0, 1267, 1268, 5, 125, 0, 0, 1268, 1269, 3, 146, 73, 0, 1269, 161, 1, 0, 0, 0, 1270, 1271, 5, 131, 0, 0, 1271, 1272, 3, 118, 59, 0, 1272, 1273, 5, 150, 0, 0, 1273, 163, 1, 0, 0, 0, 1274, 1277, 5, 113, 0, 0, 1275, 1277, 3, 166, 83, 0, 1276, 1274, 1, 0, 0, 0, 1276, 1275, 1, 0, 0, 0, 1277, 165, 1, 0, 0, 0, 1278, 1282, 5, 145, 0, 0, 1279, 1281, 3, 168, 84, 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, 147, 0, 0, 1286, 167, 1, 0, 0, 0, 1287, 1288, 5, 160, 0, 0, 1288, 1289, 3, 118, 59, 0, 1289, 1290, 5, 150, 0, 0, 1290, 1293, 1, 0, 0, 0, 1291, 1293, 5, 159, 0, 0, 1292, 1287, 1, 0, 0, 0, 1292, 1291, 1, 0, 0, 0, 1293, 169, 1, 0, 0, 0, 1294, 1298, 5, 146, 0, 0, 1295, 1297, 3, 172, 86, 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, 171, 1, 0, 0, 0, 1303, 1304, 5, 162, 0, 0, 1304, 1305, 3, 118, 59, 0, 1305, 1306, 5, 150, 0, 0, 1306, 1309, 1, 0, 0, 0, 1307, 1309, 5, 161, 0, 0, 1308, 1303, 1, 0, 0, 0, 1308, 1307, 1, 0, 0, 0, 1309, 173, 1, 0, 0, 0, 168, 177, 184, 193, 200, 204, 218, 222, 225, 229, 232, 239, 243, 252, 257, 266, 274, 281, 285, 291, 296, 304, 311, 317, 329, 337, 351, 355, 360, 370, 376, 384, 388, 392, 395, 399, 402, 405, 408, 411, 415, 419, 422, 425, 428, 432, 435, 444, 450, 471, 488, 505, 511, 517, 528, 530, 541, 544, 550, 558, 564, 566, 570, 575, 578, 581, 585, 589, 592, 594, 597, 601, 605, 608, 610, 612, 617, 628, 634, 641, 646, 650, 654, 660, 662, 669, 677, 680, 683, 702, 716, 732, 736, 747, 751, 762, 766, 773, 777, 784, 788, 793, 802, 806, 830, 847, 853, 856, 859, 869, 875, 878, 881, 889, 892, 896, 899, 913, 930, 935, 940, 946, 953, 965, 969, 972, 981, 995, 1011, 1040, 1048, 1050, 1052, 1061, 1065, 1074, 1078, 1082, 1087, 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 diff --git a/posthog/hogql/grammar/HogQLParser.py b/posthog/hogql/grammar/HogQLParser.py index ab0499e653ddb..70f7e139b7999 100644 --- a/posthog/hogql/grammar/HogQLParser.py +++ b/posthog/hogql/grammar/HogQLParser.py @@ -10,7 +10,7 @@ def serializedATN(): return [ - 4,1,160,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, + 4,1,162,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, @@ -23,519 +23,522 @@ 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,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,17,2,0,31,31,36,36,2,0,18,18,75,75,2,0,45,45,52,52, - 3,0,1,1,4,4,8,8,4,0,1,1,3,4,8,8,81,81,2,0,52,52,74,74,2,0,1,1,4, - 4,2,0,7,7,22,23,2,0,30,30,50,50,2,0,72,72,77,77,3,0,10,10,51,51, - 91,91,2,0,42,42,54,54,1,0,108,109,2,0,119,119,140,140,7,0,21,21, - 39,39,56,57,71,71,79,79,98,98,104,104,17,0,1,13,15,20,22,28,30,30, - 32,35,37,38,40,43,45,52,54,55,59,59,61,70,72,78,80,84,86,93,95,97, - 99,100,102,103,4,0,20,20,30,30,40,40,49,49,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,53,0,0,187,191,3,156,78,0,188,189,5, - 116,0,0,189,190,5,123,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,117,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,117,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,73,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,151,0,0,223,222,1,0,0,0,223,224, - 1,0,0,0,224,13,1,0,0,0,225,227,5,85,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,151,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,131,0,0,234,237,3,156,78,0,235,236,5,116,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,150, - 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,94,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,41,0,0,258,259,5,131,0,0,259,260,3,4,2,0,260,261, - 5,150,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,101,0,0,267, - 268,5,131,0,0,268,269,3,4,2,0,269,270,5,150,0,0,270,272,3,10,5,0, - 271,273,5,151,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,131,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,151,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, - 151,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,150,0,0,292,294,3,10,5,0,293,295,5,151,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,131,0,0,298,299,5,53,0,0,299,302,3,156,78,0,300,301,5,117, - 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,43,0,0,305,306,3,4,2,0,306,307,5,150,0,0,307,309, - 3,10,5,0,308,310,5,151,0,0,309,308,1,0,0,0,309,310,1,0,0,0,310,27, - 1,0,0,0,311,312,7,0,0,0,312,313,3,156,78,0,313,315,5,131,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,150,0,0,318,319,3,36,18,0,319,29,1,0,0,0,320,321,3,4,2,0,321, - 322,5,116,0,0,322,323,5,123,0,0,323,324,3,4,2,0,324,31,1,0,0,0,325, - 327,3,4,2,0,326,328,5,151,0,0,327,326,1,0,0,0,327,328,1,0,0,0,328, - 33,1,0,0,0,329,330,5,151,0,0,330,35,1,0,0,0,331,335,5,129,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,148,0,0,339, - 37,1,0,0,0,340,341,3,4,2,0,341,342,5,116,0,0,342,343,3,4,2,0,343, - 39,1,0,0,0,344,349,3,38,19,0,345,346,5,117,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,117,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,96,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,131,0,0,373,374, - 3,44,22,0,374,375,5,150,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,80,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,103,0,0,406,408,7,1,0,0,407, - 405,1,0,0,0,407,408,1,0,0,0,408,411,1,0,0,0,409,410,5,103,0,0,410, - 412,5,90,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,103,0,0,430,431,3,124, - 62,0,431,51,1,0,0,0,432,433,5,89,0,0,433,436,5,109,0,0,434,435,5, - 103,0,0,435,437,5,86,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,2,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,48,0,0,446,447,3,114,57,0,447,57,1,0,0,0,448,449, - 5,102,0,0,449,450,3,156,78,0,450,451,5,6,0,0,451,452,5,131,0,0,452, - 453,3,98,49,0,453,463,5,150,0,0,454,455,5,117,0,0,455,456,3,156, - 78,0,456,457,5,6,0,0,457,458,5,131,0,0,458,459,3,98,49,0,459,460, - 5,150,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, - 70,0,0,467,468,3,116,58,0,468,61,1,0,0,0,469,470,5,100,0,0,470,471, - 3,116,58,0,471,63,1,0,0,0,472,473,5,37,0,0,473,480,5,11,0,0,474, - 475,7,1,0,0,475,476,5,131,0,0,476,477,3,114,57,0,477,478,5,150,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,38,0,0,483,484,3,116,58,0,484,67,1, - 0,0,0,485,486,5,65,0,0,486,487,5,11,0,0,487,488,3,88,44,0,488,69, - 1,0,0,0,489,490,5,65,0,0,490,491,5,11,0,0,491,492,3,114,57,0,492, - 71,1,0,0,0,493,494,5,55,0,0,494,497,3,116,58,0,495,496,5,117,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,103,0,0,500,504,5,86,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,55,0,0,506,509,3,116,58,0,507,508,5,103,0,0,508, - 510,5,86,0,0,509,507,1,0,0,0,509,510,1,0,0,0,510,511,1,0,0,0,511, - 512,5,62,0,0,512,513,3,116,58,0,513,523,1,0,0,0,514,515,5,55,0,0, - 515,516,3,116,58,0,516,517,5,62,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,62,0,0,525,526,3,116,58,0,526,75,1,0,0,0,527,528, - 5,82,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,131,0,0,539,540,3,78,39,0,540,541,5, - 150,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,48,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,3,0,0,562,561,1,0,0,0,562,563,1,0,0,0,563,564, - 1,0,0,0,564,571,5,45,0,0,565,567,5,45,0,0,566,568,7,3,0,0,567,566, - 1,0,0,0,567,568,1,0,0,0,568,571,1,0,0,0,569,571,7,3,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,4,0,0,573,572,1,0,0,0,573,574,1,0,0,0,574,575,1,0,0,0,575,577, - 7,5,0,0,576,578,5,66,0,0,577,576,1,0,0,0,577,578,1,0,0,0,578,587, - 1,0,0,0,579,581,7,5,0,0,580,582,5,66,0,0,581,580,1,0,0,0,581,582, - 1,0,0,0,582,584,1,0,0,0,583,585,7,4,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,6,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,66,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,66,0,0,597,596, - 1,0,0,0,597,598,1,0,0,0,598,600,1,0,0,0,599,601,7,6,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,48,0,0,608,610, - 5,117,0,0,609,606,1,0,0,0,609,608,1,0,0,0,610,83,1,0,0,0,611,612, - 5,63,0,0,612,621,3,114,57,0,613,614,5,97,0,0,614,615,5,131,0,0,615, - 616,3,114,57,0,616,617,5,150,0,0,617,621,1,0,0,0,618,619,5,97,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,78,0,0,623,626,3,92,46,0,624,625,5, - 62,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,117,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,7,0,0,638, - 637,1,0,0,0,638,639,1,0,0,0,639,642,1,0,0,0,640,641,5,61,0,0,641, - 643,7,8,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,111,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,152,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,117,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,123,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,68,0,0,678,679,5,11,0,0,679,680,3,114,57,0, - 680,101,1,0,0,0,681,682,5,65,0,0,682,683,5,11,0,0,683,684,3,88,44, - 0,684,103,1,0,0,0,685,686,7,9,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,76,0,0,698,699, - 5,95,0,0,699,709,5,69,0,0,700,701,5,95,0,0,701,709,5,32,0,0,702, - 703,3,144,72,0,703,704,5,69,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,131,0,0,716,717,3,156,78,0,717, - 724,3,112,56,0,718,719,5,117,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,117, - 0,0,728,727,1,0,0,0,728,729,1,0,0,0,729,730,1,0,0,0,730,731,5,150, - 0,0,731,770,1,0,0,0,732,733,3,156,78,0,733,734,5,131,0,0,734,739, - 3,158,79,0,735,736,5,117,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,117,0,0,743,742,1,0,0,0,743,744,1,0,0, - 0,744,745,1,0,0,0,745,746,5,150,0,0,746,770,1,0,0,0,747,748,3,156, - 78,0,748,749,5,131,0,0,749,754,3,112,56,0,750,751,5,117,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,117,0,0,758, - 757,1,0,0,0,758,759,1,0,0,0,759,760,1,0,0,0,760,761,5,150,0,0,761, - 770,1,0,0,0,762,763,3,156,78,0,763,765,5,131,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,150, - 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,117,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,117,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,99,0,0,788, - 789,3,116,58,0,789,790,5,84,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,131,0,0,804,805,3,116,58,0,805, - 806,5,6,0,0,806,807,3,112,56,0,807,808,5,150,0,0,808,933,1,0,0,0, - 809,810,5,20,0,0,810,933,5,111,0,0,811,812,5,46,0,0,812,813,3,116, - 58,0,813,814,3,148,74,0,814,933,1,0,0,0,815,816,5,83,0,0,816,817, - 5,131,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,150,0,0,825,933,1,0,0,0,826,827,5, - 87,0,0,827,933,5,111,0,0,828,829,5,92,0,0,829,830,5,131,0,0,830, - 831,7,10,0,0,831,832,3,162,81,0,832,833,5,34,0,0,833,834,3,116,58, - 0,834,835,5,150,0,0,835,933,1,0,0,0,836,837,3,156,78,0,837,839,5, - 131,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,150,0,0,842,851,1,0,0,0,843,845,5,131,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,150,0,0,851,843,1,0,0,0,851,852,1,0,0,0,852,853,1,0,0,0,853, - 854,5,67,0,0,854,855,5,131,0,0,855,856,3,98,49,0,856,857,5,150,0, - 0,857,933,1,0,0,0,858,859,3,156,78,0,859,861,5,131,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,150,0,0,864,873,1,0,0,0,865,867,5,131,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,150,0,0,873, - 865,1,0,0,0,873,874,1,0,0,0,874,875,1,0,0,0,875,876,5,67,0,0,876, - 877,3,156,78,0,877,933,1,0,0,0,878,884,3,156,78,0,879,881,5,131, - 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,150,0,0,884,879,1,0,0,0,884,885,1,0,0,0,885,886, - 1,0,0,0,886,888,5,131,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,150,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,119,0, - 0,899,933,3,116,58,20,900,901,5,59,0,0,901,933,3,116,58,14,902,903, - 3,136,68,0,903,904,5,121,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,113,0,0,908,909,5,131,0,0, - 909,910,3,44,22,0,910,911,5,150,0,0,911,933,1,0,0,0,912,913,5,131, - 0,0,913,914,3,116,58,0,914,915,5,150,0,0,915,933,1,0,0,0,916,917, - 5,131,0,0,917,918,3,114,57,0,918,919,5,150,0,0,919,933,1,0,0,0,920, - 922,5,130,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,149,0,0,925,927,5,129,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,148, - 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,113,0,0,936,939,5,152,0,0,937,939,5,139,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,140,0,0,943,946,5,119,0,0,944,946,5, - 118,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,122,0,0, - 950,974,5,123,0,0,951,974,5,134,0,0,952,974,5,132,0,0,953,974,5, - 133,0,0,954,974,5,124,0,0,955,974,5,125,0,0,956,958,5,59,0,0,957, - 956,1,0,0,0,957,958,1,0,0,0,958,959,1,0,0,0,959,961,5,43,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,59,0,0,964,963,1,0,0,0,964,965,1,0,0,0,965,966,1,0,0,0,966, - 974,7,11,0,0,967,974,5,146,0,0,968,974,5,147,0,0,969,974,5,136,0, - 0,970,974,5,127,0,0,971,974,5,128,0,0,972,974,5,135,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,138,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,64,0,0,984,1043,3,116,58,13,985,987,10,11,0, - 0,986,988,5,59,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,141,0,0,996,997, - 3,116,58,0,997,998,5,116,0,0,998,999,3,116,58,10,999,1043,1,0,0, - 0,1000,1001,10,30,0,0,1001,1003,5,131,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,150, - 0,0,1006,1007,10,26,0,0,1007,1008,5,130,0,0,1008,1009,3,116,58,0, - 1009,1010,5,149,0,0,1010,1043,1,0,0,0,1011,1012,10,25,0,0,1012,1013, - 5,121,0,0,1013,1043,5,109,0,0,1014,1015,10,24,0,0,1015,1016,5,121, - 0,0,1016,1043,3,156,78,0,1017,1018,10,23,0,0,1018,1019,5,137,0,0, - 1019,1020,5,130,0,0,1020,1021,3,116,58,0,1021,1022,5,149,0,0,1022, - 1043,1,0,0,0,1023,1024,10,22,0,0,1024,1025,5,137,0,0,1025,1043,5, - 109,0,0,1026,1027,10,21,0,0,1027,1028,5,137,0,0,1028,1043,3,156, - 78,0,1029,1030,10,16,0,0,1030,1032,5,47,0,0,1031,1033,5,59,0,0,1032, - 1031,1,0,0,0,1032,1033,1,0,0,0,1033,1034,1,0,0,0,1034,1043,5,60, - 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,111,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,131,0,0,1048,1053,3,156,78,0,1049, - 1050,5,117,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,117,0,0,1057,1056,1,0,0,0,1057,1058,1,0, - 0,0,1058,1059,1,0,0,0,1059,1060,5,150,0,0,1060,1075,1,0,0,0,1061, - 1066,3,156,78,0,1062,1063,5,117,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,117,0,0,1070,1069,1,0, - 0,0,1070,1071,1,0,0,0,1071,1075,1,0,0,0,1072,1073,5,131,0,0,1073, - 1075,5,150,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,112,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,133,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,152,0,0, - 1090,1091,5,125,0,0,1091,1114,1,0,0,0,1092,1093,5,133,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,125,0,0,1101,1107,3,120,60,0,1102,1103,5,129, - 0,0,1103,1104,3,116,58,0,1104,1105,5,148,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,133,0,0,1109,1110,5,152,0,0,1110,1111,3,156,78,0,1111, - 1112,5,125,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,123,0,0,1117, - 1118,3,162,81,0,1118,1127,1,0,0,0,1119,1120,3,156,78,0,1120,1121, - 5,123,0,0,1121,1122,5,129,0,0,1122,1123,3,116,58,0,1123,1124,5,148, - 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,117,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,117,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,131,0,0,1142,1143,3,44,22,0,1143,1144,5,150, - 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,121,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,121,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,131,0,0,1172,1173,3,44,22,0,1173,1174,5,150,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,131,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,150,0,0,1196,135,1,0,0,0,1197,1198,3,140,70,0,1198,1199, - 5,121,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,117,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,117,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,107,0,0,1218,1219,5,121,0,0,1219,1226,7, - 12,0,0,1220,1221,5,109,0,0,1221,1223,5,121,0,0,1222,1224,7,12,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,13,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,108,0,0,1232,1237,5,109,0,0, - 1233,1237,5,110,0,0,1234,1237,5,44,0,0,1235,1237,5,58,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,111,0,0,1240,1242,5,60,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,14,0, - 0,1244,149,1,0,0,0,1245,1246,7,15,0,0,1246,151,1,0,0,0,1247,1248, - 7,16,0,0,1248,153,1,0,0,0,1249,1252,5,106,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,106,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,123,0,0,1260,1261,3,144,72,0,1261,159, - 1,0,0,0,1262,1263,5,129,0,0,1263,1264,3,116,58,0,1264,1265,5,148, - 0,0,1265,161,1,0,0,0,1266,1269,5,111,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,143, - 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,145,0,0,1278,165,1,0,0,0,1279,1280,5,158,0,0,1280, - 1281,3,116,58,0,1281,1282,5,148,0,0,1282,1285,1,0,0,0,1283,1285, - 5,157,0,0,1284,1279,1,0,0,0,1284,1283,1,0,0,0,1285,167,1,0,0,0,1286, - 1290,5,144,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,160, - 0,0,1296,1297,3,116,58,0,1297,1298,5,148,0,0,1298,1301,1,0,0,0,1299, - 1301,5,159,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 + 85,7,85,2,86,7,86,1,0,5,0,176,8,0,10,0,12,0,179,9,0,1,0,1,0,1,1, + 1,1,3,1,185,8,1,1,2,1,2,1,3,1,3,1,3,1,3,1,3,3,3,194,8,3,1,4,1,4, + 1,4,5,4,199,8,4,10,4,12,4,202,9,4,1,4,3,4,205,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,219,8,5,1,6,1,6,3,6,223,8, + 6,1,6,3,6,226,8,6,1,7,1,7,3,7,230,8,7,1,7,3,7,233,8,7,1,8,1,8,1, + 8,1,8,1,8,3,8,240,8,8,1,8,1,8,3,8,244,8,8,1,8,1,8,1,9,1,9,1,9,5, + 9,251,8,9,10,9,12,9,254,9,9,1,9,1,9,3,9,258,8,9,1,10,1,10,1,10,1, + 10,1,10,1,10,1,10,3,10,267,8,10,1,11,1,11,1,11,1,11,1,11,1,11,3, + 11,275,8,11,1,12,1,12,1,12,1,12,1,12,3,12,282,8,12,1,12,1,12,3,12, + 286,8,12,1,12,1,12,1,12,1,12,3,12,292,8,12,1,12,1,12,1,12,3,12,297, + 8,12,1,13,1,13,1,13,1,13,1,13,1,13,3,13,305,8,13,1,13,1,13,1,13, + 1,13,1,13,3,13,312,8,13,1,14,1,14,1,14,1,14,3,14,318,8,14,1,14,1, + 14,1,14,1,15,1,15,1,15,1,15,1,15,1,16,1,16,3,16,330,8,16,1,17,1, + 17,1,18,1,18,5,18,336,8,18,10,18,12,18,339,9,18,1,18,1,18,1,19,1, + 19,1,19,1,19,1,20,1,20,1,20,5,20,350,8,20,10,20,12,20,353,9,20,1, + 20,3,20,356,8,20,1,21,1,21,1,21,3,21,361,8,21,1,21,1,21,1,22,1,22, + 1,22,1,22,1,22,1,22,3,22,371,8,22,1,23,1,23,1,23,1,23,3,23,377,8, + 23,1,23,1,23,1,24,1,24,5,24,383,8,24,10,24,12,24,386,9,24,1,25,3, + 25,389,8,25,1,25,1,25,3,25,393,8,25,1,25,3,25,396,8,25,1,25,1,25, + 3,25,400,8,25,1,25,3,25,403,8,25,1,25,3,25,406,8,25,1,25,3,25,409, + 8,25,1,25,3,25,412,8,25,1,25,1,25,3,25,416,8,25,1,25,1,25,3,25,420, + 8,25,1,25,3,25,423,8,25,1,25,3,25,426,8,25,1,25,3,25,429,8,25,1, + 25,1,25,3,25,433,8,25,1,25,3,25,436,8,25,1,26,1,26,1,26,1,27,1,27, + 1,27,1,27,3,27,445,8,27,1,28,1,28,1,28,1,29,3,29,451,8,29,1,29,1, + 29,1,29,1,29,1,30,1,30,1,30,1,30,1,30,1,30,1,30,1,30,1,30,1,30,1, + 30,1,30,1,30,5,30,470,8,30,10,30,12,30,473,9,30,1,31,1,31,1,31,1, + 32,1,32,1,32,1,33,1,33,1,33,1,33,1,33,1,33,1,33,1,33,3,33,489,8, + 33,1,34,1,34,1,34,1,35,1,35,1,35,1,35,1,36,1,36,1,36,1,36,1,37,1, + 37,1,37,1,37,3,37,506,8,37,1,37,1,37,1,37,1,37,3,37,512,8,37,1,37, + 1,37,1,37,1,37,3,37,518,8,37,1,37,1,37,1,37,1,37,1,37,1,37,1,37, + 1,37,1,37,3,37,529,8,37,3,37,531,8,37,1,38,1,38,1,38,1,39,1,39,1, + 39,1,40,1,40,1,40,3,40,542,8,40,1,40,3,40,545,8,40,1,40,1,40,1,40, + 1,40,3,40,551,8,40,1,40,1,40,1,40,1,40,1,40,1,40,3,40,559,8,40,1, + 40,1,40,1,40,1,40,5,40,565,8,40,10,40,12,40,568,9,40,1,41,3,41,571, + 8,41,1,41,1,41,1,41,3,41,576,8,41,1,41,3,41,579,8,41,1,41,3,41,582, + 8,41,1,41,1,41,3,41,586,8,41,1,41,1,41,3,41,590,8,41,1,41,3,41,593, + 8,41,3,41,595,8,41,1,41,3,41,598,8,41,1,41,1,41,3,41,602,8,41,1, + 41,1,41,3,41,606,8,41,1,41,3,41,609,8,41,3,41,611,8,41,3,41,613, + 8,41,1,42,1,42,1,42,3,42,618,8,42,1,43,1,43,1,43,1,43,1,43,1,43, + 1,43,1,43,1,43,3,43,629,8,43,1,44,1,44,1,44,1,44,3,44,635,8,44,1, + 45,1,45,1,45,5,45,640,8,45,10,45,12,45,643,9,45,1,46,1,46,3,46,647, + 8,46,1,46,1,46,3,46,651,8,46,1,46,1,46,3,46,655,8,46,1,47,1,47,1, + 47,1,47,3,47,661,8,47,3,47,663,8,47,1,48,1,48,1,48,5,48,668,8,48, + 10,48,12,48,671,9,48,1,49,1,49,1,49,1,49,1,50,3,50,678,8,50,1,50, + 3,50,681,8,50,1,50,3,50,684,8,50,1,51,1,51,1,51,1,51,1,52,1,52,1, + 52,1,52,1,53,1,53,1,53,1,54,1,54,1,54,1,54,1,54,1,54,3,54,703,8, + 54,1,55,1,55,1,55,1,55,1,55,1,55,1,55,1,55,1,55,1,55,1,55,1,55,3, + 55,717,8,55,1,56,1,56,1,56,1,57,1,57,1,57,1,57,1,57,1,57,1,57,1, + 57,1,57,5,57,731,8,57,10,57,12,57,734,9,57,1,57,3,57,737,8,57,1, + 57,1,57,1,57,1,57,1,57,1,57,1,57,5,57,746,8,57,10,57,12,57,749,9, + 57,1,57,3,57,752,8,57,1,57,1,57,1,57,1,57,1,57,1,57,1,57,5,57,761, + 8,57,10,57,12,57,764,9,57,1,57,3,57,767,8,57,1,57,1,57,1,57,1,57, + 1,57,3,57,774,8,57,1,57,1,57,3,57,778,8,57,1,58,1,58,1,58,5,58,783, + 8,58,10,58,12,58,786,9,58,1,58,3,58,789,8,58,1,59,1,59,1,59,3,59, + 794,8,59,1,59,1,59,1,59,1,59,1,59,4,59,801,8,59,11,59,12,59,802, + 1,59,1,59,3,59,807,8,59,1,59,1,59,1,59,1,59,1,59,1,59,1,59,1,59, + 1,59,1,59,1,59,1,59,1,59,1,59,1,59,1,59,1,59,1,59,1,59,1,59,1,59, + 1,59,3,59,831,8,59,1,59,1,59,1,59,1,59,1,59,1,59,1,59,1,59,1,59, + 1,59,1,59,1,59,1,59,1,59,1,59,3,59,848,8,59,1,59,1,59,1,59,1,59, + 3,59,854,8,59,1,59,3,59,857,8,59,1,59,3,59,860,8,59,1,59,1,59,1, + 59,1,59,1,59,1,59,1,59,1,59,3,59,870,8,59,1,59,1,59,1,59,1,59,3, + 59,876,8,59,1,59,3,59,879,8,59,1,59,3,59,882,8,59,1,59,1,59,1,59, + 1,59,1,59,1,59,3,59,890,8,59,1,59,3,59,893,8,59,1,59,1,59,3,59,897, + 8,59,1,59,3,59,900,8,59,1,59,1,59,1,59,1,59,1,59,1,59,1,59,1,59, + 1,59,1,59,1,59,1,59,3,59,914,8,59,1,59,1,59,1,59,1,59,1,59,1,59, + 1,59,1,59,1,59,1,59,1,59,1,59,1,59,1,59,1,59,3,59,931,8,59,1,59, + 1,59,1,59,3,59,936,8,59,1,59,1,59,1,59,3,59,941,8,59,1,59,1,59,1, + 59,1,59,3,59,947,8,59,1,59,1,59,1,59,1,59,1,59,3,59,954,8,59,1,59, + 1,59,1,59,1,59,1,59,1,59,1,59,1,59,1,59,1,59,3,59,966,8,59,1,59, + 1,59,3,59,970,8,59,1,59,3,59,973,8,59,1,59,1,59,1,59,1,59,1,59,1, + 59,1,59,3,59,982,8,59,1,59,1,59,1,59,1,59,1,59,1,59,1,59,1,59,1, + 59,1,59,1,59,1,59,3,59,996,8,59,1,59,1,59,1,59,1,59,1,59,1,59,1, + 59,1,59,1,59,1,59,1,59,1,59,1,59,1,59,3,59,1012,8,59,1,59,1,59,1, + 59,1,59,1,59,1,59,1,59,1,59,1,59,1,59,1,59,1,59,1,59,1,59,1,59,1, + 59,1,59,1,59,1,59,1,59,1,59,1,59,1,59,1,59,1,59,1,59,1,59,3,59,1041, + 8,59,1,59,1,59,1,59,1,59,1,59,1,59,3,59,1049,8,59,5,59,1051,8,59, + 10,59,12,59,1054,9,59,1,60,1,60,1,60,1,60,5,60,1060,8,60,10,60,12, + 60,1063,9,60,1,60,3,60,1066,8,60,1,60,1,60,1,60,1,60,1,60,5,60,1073, + 8,60,10,60,12,60,1076,9,60,1,60,3,60,1079,8,60,1,60,1,60,3,60,1083, + 8,60,1,60,1,60,1,60,3,60,1088,8,60,1,61,1,61,1,61,5,61,1093,8,61, + 10,61,12,61,1096,9,61,1,61,1,61,1,61,1,61,1,61,1,61,5,61,1104,8, + 61,10,61,12,61,1107,9,61,1,61,1,61,1,61,1,61,1,61,1,61,3,61,1115, + 8,61,1,61,1,61,1,61,1,61,1,61,3,61,1122,8,61,1,62,1,62,1,62,1,62, + 1,62,1,62,1,62,1,62,1,62,1,62,1,62,3,62,1135,8,62,1,63,1,63,1,63, + 5,63,1140,8,63,10,63,12,63,1143,9,63,1,63,3,63,1146,8,63,1,64,1, + 64,1,64,1,64,1,64,1,64,1,64,1,64,1,64,1,64,3,64,1158,8,64,1,65,1, + 65,1,65,1,65,3,65,1164,8,65,1,65,3,65,1167,8,65,1,66,1,66,1,66,5, + 66,1172,8,66,10,66,12,66,1175,9,66,1,67,1,67,1,67,1,67,1,67,1,67, + 1,67,1,67,1,67,3,67,1186,8,67,1,67,1,67,1,67,1,67,3,67,1192,8,67, + 5,67,1194,8,67,10,67,12,67,1197,9,67,1,68,1,68,1,68,3,68,1202,8, + 68,1,68,1,68,1,69,1,69,1,69,3,69,1209,8,69,1,69,1,69,1,70,1,70,1, + 70,5,70,1216,8,70,10,70,12,70,1219,9,70,1,70,3,70,1222,8,70,1,71, + 1,71,1,72,1,72,1,72,1,72,1,72,1,72,3,72,1232,8,72,3,72,1234,8,72, + 1,73,3,73,1237,8,73,1,73,1,73,1,73,1,73,1,73,1,73,3,73,1245,8,73, + 1,74,1,74,1,74,3,74,1250,8,74,1,75,1,75,1,76,1,76,1,77,1,77,1,78, + 1,78,3,78,1260,8,78,1,79,1,79,1,79,3,79,1265,8,79,1,80,1,80,1,80, + 1,80,1,81,1,81,1,81,1,81,1,82,1,82,3,82,1277,8,82,1,83,1,83,5,83, + 1281,8,83,10,83,12,83,1284,9,83,1,83,1,83,1,84,1,84,1,84,1,84,1, + 84,3,84,1293,8,84,1,85,1,85,5,85,1297,8,85,10,85,12,85,1300,9,85, + 1,85,1,85,1,86,1,86,1,86,1,86,1,86,3,86,1309,8,86,1,86,0,3,80,118, + 134,87,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,0,17,2,0,32,32,37,37,2,0, + 18,18,77,77,2,0,46,46,54,54,3,0,1,1,4,4,8,8,4,0,1,1,3,4,8,8,83,83, + 2,0,54,54,76,76,2,0,1,1,4,4,2,0,7,7,22,23,2,0,31,31,52,52,2,0,74, + 74,79,79,3,0,10,10,53,53,93,93,2,0,43,43,56,56,1,0,110,111,2,0,121, + 121,142,142,7,0,21,21,40,40,58,59,73,73,81,81,100,100,106,106,19, + 0,1,13,15,20,22,26,28,29,31,31,33,36,38,39,41,44,46,46,48,54,56, + 57,61,61,63,72,74,80,82,86,88,95,97,99,101,102,104,105,4,0,20,20, + 31,31,41,41,51,51,1484,0,177,1,0,0,0,2,184,1,0,0,0,4,186,1,0,0,0, + 6,188,1,0,0,0,8,195,1,0,0,0,10,218,1,0,0,0,12,220,1,0,0,0,14,227, + 1,0,0,0,16,234,1,0,0,0,18,247,1,0,0,0,20,259,1,0,0,0,22,268,1,0, + 0,0,24,276,1,0,0,0,26,298,1,0,0,0,28,313,1,0,0,0,30,322,1,0,0,0, + 32,327,1,0,0,0,34,331,1,0,0,0,36,333,1,0,0,0,38,342,1,0,0,0,40,346, + 1,0,0,0,42,360,1,0,0,0,44,370,1,0,0,0,46,376,1,0,0,0,48,380,1,0, + 0,0,50,388,1,0,0,0,52,437,1,0,0,0,54,440,1,0,0,0,56,446,1,0,0,0, + 58,450,1,0,0,0,60,456,1,0,0,0,62,474,1,0,0,0,64,477,1,0,0,0,66,480, + 1,0,0,0,68,490,1,0,0,0,70,493,1,0,0,0,72,497,1,0,0,0,74,530,1,0, + 0,0,76,532,1,0,0,0,78,535,1,0,0,0,80,550,1,0,0,0,82,612,1,0,0,0, + 84,617,1,0,0,0,86,628,1,0,0,0,88,630,1,0,0,0,90,636,1,0,0,0,92,644, + 1,0,0,0,94,662,1,0,0,0,96,664,1,0,0,0,98,672,1,0,0,0,100,677,1,0, + 0,0,102,685,1,0,0,0,104,689,1,0,0,0,106,693,1,0,0,0,108,702,1,0, + 0,0,110,716,1,0,0,0,112,718,1,0,0,0,114,777,1,0,0,0,116,779,1,0, + 0,0,118,940,1,0,0,0,120,1082,1,0,0,0,122,1121,1,0,0,0,124,1134,1, + 0,0,0,126,1136,1,0,0,0,128,1157,1,0,0,0,130,1166,1,0,0,0,132,1168, + 1,0,0,0,134,1185,1,0,0,0,136,1198,1,0,0,0,138,1208,1,0,0,0,140,1212, + 1,0,0,0,142,1223,1,0,0,0,144,1233,1,0,0,0,146,1236,1,0,0,0,148,1249, + 1,0,0,0,150,1251,1,0,0,0,152,1253,1,0,0,0,154,1255,1,0,0,0,156,1259, + 1,0,0,0,158,1264,1,0,0,0,160,1266,1,0,0,0,162,1270,1,0,0,0,164,1276, + 1,0,0,0,166,1278,1,0,0,0,168,1292,1,0,0,0,170,1294,1,0,0,0,172,1308, + 1,0,0,0,174,176,3,2,1,0,175,174,1,0,0,0,176,179,1,0,0,0,177,175, + 1,0,0,0,177,178,1,0,0,0,178,180,1,0,0,0,179,177,1,0,0,0,180,181, + 5,0,0,1,181,1,1,0,0,0,182,185,3,6,3,0,183,185,3,10,5,0,184,182,1, + 0,0,0,184,183,1,0,0,0,185,3,1,0,0,0,186,187,3,118,59,0,187,5,1,0, + 0,0,188,189,5,55,0,0,189,193,3,158,79,0,190,191,5,118,0,0,191,192, + 5,125,0,0,192,194,3,4,2,0,193,190,1,0,0,0,193,194,1,0,0,0,194,7, + 1,0,0,0,195,200,3,158,79,0,196,197,5,119,0,0,197,199,3,158,79,0, + 198,196,1,0,0,0,199,202,1,0,0,0,200,198,1,0,0,0,200,201,1,0,0,0, + 201,204,1,0,0,0,202,200,1,0,0,0,203,205,5,119,0,0,204,203,1,0,0, + 0,204,205,1,0,0,0,205,9,1,0,0,0,206,219,3,12,6,0,207,219,3,14,7, + 0,208,219,3,18,9,0,209,219,3,20,10,0,210,219,3,22,11,0,211,219,3, + 26,13,0,212,219,3,24,12,0,213,219,3,28,14,0,214,219,3,30,15,0,215, + 219,3,36,18,0,216,219,3,32,16,0,217,219,3,34,17,0,218,206,1,0,0, + 0,218,207,1,0,0,0,218,208,1,0,0,0,218,209,1,0,0,0,218,210,1,0,0, + 0,218,211,1,0,0,0,218,212,1,0,0,0,218,213,1,0,0,0,218,214,1,0,0, + 0,218,215,1,0,0,0,218,216,1,0,0,0,218,217,1,0,0,0,219,11,1,0,0,0, + 220,222,5,75,0,0,221,223,3,4,2,0,222,221,1,0,0,0,222,223,1,0,0,0, + 223,225,1,0,0,0,224,226,5,153,0,0,225,224,1,0,0,0,225,226,1,0,0, + 0,226,13,1,0,0,0,227,229,5,87,0,0,228,230,3,4,2,0,229,228,1,0,0, + 0,229,230,1,0,0,0,230,232,1,0,0,0,231,233,5,153,0,0,232,231,1,0, + 0,0,232,233,1,0,0,0,233,15,1,0,0,0,234,243,5,14,0,0,235,236,5,133, + 0,0,236,239,3,158,79,0,237,238,5,118,0,0,238,240,3,158,79,0,239, + 237,1,0,0,0,239,240,1,0,0,0,240,241,1,0,0,0,241,242,5,152,0,0,242, + 244,1,0,0,0,243,235,1,0,0,0,243,244,1,0,0,0,244,245,1,0,0,0,245, + 246,3,36,18,0,246,17,1,0,0,0,247,248,5,96,0,0,248,252,3,36,18,0, + 249,251,3,16,8,0,250,249,1,0,0,0,251,254,1,0,0,0,252,250,1,0,0,0, + 252,253,1,0,0,0,253,257,1,0,0,0,254,252,1,0,0,0,255,256,5,30,0,0, + 256,258,3,36,18,0,257,255,1,0,0,0,257,258,1,0,0,0,258,19,1,0,0,0, + 259,260,5,42,0,0,260,261,5,133,0,0,261,262,3,4,2,0,262,263,5,152, + 0,0,263,266,3,10,5,0,264,265,5,25,0,0,265,267,3,10,5,0,266,264,1, + 0,0,0,266,267,1,0,0,0,267,21,1,0,0,0,268,269,5,103,0,0,269,270,5, + 133,0,0,270,271,3,4,2,0,271,272,5,152,0,0,272,274,3,10,5,0,273,275, + 5,153,0,0,274,273,1,0,0,0,274,275,1,0,0,0,275,23,1,0,0,0,276,277, + 5,34,0,0,277,281,5,133,0,0,278,282,3,6,3,0,279,282,3,30,15,0,280, + 282,3,4,2,0,281,278,1,0,0,0,281,279,1,0,0,0,281,280,1,0,0,0,281, + 282,1,0,0,0,282,283,1,0,0,0,283,285,5,153,0,0,284,286,3,4,2,0,285, + 284,1,0,0,0,285,286,1,0,0,0,286,287,1,0,0,0,287,291,5,153,0,0,288, + 292,3,6,3,0,289,292,3,30,15,0,290,292,3,4,2,0,291,288,1,0,0,0,291, + 289,1,0,0,0,291,290,1,0,0,0,291,292,1,0,0,0,292,293,1,0,0,0,293, + 294,5,152,0,0,294,296,3,10,5,0,295,297,5,153,0,0,296,295,1,0,0,0, + 296,297,1,0,0,0,297,25,1,0,0,0,298,299,5,34,0,0,299,300,5,133,0, + 0,300,301,5,55,0,0,301,304,3,158,79,0,302,303,5,119,0,0,303,305, + 3,158,79,0,304,302,1,0,0,0,304,305,1,0,0,0,305,306,1,0,0,0,306,307, + 5,44,0,0,307,308,3,4,2,0,308,309,5,152,0,0,309,311,3,10,5,0,310, + 312,5,153,0,0,311,310,1,0,0,0,311,312,1,0,0,0,312,27,1,0,0,0,313, + 314,7,0,0,0,314,315,3,158,79,0,315,317,5,133,0,0,316,318,3,8,4,0, + 317,316,1,0,0,0,317,318,1,0,0,0,318,319,1,0,0,0,319,320,5,152,0, + 0,320,321,3,36,18,0,321,29,1,0,0,0,322,323,3,4,2,0,323,324,5,118, + 0,0,324,325,5,125,0,0,325,326,3,4,2,0,326,31,1,0,0,0,327,329,3,4, + 2,0,328,330,5,153,0,0,329,328,1,0,0,0,329,330,1,0,0,0,330,33,1,0, + 0,0,331,332,5,153,0,0,332,35,1,0,0,0,333,337,5,131,0,0,334,336,3, + 2,1,0,335,334,1,0,0,0,336,339,1,0,0,0,337,335,1,0,0,0,337,338,1, + 0,0,0,338,340,1,0,0,0,339,337,1,0,0,0,340,341,5,150,0,0,341,37,1, + 0,0,0,342,343,3,4,2,0,343,344,5,118,0,0,344,345,3,4,2,0,345,39,1, + 0,0,0,346,351,3,38,19,0,347,348,5,119,0,0,348,350,3,38,19,0,349, + 347,1,0,0,0,350,353,1,0,0,0,351,349,1,0,0,0,351,352,1,0,0,0,352, + 355,1,0,0,0,353,351,1,0,0,0,354,356,5,119,0,0,355,354,1,0,0,0,355, + 356,1,0,0,0,356,41,1,0,0,0,357,361,3,48,24,0,358,361,3,50,25,0,359, + 361,3,122,61,0,360,357,1,0,0,0,360,358,1,0,0,0,360,359,1,0,0,0,361, + 362,1,0,0,0,362,363,5,0,0,1,363,43,1,0,0,0,364,371,3,50,25,0,365, + 366,5,133,0,0,366,367,3,48,24,0,367,368,5,152,0,0,368,371,1,0,0, + 0,369,371,3,162,81,0,370,364,1,0,0,0,370,365,1,0,0,0,370,369,1,0, + 0,0,371,45,1,0,0,0,372,377,5,27,0,0,373,374,5,98,0,0,374,377,5,1, + 0,0,375,377,5,47,0,0,376,372,1,0,0,0,376,373,1,0,0,0,376,375,1,0, + 0,0,377,378,1,0,0,0,378,379,3,44,22,0,379,47,1,0,0,0,380,384,3,44, + 22,0,381,383,3,46,23,0,382,381,1,0,0,0,383,386,1,0,0,0,384,382,1, + 0,0,0,384,385,1,0,0,0,385,49,1,0,0,0,386,384,1,0,0,0,387,389,3,52, + 26,0,388,387,1,0,0,0,388,389,1,0,0,0,389,390,1,0,0,0,390,392,5,82, + 0,0,391,393,5,24,0,0,392,391,1,0,0,0,392,393,1,0,0,0,393,395,1,0, + 0,0,394,396,3,54,27,0,395,394,1,0,0,0,395,396,1,0,0,0,396,397,1, + 0,0,0,397,399,3,116,58,0,398,400,3,56,28,0,399,398,1,0,0,0,399,400, + 1,0,0,0,400,402,1,0,0,0,401,403,3,58,29,0,402,401,1,0,0,0,402,403, + 1,0,0,0,403,405,1,0,0,0,404,406,3,62,31,0,405,404,1,0,0,0,405,406, + 1,0,0,0,406,408,1,0,0,0,407,409,3,64,32,0,408,407,1,0,0,0,408,409, + 1,0,0,0,409,411,1,0,0,0,410,412,3,66,33,0,411,410,1,0,0,0,411,412, + 1,0,0,0,412,415,1,0,0,0,413,414,5,105,0,0,414,416,7,1,0,0,415,413, + 1,0,0,0,415,416,1,0,0,0,416,419,1,0,0,0,417,418,5,105,0,0,418,420, + 5,92,0,0,419,417,1,0,0,0,419,420,1,0,0,0,420,422,1,0,0,0,421,423, + 3,68,34,0,422,421,1,0,0,0,422,423,1,0,0,0,423,425,1,0,0,0,424,426, + 3,60,30,0,425,424,1,0,0,0,425,426,1,0,0,0,426,428,1,0,0,0,427,429, + 3,70,35,0,428,427,1,0,0,0,428,429,1,0,0,0,429,432,1,0,0,0,430,433, + 3,74,37,0,431,433,3,76,38,0,432,430,1,0,0,0,432,431,1,0,0,0,432, + 433,1,0,0,0,433,435,1,0,0,0,434,436,3,78,39,0,435,434,1,0,0,0,435, + 436,1,0,0,0,436,51,1,0,0,0,437,438,5,105,0,0,438,439,3,126,63,0, + 439,53,1,0,0,0,440,441,5,91,0,0,441,444,5,111,0,0,442,443,5,105, + 0,0,443,445,5,88,0,0,444,442,1,0,0,0,444,445,1,0,0,0,445,55,1,0, + 0,0,446,447,5,35,0,0,447,448,3,80,40,0,448,57,1,0,0,0,449,451,7, + 2,0,0,450,449,1,0,0,0,450,451,1,0,0,0,451,452,1,0,0,0,452,453,5, + 5,0,0,453,454,5,50,0,0,454,455,3,116,58,0,455,59,1,0,0,0,456,457, + 5,104,0,0,457,458,3,158,79,0,458,459,5,6,0,0,459,460,5,133,0,0,460, + 461,3,100,50,0,461,471,5,152,0,0,462,463,5,119,0,0,463,464,3,158, + 79,0,464,465,5,6,0,0,465,466,5,133,0,0,466,467,3,100,50,0,467,468, + 5,152,0,0,468,470,1,0,0,0,469,462,1,0,0,0,470,473,1,0,0,0,471,469, + 1,0,0,0,471,472,1,0,0,0,472,61,1,0,0,0,473,471,1,0,0,0,474,475,5, + 72,0,0,475,476,3,118,59,0,476,63,1,0,0,0,477,478,5,102,0,0,478,479, + 3,118,59,0,479,65,1,0,0,0,480,481,5,38,0,0,481,488,5,11,0,0,482, + 483,7,1,0,0,483,484,5,133,0,0,484,485,3,116,58,0,485,486,5,152,0, + 0,486,489,1,0,0,0,487,489,3,116,58,0,488,482,1,0,0,0,488,487,1,0, + 0,0,489,67,1,0,0,0,490,491,5,39,0,0,491,492,3,118,59,0,492,69,1, + 0,0,0,493,494,5,67,0,0,494,495,5,11,0,0,495,496,3,90,45,0,496,71, + 1,0,0,0,497,498,5,67,0,0,498,499,5,11,0,0,499,500,3,116,58,0,500, + 73,1,0,0,0,501,502,5,57,0,0,502,505,3,118,59,0,503,504,5,119,0,0, + 504,506,3,118,59,0,505,503,1,0,0,0,505,506,1,0,0,0,506,511,1,0,0, + 0,507,508,5,105,0,0,508,512,5,88,0,0,509,510,5,11,0,0,510,512,3, + 116,58,0,511,507,1,0,0,0,511,509,1,0,0,0,511,512,1,0,0,0,512,531, + 1,0,0,0,513,514,5,57,0,0,514,517,3,118,59,0,515,516,5,105,0,0,516, + 518,5,88,0,0,517,515,1,0,0,0,517,518,1,0,0,0,518,519,1,0,0,0,519, + 520,5,64,0,0,520,521,3,118,59,0,521,531,1,0,0,0,522,523,5,57,0,0, + 523,524,3,118,59,0,524,525,5,64,0,0,525,528,3,118,59,0,526,527,5, + 11,0,0,527,529,3,116,58,0,528,526,1,0,0,0,528,529,1,0,0,0,529,531, + 1,0,0,0,530,501,1,0,0,0,530,513,1,0,0,0,530,522,1,0,0,0,531,75,1, + 0,0,0,532,533,5,64,0,0,533,534,3,118,59,0,534,77,1,0,0,0,535,536, + 5,84,0,0,536,537,3,96,48,0,537,79,1,0,0,0,538,539,6,40,-1,0,539, + 541,3,134,67,0,540,542,5,29,0,0,541,540,1,0,0,0,541,542,1,0,0,0, + 542,544,1,0,0,0,543,545,3,88,44,0,544,543,1,0,0,0,544,545,1,0,0, + 0,545,551,1,0,0,0,546,547,5,133,0,0,547,548,3,80,40,0,548,549,5, + 152,0,0,549,551,1,0,0,0,550,538,1,0,0,0,550,546,1,0,0,0,551,566, + 1,0,0,0,552,553,10,3,0,0,553,554,3,84,42,0,554,555,3,80,40,4,555, + 565,1,0,0,0,556,558,10,4,0,0,557,559,3,82,41,0,558,557,1,0,0,0,558, + 559,1,0,0,0,559,560,1,0,0,0,560,561,5,50,0,0,561,562,3,80,40,0,562, + 563,3,86,43,0,563,565,1,0,0,0,564,552,1,0,0,0,564,556,1,0,0,0,565, + 568,1,0,0,0,566,564,1,0,0,0,566,567,1,0,0,0,567,81,1,0,0,0,568,566, + 1,0,0,0,569,571,7,3,0,0,570,569,1,0,0,0,570,571,1,0,0,0,571,572, + 1,0,0,0,572,579,5,46,0,0,573,575,5,46,0,0,574,576,7,3,0,0,575,574, + 1,0,0,0,575,576,1,0,0,0,576,579,1,0,0,0,577,579,7,3,0,0,578,570, + 1,0,0,0,578,573,1,0,0,0,578,577,1,0,0,0,579,613,1,0,0,0,580,582, + 7,4,0,0,581,580,1,0,0,0,581,582,1,0,0,0,582,583,1,0,0,0,583,585, + 7,5,0,0,584,586,5,68,0,0,585,584,1,0,0,0,585,586,1,0,0,0,586,595, + 1,0,0,0,587,589,7,5,0,0,588,590,5,68,0,0,589,588,1,0,0,0,589,590, + 1,0,0,0,590,592,1,0,0,0,591,593,7,4,0,0,592,591,1,0,0,0,592,593, + 1,0,0,0,593,595,1,0,0,0,594,581,1,0,0,0,594,587,1,0,0,0,595,613, + 1,0,0,0,596,598,7,6,0,0,597,596,1,0,0,0,597,598,1,0,0,0,598,599, + 1,0,0,0,599,601,5,36,0,0,600,602,5,68,0,0,601,600,1,0,0,0,601,602, + 1,0,0,0,602,611,1,0,0,0,603,605,5,36,0,0,604,606,5,68,0,0,605,604, + 1,0,0,0,605,606,1,0,0,0,606,608,1,0,0,0,607,609,7,6,0,0,608,607, + 1,0,0,0,608,609,1,0,0,0,609,611,1,0,0,0,610,597,1,0,0,0,610,603, + 1,0,0,0,611,613,1,0,0,0,612,578,1,0,0,0,612,594,1,0,0,0,612,610, + 1,0,0,0,613,83,1,0,0,0,614,615,5,17,0,0,615,618,5,50,0,0,616,618, + 5,119,0,0,617,614,1,0,0,0,617,616,1,0,0,0,618,85,1,0,0,0,619,620, + 5,65,0,0,620,629,3,116,58,0,621,622,5,99,0,0,622,623,5,133,0,0,623, + 624,3,116,58,0,624,625,5,152,0,0,625,629,1,0,0,0,626,627,5,99,0, + 0,627,629,3,116,58,0,628,619,1,0,0,0,628,621,1,0,0,0,628,626,1,0, + 0,0,629,87,1,0,0,0,630,631,5,80,0,0,631,634,3,94,47,0,632,633,5, + 64,0,0,633,635,3,94,47,0,634,632,1,0,0,0,634,635,1,0,0,0,635,89, + 1,0,0,0,636,641,3,92,46,0,637,638,5,119,0,0,638,640,3,92,46,0,639, + 637,1,0,0,0,640,643,1,0,0,0,641,639,1,0,0,0,641,642,1,0,0,0,642, + 91,1,0,0,0,643,641,1,0,0,0,644,646,3,118,59,0,645,647,7,7,0,0,646, + 645,1,0,0,0,646,647,1,0,0,0,647,650,1,0,0,0,648,649,5,63,0,0,649, + 651,7,8,0,0,650,648,1,0,0,0,650,651,1,0,0,0,651,654,1,0,0,0,652, + 653,5,16,0,0,653,655,5,113,0,0,654,652,1,0,0,0,654,655,1,0,0,0,655, + 93,1,0,0,0,656,663,3,162,81,0,657,660,3,146,73,0,658,659,5,154,0, + 0,659,661,3,146,73,0,660,658,1,0,0,0,660,661,1,0,0,0,661,663,1,0, + 0,0,662,656,1,0,0,0,662,657,1,0,0,0,663,95,1,0,0,0,664,669,3,98, + 49,0,665,666,5,119,0,0,666,668,3,98,49,0,667,665,1,0,0,0,668,671, + 1,0,0,0,669,667,1,0,0,0,669,670,1,0,0,0,670,97,1,0,0,0,671,669,1, + 0,0,0,672,673,3,158,79,0,673,674,5,125,0,0,674,675,3,148,74,0,675, + 99,1,0,0,0,676,678,3,102,51,0,677,676,1,0,0,0,677,678,1,0,0,0,678, + 680,1,0,0,0,679,681,3,104,52,0,680,679,1,0,0,0,680,681,1,0,0,0,681, + 683,1,0,0,0,682,684,3,106,53,0,683,682,1,0,0,0,683,684,1,0,0,0,684, + 101,1,0,0,0,685,686,5,70,0,0,686,687,5,11,0,0,687,688,3,116,58,0, + 688,103,1,0,0,0,689,690,5,67,0,0,690,691,5,11,0,0,691,692,3,90,45, + 0,692,105,1,0,0,0,693,694,7,9,0,0,694,695,3,108,54,0,695,107,1,0, + 0,0,696,703,3,110,55,0,697,698,5,9,0,0,698,699,3,110,55,0,699,700, + 5,2,0,0,700,701,3,110,55,0,701,703,1,0,0,0,702,696,1,0,0,0,702,697, + 1,0,0,0,703,109,1,0,0,0,704,705,5,19,0,0,705,717,5,78,0,0,706,707, + 5,97,0,0,707,717,5,71,0,0,708,709,5,97,0,0,709,717,5,33,0,0,710, + 711,3,146,73,0,711,712,5,71,0,0,712,717,1,0,0,0,713,714,3,146,73, + 0,714,715,5,33,0,0,715,717,1,0,0,0,716,704,1,0,0,0,716,706,1,0,0, + 0,716,708,1,0,0,0,716,710,1,0,0,0,716,713,1,0,0,0,717,111,1,0,0, + 0,718,719,3,118,59,0,719,720,5,0,0,1,720,113,1,0,0,0,721,778,3,158, + 79,0,722,723,3,158,79,0,723,724,5,133,0,0,724,725,3,158,79,0,725, + 732,3,114,57,0,726,727,5,119,0,0,727,728,3,158,79,0,728,729,3,114, + 57,0,729,731,1,0,0,0,730,726,1,0,0,0,731,734,1,0,0,0,732,730,1,0, + 0,0,732,733,1,0,0,0,733,736,1,0,0,0,734,732,1,0,0,0,735,737,5,119, + 0,0,736,735,1,0,0,0,736,737,1,0,0,0,737,738,1,0,0,0,738,739,5,152, + 0,0,739,778,1,0,0,0,740,741,3,158,79,0,741,742,5,133,0,0,742,747, + 3,160,80,0,743,744,5,119,0,0,744,746,3,160,80,0,745,743,1,0,0,0, + 746,749,1,0,0,0,747,745,1,0,0,0,747,748,1,0,0,0,748,751,1,0,0,0, + 749,747,1,0,0,0,750,752,5,119,0,0,751,750,1,0,0,0,751,752,1,0,0, + 0,752,753,1,0,0,0,753,754,5,152,0,0,754,778,1,0,0,0,755,756,3,158, + 79,0,756,757,5,133,0,0,757,762,3,114,57,0,758,759,5,119,0,0,759, + 761,3,114,57,0,760,758,1,0,0,0,761,764,1,0,0,0,762,760,1,0,0,0,762, + 763,1,0,0,0,763,766,1,0,0,0,764,762,1,0,0,0,765,767,5,119,0,0,766, + 765,1,0,0,0,766,767,1,0,0,0,767,768,1,0,0,0,768,769,5,152,0,0,769, + 778,1,0,0,0,770,771,3,158,79,0,771,773,5,133,0,0,772,774,3,116,58, + 0,773,772,1,0,0,0,773,774,1,0,0,0,774,775,1,0,0,0,775,776,5,152, + 0,0,776,778,1,0,0,0,777,721,1,0,0,0,777,722,1,0,0,0,777,740,1,0, + 0,0,777,755,1,0,0,0,777,770,1,0,0,0,778,115,1,0,0,0,779,784,3,118, + 59,0,780,781,5,119,0,0,781,783,3,118,59,0,782,780,1,0,0,0,783,786, + 1,0,0,0,784,782,1,0,0,0,784,785,1,0,0,0,785,788,1,0,0,0,786,784, + 1,0,0,0,787,789,5,119,0,0,788,787,1,0,0,0,788,789,1,0,0,0,789,117, + 1,0,0,0,790,791,6,59,-1,0,791,793,5,12,0,0,792,794,3,118,59,0,793, + 792,1,0,0,0,793,794,1,0,0,0,794,800,1,0,0,0,795,796,5,101,0,0,796, + 797,3,118,59,0,797,798,5,86,0,0,798,799,3,118,59,0,799,801,1,0,0, + 0,800,795,1,0,0,0,801,802,1,0,0,0,802,800,1,0,0,0,802,803,1,0,0, + 0,803,806,1,0,0,0,804,805,5,25,0,0,805,807,3,118,59,0,806,804,1, + 0,0,0,806,807,1,0,0,0,807,808,1,0,0,0,808,809,5,26,0,0,809,941,1, + 0,0,0,810,811,5,13,0,0,811,812,5,133,0,0,812,813,3,118,59,0,813, + 814,5,6,0,0,814,815,3,114,57,0,815,816,5,152,0,0,816,941,1,0,0,0, + 817,818,5,20,0,0,818,941,5,113,0,0,819,820,5,48,0,0,820,821,3,118, + 59,0,821,822,3,150,75,0,822,941,1,0,0,0,823,824,5,85,0,0,824,825, + 5,133,0,0,825,826,3,118,59,0,826,827,5,35,0,0,827,830,3,118,59,0, + 828,829,5,34,0,0,829,831,3,118,59,0,830,828,1,0,0,0,830,831,1,0, + 0,0,831,832,1,0,0,0,832,833,5,152,0,0,833,941,1,0,0,0,834,835,5, + 89,0,0,835,941,5,113,0,0,836,837,5,94,0,0,837,838,5,133,0,0,838, + 839,7,10,0,0,839,840,3,164,82,0,840,841,5,35,0,0,841,842,3,118,59, + 0,842,843,5,152,0,0,843,941,1,0,0,0,844,845,3,158,79,0,845,847,5, + 133,0,0,846,848,3,116,58,0,847,846,1,0,0,0,847,848,1,0,0,0,848,849, + 1,0,0,0,849,850,5,152,0,0,850,859,1,0,0,0,851,853,5,133,0,0,852, + 854,5,24,0,0,853,852,1,0,0,0,853,854,1,0,0,0,854,856,1,0,0,0,855, + 857,3,116,58,0,856,855,1,0,0,0,856,857,1,0,0,0,857,858,1,0,0,0,858, + 860,5,152,0,0,859,851,1,0,0,0,859,860,1,0,0,0,860,861,1,0,0,0,861, + 862,5,69,0,0,862,863,5,133,0,0,863,864,3,100,50,0,864,865,5,152, + 0,0,865,941,1,0,0,0,866,867,3,158,79,0,867,869,5,133,0,0,868,870, + 3,116,58,0,869,868,1,0,0,0,869,870,1,0,0,0,870,871,1,0,0,0,871,872, + 5,152,0,0,872,881,1,0,0,0,873,875,5,133,0,0,874,876,5,24,0,0,875, + 874,1,0,0,0,875,876,1,0,0,0,876,878,1,0,0,0,877,879,3,116,58,0,878, + 877,1,0,0,0,878,879,1,0,0,0,879,880,1,0,0,0,880,882,5,152,0,0,881, + 873,1,0,0,0,881,882,1,0,0,0,882,883,1,0,0,0,883,884,5,69,0,0,884, + 885,3,158,79,0,885,941,1,0,0,0,886,892,3,158,79,0,887,889,5,133, + 0,0,888,890,3,116,58,0,889,888,1,0,0,0,889,890,1,0,0,0,890,891,1, + 0,0,0,891,893,5,152,0,0,892,887,1,0,0,0,892,893,1,0,0,0,893,894, + 1,0,0,0,894,896,5,133,0,0,895,897,5,24,0,0,896,895,1,0,0,0,896,897, + 1,0,0,0,897,899,1,0,0,0,898,900,3,116,58,0,899,898,1,0,0,0,899,900, + 1,0,0,0,900,901,1,0,0,0,901,902,5,152,0,0,902,941,1,0,0,0,903,941, + 3,122,61,0,904,941,3,166,83,0,905,941,3,148,74,0,906,907,5,121,0, + 0,907,941,3,118,59,20,908,909,5,61,0,0,909,941,3,118,59,14,910,911, + 3,138,69,0,911,912,5,123,0,0,912,914,1,0,0,0,913,910,1,0,0,0,913, + 914,1,0,0,0,914,915,1,0,0,0,915,941,5,115,0,0,916,917,5,133,0,0, + 917,918,3,48,24,0,918,919,5,152,0,0,919,941,1,0,0,0,920,921,5,133, + 0,0,921,922,3,118,59,0,922,923,5,152,0,0,923,941,1,0,0,0,924,925, + 5,133,0,0,925,926,3,116,58,0,926,927,5,152,0,0,927,941,1,0,0,0,928, + 930,5,132,0,0,929,931,3,116,58,0,930,929,1,0,0,0,930,931,1,0,0,0, + 931,932,1,0,0,0,932,941,5,151,0,0,933,935,5,131,0,0,934,936,3,40, + 20,0,935,934,1,0,0,0,935,936,1,0,0,0,936,937,1,0,0,0,937,941,5,150, + 0,0,938,941,3,120,60,0,939,941,3,130,65,0,940,790,1,0,0,0,940,810, + 1,0,0,0,940,817,1,0,0,0,940,819,1,0,0,0,940,823,1,0,0,0,940,834, + 1,0,0,0,940,836,1,0,0,0,940,844,1,0,0,0,940,866,1,0,0,0,940,886, + 1,0,0,0,940,903,1,0,0,0,940,904,1,0,0,0,940,905,1,0,0,0,940,906, + 1,0,0,0,940,908,1,0,0,0,940,913,1,0,0,0,940,916,1,0,0,0,940,920, + 1,0,0,0,940,924,1,0,0,0,940,928,1,0,0,0,940,933,1,0,0,0,940,938, + 1,0,0,0,940,939,1,0,0,0,941,1052,1,0,0,0,942,946,10,19,0,0,943,947, + 5,115,0,0,944,947,5,154,0,0,945,947,5,141,0,0,946,943,1,0,0,0,946, + 944,1,0,0,0,946,945,1,0,0,0,947,948,1,0,0,0,948,1051,3,118,59,20, + 949,953,10,18,0,0,950,954,5,142,0,0,951,954,5,121,0,0,952,954,5, + 120,0,0,953,950,1,0,0,0,953,951,1,0,0,0,953,952,1,0,0,0,954,955, + 1,0,0,0,955,1051,3,118,59,19,956,981,10,17,0,0,957,982,5,124,0,0, + 958,982,5,125,0,0,959,982,5,136,0,0,960,982,5,134,0,0,961,982,5, + 135,0,0,962,982,5,126,0,0,963,982,5,127,0,0,964,966,5,61,0,0,965, + 964,1,0,0,0,965,966,1,0,0,0,966,967,1,0,0,0,967,969,5,44,0,0,968, + 970,5,15,0,0,969,968,1,0,0,0,969,970,1,0,0,0,970,982,1,0,0,0,971, + 973,5,61,0,0,972,971,1,0,0,0,972,973,1,0,0,0,973,974,1,0,0,0,974, + 982,7,11,0,0,975,982,5,148,0,0,976,982,5,149,0,0,977,982,5,138,0, + 0,978,982,5,129,0,0,979,982,5,130,0,0,980,982,5,137,0,0,981,957, + 1,0,0,0,981,958,1,0,0,0,981,959,1,0,0,0,981,960,1,0,0,0,981,961, + 1,0,0,0,981,962,1,0,0,0,981,963,1,0,0,0,981,965,1,0,0,0,981,972, + 1,0,0,0,981,975,1,0,0,0,981,976,1,0,0,0,981,977,1,0,0,0,981,978, + 1,0,0,0,981,979,1,0,0,0,981,980,1,0,0,0,982,983,1,0,0,0,983,1051, + 3,118,59,18,984,985,10,15,0,0,985,986,5,140,0,0,986,1051,3,118,59, + 16,987,988,10,13,0,0,988,989,5,2,0,0,989,1051,3,118,59,14,990,991, + 10,12,0,0,991,992,5,66,0,0,992,1051,3,118,59,13,993,995,10,11,0, + 0,994,996,5,61,0,0,995,994,1,0,0,0,995,996,1,0,0,0,996,997,1,0,0, + 0,997,998,5,9,0,0,998,999,3,118,59,0,999,1000,5,2,0,0,1000,1001, + 3,118,59,12,1001,1051,1,0,0,0,1002,1003,10,10,0,0,1003,1004,5,143, + 0,0,1004,1005,3,118,59,0,1005,1006,5,118,0,0,1006,1007,3,118,59, + 10,1007,1051,1,0,0,0,1008,1009,10,30,0,0,1009,1011,5,133,0,0,1010, + 1012,3,116,58,0,1011,1010,1,0,0,0,1011,1012,1,0,0,0,1012,1013,1, + 0,0,0,1013,1051,5,152,0,0,1014,1015,10,26,0,0,1015,1016,5,132,0, + 0,1016,1017,3,118,59,0,1017,1018,5,151,0,0,1018,1051,1,0,0,0,1019, + 1020,10,25,0,0,1020,1021,5,123,0,0,1021,1051,5,111,0,0,1022,1023, + 10,24,0,0,1023,1024,5,123,0,0,1024,1051,3,158,79,0,1025,1026,10, + 23,0,0,1026,1027,5,139,0,0,1027,1028,5,132,0,0,1028,1029,3,118,59, + 0,1029,1030,5,151,0,0,1030,1051,1,0,0,0,1031,1032,10,22,0,0,1032, + 1033,5,139,0,0,1033,1051,5,111,0,0,1034,1035,10,21,0,0,1035,1036, + 5,139,0,0,1036,1051,3,158,79,0,1037,1038,10,16,0,0,1038,1040,5,49, + 0,0,1039,1041,5,61,0,0,1040,1039,1,0,0,0,1040,1041,1,0,0,0,1041, + 1042,1,0,0,0,1042,1051,5,62,0,0,1043,1048,10,9,0,0,1044,1045,5,6, + 0,0,1045,1049,3,158,79,0,1046,1047,5,6,0,0,1047,1049,5,113,0,0,1048, + 1044,1,0,0,0,1048,1046,1,0,0,0,1049,1051,1,0,0,0,1050,942,1,0,0, + 0,1050,949,1,0,0,0,1050,956,1,0,0,0,1050,984,1,0,0,0,1050,987,1, + 0,0,0,1050,990,1,0,0,0,1050,993,1,0,0,0,1050,1002,1,0,0,0,1050,1008, + 1,0,0,0,1050,1014,1,0,0,0,1050,1019,1,0,0,0,1050,1022,1,0,0,0,1050, + 1025,1,0,0,0,1050,1031,1,0,0,0,1050,1034,1,0,0,0,1050,1037,1,0,0, + 0,1050,1043,1,0,0,0,1051,1054,1,0,0,0,1052,1050,1,0,0,0,1052,1053, + 1,0,0,0,1053,119,1,0,0,0,1054,1052,1,0,0,0,1055,1056,5,133,0,0,1056, + 1061,3,158,79,0,1057,1058,5,119,0,0,1058,1060,3,158,79,0,1059,1057, + 1,0,0,0,1060,1063,1,0,0,0,1061,1059,1,0,0,0,1061,1062,1,0,0,0,1062, + 1065,1,0,0,0,1063,1061,1,0,0,0,1064,1066,5,119,0,0,1065,1064,1,0, + 0,0,1065,1066,1,0,0,0,1066,1067,1,0,0,0,1067,1068,5,152,0,0,1068, + 1083,1,0,0,0,1069,1074,3,158,79,0,1070,1071,5,119,0,0,1071,1073, + 3,158,79,0,1072,1070,1,0,0,0,1073,1076,1,0,0,0,1074,1072,1,0,0,0, + 1074,1075,1,0,0,0,1075,1078,1,0,0,0,1076,1074,1,0,0,0,1077,1079, + 5,119,0,0,1078,1077,1,0,0,0,1078,1079,1,0,0,0,1079,1083,1,0,0,0, + 1080,1081,5,133,0,0,1081,1083,5,152,0,0,1082,1055,1,0,0,0,1082,1069, + 1,0,0,0,1082,1080,1,0,0,0,1083,1084,1,0,0,0,1084,1087,5,114,0,0, + 1085,1088,3,118,59,0,1086,1088,3,36,18,0,1087,1085,1,0,0,0,1087, + 1086,1,0,0,0,1088,121,1,0,0,0,1089,1090,5,135,0,0,1090,1094,3,158, + 79,0,1091,1093,3,124,62,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,154,0,0,1098,1099,5,127,0,0,1099,1122,1,0,0,0,1100, + 1101,5,135,0,0,1101,1105,3,158,79,0,1102,1104,3,124,62,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,127,0,0,1109,1115,3,122, + 61,0,1110,1111,5,131,0,0,1111,1112,3,118,59,0,1112,1113,5,150,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,135,0,0,1117,1118,5,154,0, + 0,1118,1119,3,158,79,0,1119,1120,5,127,0,0,1120,1122,1,0,0,0,1121, + 1089,1,0,0,0,1121,1100,1,0,0,0,1122,123,1,0,0,0,1123,1124,3,158, + 79,0,1124,1125,5,125,0,0,1125,1126,3,164,82,0,1126,1135,1,0,0,0, + 1127,1128,3,158,79,0,1128,1129,5,125,0,0,1129,1130,5,131,0,0,1130, + 1131,3,118,59,0,1131,1132,5,150,0,0,1132,1135,1,0,0,0,1133,1135, + 3,158,79,0,1134,1123,1,0,0,0,1134,1127,1,0,0,0,1134,1133,1,0,0,0, + 1135,125,1,0,0,0,1136,1141,3,128,64,0,1137,1138,5,119,0,0,1138,1140, + 3,128,64,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,119,0,0,1145,1144,1,0,0,0,1145,1146,1,0,0,0,1146,127,1,0,0,0,1147, + 1148,3,158,79,0,1148,1149,5,6,0,0,1149,1150,5,133,0,0,1150,1151, + 3,48,24,0,1151,1152,5,152,0,0,1152,1158,1,0,0,0,1153,1154,3,118, + 59,0,1154,1155,5,6,0,0,1155,1156,3,158,79,0,1156,1158,1,0,0,0,1157, + 1147,1,0,0,0,1157,1153,1,0,0,0,1158,129,1,0,0,0,1159,1167,3,162, + 81,0,1160,1161,3,138,69,0,1161,1162,5,123,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,132,66,0,1166,1159,1,0,0,0,1166,1163,1,0,0,0,1167,131,1,0,0,0, + 1168,1173,3,158,79,0,1169,1170,5,123,0,0,1170,1172,3,158,79,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,133,1,0,0,0,1175,1173,1,0,0,0,1176,1177,6,67,-1,0,1177,1186, + 3,138,69,0,1178,1186,3,136,68,0,1179,1180,5,133,0,0,1180,1181,3, + 48,24,0,1181,1182,5,152,0,0,1182,1186,1,0,0,0,1183,1186,3,122,61, + 0,1184,1186,3,162,81,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,156,78,0,1189,1190,5,6,0,0,1190, + 1192,3,158,79,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,135,1,0,0,0,1197,1195,1,0,0,0,1198,1199,3,158, + 79,0,1199,1201,5,133,0,0,1200,1202,3,140,70,0,1201,1200,1,0,0,0, + 1201,1202,1,0,0,0,1202,1203,1,0,0,0,1203,1204,5,152,0,0,1204,137, + 1,0,0,0,1205,1206,3,142,71,0,1206,1207,5,123,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,158,79,0,1211,139,1,0,0,0,1212,1217,3,118,59,0,1213,1214,5,119, + 0,0,1214,1216,3,118,59,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,119,0,0,1221,1220,1,0,0,0,1221,1222,1,0,0,0,1222,141, + 1,0,0,0,1223,1224,3,158,79,0,1224,143,1,0,0,0,1225,1234,5,109,0, + 0,1226,1227,5,123,0,0,1227,1234,7,12,0,0,1228,1229,5,111,0,0,1229, + 1231,5,123,0,0,1230,1232,7,12,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,145,1,0,0,0,1235,1237,7,13,0,0,1236,1235,1,0,0, + 0,1236,1237,1,0,0,0,1237,1244,1,0,0,0,1238,1245,3,144,72,0,1239, + 1245,5,110,0,0,1240,1245,5,111,0,0,1241,1245,5,112,0,0,1242,1245, + 5,45,0,0,1243,1245,5,60,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,147,1,0,0,0,1246,1250,3,146,73,0,1247,1250,5,113,0, + 0,1248,1250,5,62,0,0,1249,1246,1,0,0,0,1249,1247,1,0,0,0,1249,1248, + 1,0,0,0,1250,149,1,0,0,0,1251,1252,7,14,0,0,1252,151,1,0,0,0,1253, + 1254,7,15,0,0,1254,153,1,0,0,0,1255,1256,7,16,0,0,1256,155,1,0,0, + 0,1257,1260,5,108,0,0,1258,1260,3,154,77,0,1259,1257,1,0,0,0,1259, + 1258,1,0,0,0,1260,157,1,0,0,0,1261,1265,5,108,0,0,1262,1265,3,150, + 75,0,1263,1265,3,152,76,0,1264,1261,1,0,0,0,1264,1262,1,0,0,0,1264, + 1263,1,0,0,0,1265,159,1,0,0,0,1266,1267,3,164,82,0,1267,1268,5,125, + 0,0,1268,1269,3,146,73,0,1269,161,1,0,0,0,1270,1271,5,131,0,0,1271, + 1272,3,118,59,0,1272,1273,5,150,0,0,1273,163,1,0,0,0,1274,1277,5, + 113,0,0,1275,1277,3,166,83,0,1276,1274,1,0,0,0,1276,1275,1,0,0,0, + 1277,165,1,0,0,0,1278,1282,5,145,0,0,1279,1281,3,168,84,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,147,0,0,1286,167,1,0, + 0,0,1287,1288,5,160,0,0,1288,1289,3,118,59,0,1289,1290,5,150,0,0, + 1290,1293,1,0,0,0,1291,1293,5,159,0,0,1292,1287,1,0,0,0,1292,1291, + 1,0,0,0,1293,169,1,0,0,0,1294,1298,5,146,0,0,1295,1297,3,172,86, + 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, + 171,1,0,0,0,1303,1304,5,162,0,0,1304,1305,3,118,59,0,1305,1306,5, + 150,0,0,1306,1309,1,0,0,0,1307,1309,5,161,0,0,1308,1303,1,0,0,0, + 1308,1307,1,0,0,0,1309,173,1,0,0,0,168,177,184,193,200,204,218,222, + 225,229,232,239,243,252,257,266,274,281,285,291,296,304,311,317, + 329,337,351,355,360,370,376,384,388,392,395,399,402,405,408,411, + 415,419,422,425,428,432,435,444,450,471,488,505,511,517,528,530, + 541,544,550,558,564,566,570,575,578,581,585,589,592,594,597,601, + 605,608,610,612,617,628,634,641,646,650,654,660,662,669,677,680, + 683,702,716,732,736,747,751,762,766,773,777,784,788,793,802,806, + 830,847,853,856,859,869,875,878,881,889,892,896,899,913,930,935, + 940,946,953,965,969,972,981,995,1011,1040,1048,1050,1052,1061,1065, + 1074,1078,1082,1087,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 ] class HogQLParser ( Parser ): @@ -576,44 +579,46 @@ class HogQLParser ( Parser ): "", "", "", "", "", "", "", "", "", "", "", "", - "'->'", "'*'", "'`'", "'\\'", "':'", "','", "'||'", - "'-'", "'$'", "'.'", "'=='", "'='", "'>='", "'>'", - "'#'", "'~*'", "'=~*'", "'{'", "'['", "'('", "'<='", - "'<'", "", "'!~*'", "'!~'", "'?.'", "'??'", - "'%'", "'+'", "'?'", "'\"'", "'f''", "'F''", "'''", - "'~'", "'=~'", "'}'", "']'", "')'", "';'", "'/'", "'_'" ] + "", "", "'->'", "'*'", "'`'", "'\\'", + "':'", "','", "'||'", "'-'", "'$'", "'.'", "'=='", + "'='", "'>='", "'>'", "'#'", "'~*'", "'=~*'", "'{'", + "'['", "'('", "'<='", "'<'", "", "'!~*'", + "'!~'", "'?.'", "'??'", "'%'", "'+'", "'?'", "'\"'", + "'f''", "'F''", "'''", "'~'", "'=~'", "'}'", "']'", + "')'", "';'", "'/'", "'_'" ] symbolicNames = [ "", "ALL", "AND", "ANTI", "ANY", "ARRAY", "AS", "ASCENDING", "ASOF", "BETWEEN", "BOTH", "BY", "CASE", "CAST", "CATCH", "COHORT", "COLLATE", "CROSS", "CUBE", "CURRENT", "DATE", "DAY", "DESC", "DESCENDING", - "DISTINCT", "ELSE", "END", "EXTRACT", "FINAL", "FINALLY", - "FIRST", "FN", "FOLLOWING", "FOR", "FROM", "FULL", - "FUN", "GROUP", "HAVING", "HOUR", "ID", "IF", "ILIKE", - "IN", "INF", "INNER", "INTERVAL", "IS", "JOIN", "KEY", - "LAST", "LEADING", "LEFT", "LET", "LIKE", "LIMIT", - "MINUTE", "MONTH", "NAN_SQL", "NOT", "NULL_SQL", "NULLS", - "OFFSET", "ON", "OR", "ORDER", "OUTER", "OVER", "PARTITION", - "PRECEDING", "PREWHERE", "QUARTER", "RANGE", "RETURN", - "RIGHT", "ROLLUP", "ROW", "ROWS", "SAMPLE", "SECOND", - "SELECT", "SEMI", "SETTINGS", "SUBSTRING", "THEN", - "THROW", "TIES", "TIMESTAMP", "TO", "TOP", "TOTALS", - "TRAILING", "TRIM", "TRUNCATE", "TRY", "UNBOUNDED", - "UNION", "USING", "WEEK", "WHEN", "WHERE", "WHILE", - "WINDOW", "WITH", "YEAR", "ESCAPE_CHAR_COMMON", "IDENTIFIER", - "FLOATING_LITERAL", "OCTAL_LITERAL", "DECIMAL_LITERAL", - "HEXADECIMAL_LITERAL", "STRING_LITERAL", "ARROW", - "ASTERISK", "BACKQUOTE", "BACKSLASH", "COLON", "COMMA", - "CONCAT", "DASH", "DOLLAR", "DOT", "EQ_DOUBLE", "EQ_SINGLE", - "GT_EQ", "GT", "HASH", "IREGEX_SINGLE", "IREGEX_DOUBLE", - "LBRACE", "LBRACKET", "LPAREN", "LT_EQ", "LT", "NOT_EQ", - "NOT_IREGEX", "NOT_REGEX", "NULL_PROPERTY", "NULLISH", - "PERCENT", "PLUS", "QUERY", "QUOTE_DOUBLE", "QUOTE_SINGLE_TEMPLATE", - "QUOTE_SINGLE_TEMPLATE_FULL", "QUOTE_SINGLE", "REGEX_SINGLE", - "REGEX_DOUBLE", "RBRACE", "RBRACKET", "RPAREN", "SEMICOLON", - "SLASH", "UNDERSCORE", "MULTI_LINE_COMMENT", "SINGLE_LINE_COMMENT", - "WHITESPACE", "STRING_TEXT", "STRING_ESCAPE_TRIGGER", - "FULL_STRING_TEXT", "FULL_STRING_ESCAPE_TRIGGER" ] + "DISTINCT", "ELSE", "END", "EXCEPT", "EXTRACT", "FINAL", + "FINALLY", "FIRST", "FN", "FOLLOWING", "FOR", "FROM", + "FULL", "FUN", "GROUP", "HAVING", "HOUR", "ID", "IF", + "ILIKE", "IN", "INF", "INNER", "INTERSECT", "INTERVAL", + "IS", "JOIN", "KEY", "LAST", "LEADING", "LEFT", "LET", + "LIKE", "LIMIT", "MINUTE", "MONTH", "NAN_SQL", "NOT", + "NULL_SQL", "NULLS", "OFFSET", "ON", "OR", "ORDER", + "OUTER", "OVER", "PARTITION", "PRECEDING", "PREWHERE", + "QUARTER", "RANGE", "RETURN", "RIGHT", "ROLLUP", "ROW", + "ROWS", "SAMPLE", "SECOND", "SELECT", "SEMI", "SETTINGS", + "SUBSTRING", "THEN", "THROW", "TIES", "TIMESTAMP", + "TO", "TOP", "TOTALS", "TRAILING", "TRIM", "TRUNCATE", + "TRY", "UNBOUNDED", "UNION", "USING", "WEEK", "WHEN", + "WHERE", "WHILE", "WINDOW", "WITH", "YEAR", "ESCAPE_CHAR_COMMON", + "IDENTIFIER", "FLOATING_LITERAL", "OCTAL_LITERAL", + "DECIMAL_LITERAL", "HEXADECIMAL_LITERAL", "STRING_LITERAL", + "ARROW", "ASTERISK", "BACKQUOTE", "BACKSLASH", "COLON", + "COMMA", "CONCAT", "DASH", "DOLLAR", "DOT", "EQ_DOUBLE", + "EQ_SINGLE", "GT_EQ", "GT", "HASH", "IREGEX_SINGLE", + "IREGEX_DOUBLE", "LBRACE", "LBRACKET", "LPAREN", "LT_EQ", + "LT", "NOT_EQ", "NOT_IREGEX", "NOT_REGEX", "NULL_PROPERTY", + "NULLISH", "PERCENT", "PLUS", "QUERY", "QUOTE_DOUBLE", + "QUOTE_SINGLE_TEMPLATE", "QUOTE_SINGLE_TEMPLATE_FULL", + "QUOTE_SINGLE", "REGEX_SINGLE", "REGEX_DOUBLE", "RBRACE", + "RBRACKET", "RPAREN", "SEMICOLON", "SLASH", "UNDERSCORE", + "MULTI_LINE_COMMENT", "SINGLE_LINE_COMMENT", "WHITESPACE", + "STRING_TEXT", "STRING_ESCAPE_TRIGGER", "FULL_STRING_TEXT", + "FULL_STRING_ESCAPE_TRIGGER" ] RULE_program = 0 RULE_declaration = 1 @@ -637,94 +642,95 @@ class HogQLParser ( Parser ): RULE_kvPair = 19 RULE_kvPairList = 20 RULE_select = 21 - RULE_selectUnionStmt = 22 - RULE_selectStmtWithParens = 23 - RULE_selectStmt = 24 - RULE_withClause = 25 - RULE_topClause = 26 - RULE_fromClause = 27 - RULE_arrayJoinClause = 28 - RULE_windowClause = 29 - RULE_prewhereClause = 30 - RULE_whereClause = 31 - RULE_groupByClause = 32 - RULE_havingClause = 33 - RULE_orderByClause = 34 - RULE_projectionOrderByClause = 35 - RULE_limitAndOffsetClause = 36 - RULE_offsetOnlyClause = 37 - RULE_settingsClause = 38 - RULE_joinExpr = 39 - RULE_joinOp = 40 - RULE_joinOpCross = 41 - RULE_joinConstraintClause = 42 - RULE_sampleClause = 43 - RULE_orderExprList = 44 - RULE_orderExpr = 45 - RULE_ratioExpr = 46 - RULE_settingExprList = 47 - RULE_settingExpr = 48 - RULE_windowExpr = 49 - RULE_winPartitionByClause = 50 - RULE_winOrderByClause = 51 - RULE_winFrameClause = 52 - RULE_winFrameExtend = 53 - RULE_winFrameBound = 54 - RULE_expr = 55 - RULE_columnTypeExpr = 56 - RULE_columnExprList = 57 - RULE_columnExpr = 58 - 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 + RULE_selectStmtWithParens = 22 + RULE_subsequentSelectSetClause = 23 + RULE_selectSetStmt = 24 + RULE_selectStmt = 25 + RULE_withClause = 26 + RULE_topClause = 27 + RULE_fromClause = 28 + RULE_arrayJoinClause = 29 + RULE_windowClause = 30 + RULE_prewhereClause = 31 + RULE_whereClause = 32 + RULE_groupByClause = 33 + RULE_havingClause = 34 + RULE_orderByClause = 35 + RULE_projectionOrderByClause = 36 + RULE_limitAndOffsetClause = 37 + RULE_offsetOnlyClause = 38 + RULE_settingsClause = 39 + RULE_joinExpr = 40 + RULE_joinOp = 41 + RULE_joinOpCross = 42 + RULE_joinConstraintClause = 43 + RULE_sampleClause = 44 + RULE_orderExprList = 45 + RULE_orderExpr = 46 + RULE_ratioExpr = 47 + RULE_settingExprList = 48 + RULE_settingExpr = 49 + RULE_windowExpr = 50 + RULE_winPartitionByClause = 51 + RULE_winOrderByClause = 52 + RULE_winFrameClause = 53 + RULE_winFrameExtend = 54 + RULE_winFrameBound = 55 + RULE_expr = 56 + RULE_columnTypeExpr = 57 + RULE_columnExprList = 58 + RULE_columnExpr = 59 + RULE_columnLambdaExpr = 60 + RULE_hogqlxTagElement = 61 + RULE_hogqlxTagAttribute = 62 + RULE_withExprList = 63 + RULE_withExpr = 64 + RULE_columnIdentifier = 65 + RULE_nestedIdentifier = 66 + RULE_tableExpr = 67 + RULE_tableFunctionExpr = 68 + RULE_tableIdentifier = 69 + RULE_tableArgList = 70 + RULE_databaseIdentifier = 71 + RULE_floatingLiteral = 72 + RULE_numberLiteral = 73 + RULE_literal = 74 + RULE_interval = 75 + RULE_keyword = 76 + RULE_keywordForAlias = 77 + RULE_alias = 78 + RULE_identifier = 79 + RULE_enumValue = 80 + RULE_placeholder = 81 + RULE_string = 82 + RULE_templateString = 83 + RULE_stringContents = 84 + RULE_fullTemplateString = 85 + RULE_stringContentsFull = 86 ruleNames = [ "program", "declaration", "expression", "varDecl", "identifierList", "statement", "returnStmt", "throwStmt", "catchBlock", "tryCatchStmt", "ifStmt", "whileStmt", "forStmt", "forInStmt", "funcStmt", "varAssignment", "exprStmt", "emptyStmt", - "block", "kvPair", "kvPairList", "select", "selectUnionStmt", - "selectStmtWithParens", "selectStmt", "withClause", "topClause", - "fromClause", "arrayJoinClause", "windowClause", "prewhereClause", - "whereClause", "groupByClause", "havingClause", "orderByClause", - "projectionOrderByClause", "limitAndOffsetClause", "offsetOnlyClause", - "settingsClause", "joinExpr", "joinOp", "joinOpCross", - "joinConstraintClause", "sampleClause", "orderExprList", - "orderExpr", "ratioExpr", "settingExprList", "settingExpr", - "windowExpr", "winPartitionByClause", "winOrderByClause", - "winFrameClause", "winFrameExtend", "winFrameBound", - "expr", "columnTypeExpr", "columnExprList", "columnExpr", - "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" ] + "block", "kvPair", "kvPairList", "select", "selectStmtWithParens", + "subsequentSelectSetClause", "selectSetStmt", "selectStmt", + "withClause", "topClause", "fromClause", "arrayJoinClause", + "windowClause", "prewhereClause", "whereClause", "groupByClause", + "havingClause", "orderByClause", "projectionOrderByClause", + "limitAndOffsetClause", "offsetOnlyClause", "settingsClause", + "joinExpr", "joinOp", "joinOpCross", "joinConstraintClause", + "sampleClause", "orderExprList", "orderExpr", "ratioExpr", + "settingExprList", "settingExpr", "windowExpr", "winPartitionByClause", + "winOrderByClause", "winFrameClause", "winFrameExtend", + "winFrameBound", "expr", "columnTypeExpr", "columnExprList", + "columnExpr", "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" ] EOF = Token.EOF ALL=1 @@ -753,140 +759,142 @@ class HogQLParser ( Parser ): DISTINCT=24 ELSE=25 END=26 - EXTRACT=27 - FINAL=28 - FINALLY=29 - FIRST=30 - FN=31 - FOLLOWING=32 - FOR=33 - FROM=34 - FULL=35 - FUN=36 - GROUP=37 - HAVING=38 - HOUR=39 - ID=40 - IF=41 - ILIKE=42 - IN=43 - INF=44 - INNER=45 - INTERVAL=46 - IS=47 - JOIN=48 - KEY=49 - LAST=50 - LEADING=51 - LEFT=52 - LET=53 - LIKE=54 - LIMIT=55 - MINUTE=56 - MONTH=57 - NAN_SQL=58 - NOT=59 - NULL_SQL=60 - NULLS=61 - OFFSET=62 - ON=63 - OR=64 - ORDER=65 - OUTER=66 - OVER=67 - PARTITION=68 - PRECEDING=69 - PREWHERE=70 - QUARTER=71 - RANGE=72 - RETURN=73 - RIGHT=74 - ROLLUP=75 - ROW=76 - ROWS=77 - SAMPLE=78 - SECOND=79 - SELECT=80 - SEMI=81 - SETTINGS=82 - SUBSTRING=83 - THEN=84 - THROW=85 - TIES=86 - TIMESTAMP=87 - TO=88 - TOP=89 - TOTALS=90 - TRAILING=91 - TRIM=92 - TRUNCATE=93 - TRY=94 - UNBOUNDED=95 - UNION=96 - USING=97 - WEEK=98 - WHEN=99 - WHERE=100 - WHILE=101 - WINDOW=102 - WITH=103 - YEAR=104 - ESCAPE_CHAR_COMMON=105 - IDENTIFIER=106 - FLOATING_LITERAL=107 - OCTAL_LITERAL=108 - DECIMAL_LITERAL=109 - HEXADECIMAL_LITERAL=110 - STRING_LITERAL=111 - ARROW=112 - ASTERISK=113 - BACKQUOTE=114 - BACKSLASH=115 - COLON=116 - COMMA=117 - CONCAT=118 - DASH=119 - DOLLAR=120 - DOT=121 - EQ_DOUBLE=122 - EQ_SINGLE=123 - GT_EQ=124 - GT=125 - HASH=126 - IREGEX_SINGLE=127 - IREGEX_DOUBLE=128 - LBRACE=129 - LBRACKET=130 - LPAREN=131 - LT_EQ=132 - LT=133 - NOT_EQ=134 - NOT_IREGEX=135 - NOT_REGEX=136 - NULL_PROPERTY=137 - NULLISH=138 - PERCENT=139 - PLUS=140 - QUERY=141 - QUOTE_DOUBLE=142 - QUOTE_SINGLE_TEMPLATE=143 - QUOTE_SINGLE_TEMPLATE_FULL=144 - QUOTE_SINGLE=145 - REGEX_SINGLE=146 - REGEX_DOUBLE=147 - RBRACE=148 - RBRACKET=149 - RPAREN=150 - SEMICOLON=151 - SLASH=152 - UNDERSCORE=153 - MULTI_LINE_COMMENT=154 - SINGLE_LINE_COMMENT=155 - WHITESPACE=156 - STRING_TEXT=157 - STRING_ESCAPE_TRIGGER=158 - FULL_STRING_TEXT=159 - FULL_STRING_ESCAPE_TRIGGER=160 + EXCEPT=27 + EXTRACT=28 + FINAL=29 + FINALLY=30 + FIRST=31 + FN=32 + FOLLOWING=33 + FOR=34 + FROM=35 + FULL=36 + FUN=37 + GROUP=38 + HAVING=39 + HOUR=40 + ID=41 + IF=42 + ILIKE=43 + IN=44 + INF=45 + INNER=46 + INTERSECT=47 + INTERVAL=48 + IS=49 + JOIN=50 + KEY=51 + LAST=52 + LEADING=53 + LEFT=54 + LET=55 + LIKE=56 + LIMIT=57 + MINUTE=58 + MONTH=59 + NAN_SQL=60 + NOT=61 + NULL_SQL=62 + NULLS=63 + OFFSET=64 + ON=65 + OR=66 + ORDER=67 + OUTER=68 + OVER=69 + PARTITION=70 + PRECEDING=71 + PREWHERE=72 + QUARTER=73 + RANGE=74 + RETURN=75 + RIGHT=76 + ROLLUP=77 + ROW=78 + ROWS=79 + SAMPLE=80 + SECOND=81 + SELECT=82 + SEMI=83 + SETTINGS=84 + SUBSTRING=85 + THEN=86 + THROW=87 + TIES=88 + TIMESTAMP=89 + TO=90 + TOP=91 + TOTALS=92 + TRAILING=93 + TRIM=94 + TRUNCATE=95 + TRY=96 + UNBOUNDED=97 + UNION=98 + USING=99 + WEEK=100 + WHEN=101 + WHERE=102 + WHILE=103 + WINDOW=104 + WITH=105 + YEAR=106 + ESCAPE_CHAR_COMMON=107 + IDENTIFIER=108 + FLOATING_LITERAL=109 + OCTAL_LITERAL=110 + DECIMAL_LITERAL=111 + HEXADECIMAL_LITERAL=112 + STRING_LITERAL=113 + ARROW=114 + ASTERISK=115 + BACKQUOTE=116 + BACKSLASH=117 + COLON=118 + COMMA=119 + CONCAT=120 + DASH=121 + DOLLAR=122 + DOT=123 + EQ_DOUBLE=124 + EQ_SINGLE=125 + GT_EQ=126 + GT=127 + HASH=128 + IREGEX_SINGLE=129 + IREGEX_DOUBLE=130 + LBRACE=131 + LBRACKET=132 + LPAREN=133 + LT_EQ=134 + LT=135 + NOT_EQ=136 + NOT_IREGEX=137 + NOT_REGEX=138 + NULL_PROPERTY=139 + NULLISH=140 + PERCENT=141 + PLUS=142 + QUERY=143 + QUOTE_DOUBLE=144 + QUOTE_SINGLE_TEMPLATE=145 + QUOTE_SINGLE_TEMPLATE_FULL=146 + QUOTE_SINGLE=147 + REGEX_SINGLE=148 + REGEX_DOUBLE=149 + RBRACE=150 + RBRACKET=151 + RPAREN=152 + SEMICOLON=153 + SLASH=154 + UNDERSCORE=155 + MULTI_LINE_COMMENT=156 + SINGLE_LINE_COMMENT=157 + WHITESPACE=158 + STRING_TEXT=159 + STRING_ESCAPE_TRIGGER=160 + FULL_STRING_TEXT=161 + FULL_STRING_ESCAPE_TRIGGER=162 def __init__(self, input:TokenStream, output:TextIO = sys.stdout): super().__init__(input, output) @@ -933,17 +941,17 @@ def program(self): self._la = 0 # Token type try: self.enterOuterAlt(localctx, 1) - self.state = 175 + self.state = 177 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)) & 180986211001696255) != 0) or ((((_la - 129)) & ~0x3f) == 0 and ((1 << (_la - 129)) & 4212759) != 0): - self.state = 172 + while (((_la) & ~0x3f) == 0 and ((1 << _la) & -140738696331266) != 0) or ((((_la - 64)) & ~0x3f) == 0 and ((1 << (_la - 64)) & 723944844006785023) != 0) or ((((_la - 131)) & ~0x3f) == 0 and ((1 << (_la - 131)) & 4212759) != 0): + self.state = 174 self.declaration() - self.state = 177 + self.state = 179 self._errHandler.sync(self) _la = self._input.LA(1) - self.state = 178 + self.state = 180 self.match(HogQLParser.EOF) except RecognitionException as re: localctx.exception = re @@ -986,17 +994,17 @@ def declaration(self): localctx = HogQLParser.DeclarationContext(self, self._ctx, self.state) self.enterRule(localctx, 2, self.RULE_declaration) try: - self.state = 182 + self.state = 184 self._errHandler.sync(self) token = self._input.LA(1) - if token in [53]: + if token in [55]: self.enterOuterAlt(localctx, 1) - self.state = 180 + self.state = 182 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, 52, 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, 104, 106, 107, 108, 109, 110, 111, 113, 119, 121, 129, 130, 131, 133, 140, 143, 151]: + 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, 28, 29, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45, 46, 48, 49, 50, 51, 52, 53, 54, 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, 104, 105, 106, 108, 109, 110, 111, 112, 113, 115, 121, 123, 131, 132, 133, 135, 142, 145, 153]: self.enterOuterAlt(localctx, 2) - self.state = 181 + self.state = 183 self.statement() pass else: @@ -1040,7 +1048,7 @@ def expression(self): self.enterRule(localctx, 4, self.RULE_expression) try: self.enterOuterAlt(localctx, 1) - self.state = 184 + self.state = 186 self.columnExpr(0) except RecognitionException as re: localctx.exception = re @@ -1094,19 +1102,19 @@ def varDecl(self): self._la = 0 # Token type try: self.enterOuterAlt(localctx, 1) - self.state = 186 + self.state = 188 self.match(HogQLParser.LET) - self.state = 187 + self.state = 189 self.identifier() - self.state = 191 + self.state = 193 self._errHandler.sync(self) _la = self._input.LA(1) - if _la==116: - self.state = 188 + if _la==118: + self.state = 190 self.match(HogQLParser.COLON) - self.state = 189 + self.state = 191 self.match(HogQLParser.EQ_SINGLE) - self.state = 190 + self.state = 192 self.expression() @@ -1158,26 +1166,26 @@ def identifierList(self): self._la = 0 # Token type try: self.enterOuterAlt(localctx, 1) - self.state = 193 + self.state = 195 self.identifier() - self.state = 198 + self.state = 200 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 = 194 + self.state = 196 self.match(HogQLParser.COMMA) - self.state = 195 + self.state = 197 self.identifier() - self.state = 200 + self.state = 202 self._errHandler.sync(self) _alt = self._interp.adaptivePredict(self._input,3,self._ctx) - self.state = 202 + self.state = 204 self._errHandler.sync(self) _la = self._input.LA(1) - if _la==117: - self.state = 201 + if _la==119: + self.state = 203 self.match(HogQLParser.COMMA) @@ -1262,78 +1270,78 @@ def statement(self): localctx = HogQLParser.StatementContext(self, self._ctx, self.state) self.enterRule(localctx, 10, self.RULE_statement) try: - self.state = 216 + self.state = 218 self._errHandler.sync(self) la_ = self._interp.adaptivePredict(self._input,5,self._ctx) if la_ == 1: self.enterOuterAlt(localctx, 1) - self.state = 204 + self.state = 206 self.returnStmt() pass elif la_ == 2: self.enterOuterAlt(localctx, 2) - self.state = 205 + self.state = 207 self.throwStmt() pass elif la_ == 3: self.enterOuterAlt(localctx, 3) - self.state = 206 + self.state = 208 self.tryCatchStmt() pass elif la_ == 4: self.enterOuterAlt(localctx, 4) - self.state = 207 + self.state = 209 self.ifStmt() pass elif la_ == 5: self.enterOuterAlt(localctx, 5) - self.state = 208 + self.state = 210 self.whileStmt() pass elif la_ == 6: self.enterOuterAlt(localctx, 6) - self.state = 209 + self.state = 211 self.forInStmt() pass elif la_ == 7: self.enterOuterAlt(localctx, 7) - self.state = 210 + self.state = 212 self.forStmt() pass elif la_ == 8: self.enterOuterAlt(localctx, 8) - self.state = 211 + self.state = 213 self.funcStmt() pass elif la_ == 9: self.enterOuterAlt(localctx, 9) - self.state = 212 + self.state = 214 self.varAssignment() pass elif la_ == 10: self.enterOuterAlt(localctx, 10) - self.state = 213 + self.state = 215 self.block() pass elif la_ == 11: self.enterOuterAlt(localctx, 11) - self.state = 214 + self.state = 216 self.exprStmt() pass elif la_ == 12: self.enterOuterAlt(localctx, 12) - self.state = 215 + self.state = 217 self.emptyStmt() pass @@ -1382,21 +1390,21 @@ def returnStmt(self): self.enterRule(localctx, 12, self.RULE_returnStmt) try: self.enterOuterAlt(localctx, 1) - self.state = 218 - self.match(HogQLParser.RETURN) self.state = 220 + self.match(HogQLParser.RETURN) + self.state = 222 self._errHandler.sync(self) la_ = self._interp.adaptivePredict(self._input,6,self._ctx) if la_ == 1: - self.state = 219 + self.state = 221 self.expression() - self.state = 223 + self.state = 225 self._errHandler.sync(self) la_ = self._interp.adaptivePredict(self._input,7,self._ctx) if la_ == 1: - self.state = 222 + self.state = 224 self.match(HogQLParser.SEMICOLON) @@ -1444,21 +1452,21 @@ def throwStmt(self): self.enterRule(localctx, 14, self.RULE_throwStmt) try: self.enterOuterAlt(localctx, 1) - self.state = 225 - self.match(HogQLParser.THROW) self.state = 227 + self.match(HogQLParser.THROW) + self.state = 229 self._errHandler.sync(self) la_ = self._interp.adaptivePredict(self._input,8,self._ctx) if la_ == 1: - self.state = 226 + self.state = 228 self.expression() - self.state = 230 + self.state = 232 self._errHandler.sync(self) la_ = self._interp.adaptivePredict(self._input,9,self._ctx) if la_ == 1: - self.state = 229 + self.state = 231 self.match(HogQLParser.SEMICOLON) @@ -1523,31 +1531,31 @@ def catchBlock(self): self._la = 0 # Token type try: self.enterOuterAlt(localctx, 1) - self.state = 232 + self.state = 234 self.match(HogQLParser.CATCH) - self.state = 241 + self.state = 243 self._errHandler.sync(self) _la = self._input.LA(1) - if _la==131: - self.state = 233 + if _la==133: + self.state = 235 self.match(HogQLParser.LPAREN) - self.state = 234 + self.state = 236 localctx.catchVar = self.identifier() - self.state = 237 + self.state = 239 self._errHandler.sync(self) _la = self._input.LA(1) - if _la==116: - self.state = 235 + if _la==118: + self.state = 237 self.match(HogQLParser.COLON) - self.state = 236 + self.state = 238 localctx.catchType = self.identifier() - self.state = 239 + self.state = 241 self.match(HogQLParser.RPAREN) - self.state = 243 + self.state = 245 localctx.catchStmt = self.block() except RecognitionException as re: localctx.exception = re @@ -1606,27 +1614,27 @@ def tryCatchStmt(self): self._la = 0 # Token type try: self.enterOuterAlt(localctx, 1) - self.state = 245 + self.state = 247 self.match(HogQLParser.TRY) - self.state = 246 + self.state = 248 localctx.tryStmt = self.block() - self.state = 250 + self.state = 252 self._errHandler.sync(self) _la = self._input.LA(1) while _la==14: - self.state = 247 + self.state = 249 self.catchBlock() - self.state = 252 + self.state = 254 self._errHandler.sync(self) _la = self._input.LA(1) - self.state = 255 + self.state = 257 self._errHandler.sync(self) _la = self._input.LA(1) - if _la==29: - self.state = 253 + if _la==30: + self.state = 255 self.match(HogQLParser.FINALLY) - self.state = 254 + self.state = 256 localctx.finallyStmt = self.block() @@ -1687,23 +1695,23 @@ def ifStmt(self): self.enterRule(localctx, 20, self.RULE_ifStmt) try: self.enterOuterAlt(localctx, 1) - self.state = 257 + self.state = 259 self.match(HogQLParser.IF) - self.state = 258 + self.state = 260 self.match(HogQLParser.LPAREN) - self.state = 259 + self.state = 261 self.expression() - self.state = 260 + self.state = 262 self.match(HogQLParser.RPAREN) - self.state = 261 + self.state = 263 self.statement() - self.state = 264 + self.state = 266 self._errHandler.sync(self) la_ = self._interp.adaptivePredict(self._input,14,self._ctx) if la_ == 1: - self.state = 262 + self.state = 264 self.match(HogQLParser.ELSE) - self.state = 263 + self.state = 265 self.statement() @@ -1761,21 +1769,21 @@ def whileStmt(self): self.enterRule(localctx, 22, self.RULE_whileStmt) try: self.enterOuterAlt(localctx, 1) - self.state = 266 + self.state = 268 self.match(HogQLParser.WHILE) - self.state = 267 + self.state = 269 self.match(HogQLParser.LPAREN) - self.state = 268 + self.state = 270 self.expression() - self.state = 269 + self.state = 271 self.match(HogQLParser.RPAREN) - self.state = 270 - self.statement() self.state = 272 + self.statement() + self.state = 274 self._errHandler.sync(self) la_ = self._interp.adaptivePredict(self._input,15,self._ctx) if la_ == 1: - self.state = 271 + self.state = 273 self.match(HogQLParser.SEMICOLON) @@ -1861,63 +1869,63 @@ def forStmt(self): self._la = 0 # Token type try: self.enterOuterAlt(localctx, 1) - self.state = 274 + self.state = 276 self.match(HogQLParser.FOR) - self.state = 275 + self.state = 277 self.match(HogQLParser.LPAREN) - self.state = 279 + self.state = 281 self._errHandler.sync(self) la_ = self._interp.adaptivePredict(self._input,16,self._ctx) if la_ == 1: - self.state = 276 + self.state = 278 localctx.initializerVarDeclr = self.varDecl() elif la_ == 2: - self.state = 277 + self.state = 279 localctx.initializerVarAssignment = self.varAssignment() elif la_ == 3: - self.state = 278 + self.state = 280 localctx.initializerExpression = self.expression() - self.state = 281 - self.match(HogQLParser.SEMICOLON) self.state = 283 + self.match(HogQLParser.SEMICOLON) + self.state = 285 self._errHandler.sync(self) _la = self._input.LA(1) - if (((_la) & ~0x3f) == 0 and ((1 << _la) & -9007270658588674) != 0) or ((((_la - 64)) & ~0x3f) == 0 and ((1 << (_la - 64)) & 180986072486903807) != 0) or ((((_la - 129)) & ~0x3f) == 0 and ((1 << (_la - 129)) & 18455) != 0): - self.state = 282 + if (((_la) & ~0x3f) == 0 and ((1 << _la) & -36169677449216002) != 0) or ((((_la - 64)) & ~0x3f) == 0 and ((1 << (_la - 64)) & 723944289947615231) != 0) or ((((_la - 131)) & ~0x3f) == 0 and ((1 << (_la - 131)) & 18455) != 0): + self.state = 284 localctx.condition = self.expression() - self.state = 285 + self.state = 287 self.match(HogQLParser.SEMICOLON) - self.state = 289 + self.state = 291 self._errHandler.sync(self) la_ = self._interp.adaptivePredict(self._input,18,self._ctx) if la_ == 1: - self.state = 286 + self.state = 288 localctx.incrementVarDeclr = self.varDecl() elif la_ == 2: - self.state = 287 + self.state = 289 localctx.incrementVarAssignment = self.varAssignment() elif la_ == 3: - self.state = 288 + self.state = 290 localctx.incrementExpression = self.expression() - self.state = 291 + self.state = 293 self.match(HogQLParser.RPAREN) - self.state = 292 - self.statement() self.state = 294 + self.statement() + self.state = 296 self._errHandler.sync(self) la_ = self._interp.adaptivePredict(self._input,19,self._ctx) if la_ == 1: - self.state = 293 + self.state = 295 self.match(HogQLParser.SEMICOLON) @@ -1992,37 +2000,37 @@ def forInStmt(self): self._la = 0 # Token type try: self.enterOuterAlt(localctx, 1) - self.state = 296 + self.state = 298 self.match(HogQLParser.FOR) - self.state = 297 + self.state = 299 self.match(HogQLParser.LPAREN) - self.state = 298 + self.state = 300 self.match(HogQLParser.LET) - self.state = 299 + self.state = 301 self.identifier() - self.state = 302 + self.state = 304 self._errHandler.sync(self) _la = self._input.LA(1) - if _la==117: - self.state = 300 + if _la==119: + self.state = 302 self.match(HogQLParser.COMMA) - self.state = 301 + self.state = 303 self.identifier() - self.state = 304 + self.state = 306 self.match(HogQLParser.IN) - self.state = 305 + self.state = 307 self.expression() - self.state = 306 + self.state = 308 self.match(HogQLParser.RPAREN) - self.state = 307 - self.statement() self.state = 309 + self.statement() + self.state = 311 self._errHandler.sync(self) la_ = self._interp.adaptivePredict(self._input,21,self._ctx) if la_ == 1: - self.state = 308 + self.state = 310 self.match(HogQLParser.SEMICOLON) @@ -2085,28 +2093,28 @@ def funcStmt(self): self._la = 0 # Token type try: self.enterOuterAlt(localctx, 1) - self.state = 311 + self.state = 313 _la = self._input.LA(1) - if not(_la==31 or _la==36): + if not(_la==32 or _la==37): self._errHandler.recoverInline(self) else: self._errHandler.reportMatch(self) self.consume() - self.state = 312 + self.state = 314 self.identifier() - self.state = 313 - self.match(HogQLParser.LPAREN) self.state = 315 + self.match(HogQLParser.LPAREN) + self.state = 317 self._errHandler.sync(self) _la = self._input.LA(1) - if (((_la) & ~0x3f) == 0 and ((1 << _la) & -1450176743603191810) != 0) or ((((_la - 64)) & ~0x3f) == 0 and ((1 << (_la - 64)) & 6458554974207) != 0): - self.state = 314 + if (((_la) & ~0x3f) == 0 and ((1 << _la) & -5800812384855539714) != 0) or ((((_la - 64)) & ~0x3f) == 0 and ((1 << (_la - 64)) & 25834219896831) != 0): + self.state = 316 self.identifierList() - self.state = 317 + self.state = 319 self.match(HogQLParser.RPAREN) - self.state = 318 + self.state = 320 self.block() except RecognitionException as re: localctx.exception = re @@ -2155,13 +2163,13 @@ def varAssignment(self): self.enterRule(localctx, 30, self.RULE_varAssignment) try: self.enterOuterAlt(localctx, 1) - self.state = 320 + self.state = 322 self.expression() - self.state = 321 + self.state = 323 self.match(HogQLParser.COLON) - self.state = 322 + self.state = 324 self.match(HogQLParser.EQ_SINGLE) - self.state = 323 + self.state = 325 self.expression() except RecognitionException as re: localctx.exception = re @@ -2204,13 +2212,13 @@ def exprStmt(self): self.enterRule(localctx, 32, self.RULE_exprStmt) try: self.enterOuterAlt(localctx, 1) - self.state = 325 - self.expression() self.state = 327 + self.expression() + self.state = 329 self._errHandler.sync(self) la_ = self._interp.adaptivePredict(self._input,23,self._ctx) if la_ == 1: - self.state = 326 + self.state = 328 self.match(HogQLParser.SEMICOLON) @@ -2251,7 +2259,7 @@ def emptyStmt(self): self.enterRule(localctx, 34, self.RULE_emptyStmt) try: self.enterOuterAlt(localctx, 1) - self.state = 329 + self.state = 331 self.match(HogQLParser.SEMICOLON) except RecognitionException as re: localctx.exception = re @@ -2301,19 +2309,19 @@ def block(self): self._la = 0 # Token type try: self.enterOuterAlt(localctx, 1) - self.state = 331 + self.state = 333 self.match(HogQLParser.LBRACE) - self.state = 335 + self.state = 337 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)) & 180986211001696255) != 0) or ((((_la - 129)) & ~0x3f) == 0 and ((1 << (_la - 129)) & 4212759) != 0): - self.state = 332 + while (((_la) & ~0x3f) == 0 and ((1 << _la) & -140738696331266) != 0) or ((((_la - 64)) & ~0x3f) == 0 and ((1 << (_la - 64)) & 723944844006785023) != 0) or ((((_la - 131)) & ~0x3f) == 0 and ((1 << (_la - 131)) & 4212759) != 0): + self.state = 334 self.declaration() - self.state = 337 + self.state = 339 self._errHandler.sync(self) _la = self._input.LA(1) - self.state = 338 + self.state = 340 self.match(HogQLParser.RBRACE) except RecognitionException as re: localctx.exception = re @@ -2359,11 +2367,11 @@ def kvPair(self): self.enterRule(localctx, 38, self.RULE_kvPair) try: self.enterOuterAlt(localctx, 1) - self.state = 340 + self.state = 342 self.expression() - self.state = 341 + self.state = 343 self.match(HogQLParser.COLON) - self.state = 342 + self.state = 344 self.expression() except RecognitionException as re: localctx.exception = re @@ -2413,26 +2421,26 @@ def kvPairList(self): self._la = 0 # Token type try: self.enterOuterAlt(localctx, 1) - self.state = 344 + self.state = 346 self.kvPair() - self.state = 349 + self.state = 351 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 = 345 + self.state = 347 self.match(HogQLParser.COMMA) - self.state = 346 + self.state = 348 self.kvPair() - self.state = 351 + self.state = 353 self._errHandler.sync(self) _alt = self._interp.adaptivePredict(self._input,25,self._ctx) - self.state = 353 + self.state = 355 self._errHandler.sync(self) _la = self._input.LA(1) - if _la==117: - self.state = 352 + if _la==119: + self.state = 354 self.match(HogQLParser.COMMA) @@ -2455,8 +2463,8 @@ def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1): def EOF(self): return self.getToken(HogQLParser.EOF, 0) - def selectUnionStmt(self): - return self.getTypedRuleContext(HogQLParser.SelectUnionStmtContext,0) + def selectSetStmt(self): + return self.getTypedRuleContext(HogQLParser.SelectSetStmtContext,0) def selectStmt(self): @@ -2485,26 +2493,26 @@ def select(self): self.enterRule(localctx, 42, self.RULE_select) try: self.enterOuterAlt(localctx, 1) - self.state = 358 + self.state = 360 self._errHandler.sync(self) la_ = self._interp.adaptivePredict(self._input,27,self._ctx) if la_ == 1: - self.state = 355 - self.selectUnionStmt() + self.state = 357 + self.selectSetStmt() pass elif la_ == 2: - self.state = 356 + self.state = 358 self.selectStmt() pass elif la_ == 3: - self.state = 357 + self.state = 359 self.hogqlxTagElement() pass - self.state = 360 + self.state = 362 self.match(HogQLParser.EOF) except RecognitionException as re: localctx.exception = re @@ -2515,66 +2523,72 @@ def select(self): return localctx - class SelectUnionStmtContext(ParserRuleContext): + class SelectStmtWithParensContext(ParserRuleContext): __slots__ = 'parser' def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1): super().__init__(parent, invokingState) self.parser = parser - def selectStmtWithParens(self, i:int=None): - if i is None: - return self.getTypedRuleContexts(HogQLParser.SelectStmtWithParensContext) - else: - return self.getTypedRuleContext(HogQLParser.SelectStmtWithParensContext,i) + def selectStmt(self): + return self.getTypedRuleContext(HogQLParser.SelectStmtContext,0) - def UNION(self, i:int=None): - if i is None: - return self.getTokens(HogQLParser.UNION) - else: - return self.getToken(HogQLParser.UNION, i) + def LPAREN(self): + return self.getToken(HogQLParser.LPAREN, 0) + + def selectSetStmt(self): + return self.getTypedRuleContext(HogQLParser.SelectSetStmtContext,0) + + + def RPAREN(self): + return self.getToken(HogQLParser.RPAREN, 0) + + def placeholder(self): + return self.getTypedRuleContext(HogQLParser.PlaceholderContext,0) - def ALL(self, i:int=None): - if i is None: - return self.getTokens(HogQLParser.ALL) - else: - return self.getToken(HogQLParser.ALL, i) def getRuleIndex(self): - return HogQLParser.RULE_selectUnionStmt + return HogQLParser.RULE_selectStmtWithParens def accept(self, visitor:ParseTreeVisitor): - if hasattr( visitor, "visitSelectUnionStmt" ): - return visitor.visitSelectUnionStmt(self) + if hasattr( visitor, "visitSelectStmtWithParens" ): + return visitor.visitSelectStmtWithParens(self) else: return visitor.visitChildren(self) - def selectUnionStmt(self): + def selectStmtWithParens(self): - localctx = HogQLParser.SelectUnionStmtContext(self, self._ctx, self.state) - self.enterRule(localctx, 44, self.RULE_selectUnionStmt) - self._la = 0 # Token type + localctx = HogQLParser.SelectStmtWithParensContext(self, self._ctx, self.state) + self.enterRule(localctx, 44, self.RULE_selectStmtWithParens) try: - self.enterOuterAlt(localctx, 1) - self.state = 362 - self.selectStmtWithParens() - self.state = 368 + self.state = 370 self._errHandler.sync(self) - _la = self._input.LA(1) - while _la==96: - self.state = 363 - self.match(HogQLParser.UNION) + token = self._input.LA(1) + if token in [82, 105]: + self.enterOuterAlt(localctx, 1) self.state = 364 - self.match(HogQLParser.ALL) + self.selectStmt() + pass + elif token in [133]: + self.enterOuterAlt(localctx, 2) self.state = 365 - self.selectStmtWithParens() - self.state = 370 - self._errHandler.sync(self) - _la = self._input.LA(1) + self.match(HogQLParser.LPAREN) + self.state = 366 + self.selectSetStmt() + self.state = 367 + self.match(HogQLParser.RPAREN) + pass + elif token in [131]: + self.enterOuterAlt(localctx, 3) + self.state = 369 + self.placeholder() + pass + else: + raise NoViableAltException(self) except RecognitionException as re: localctx.exception = re @@ -2585,73 +2599,127 @@ def selectUnionStmt(self): return localctx - class SelectStmtWithParensContext(ParserRuleContext): + class SubsequentSelectSetClauseContext(ParserRuleContext): __slots__ = 'parser' def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1): super().__init__(parent, invokingState) self.parser = parser - def selectStmt(self): - return self.getTypedRuleContext(HogQLParser.SelectStmtContext,0) - + def selectStmtWithParens(self): + return self.getTypedRuleContext(HogQLParser.SelectStmtWithParensContext,0) - def LPAREN(self): - return self.getToken(HogQLParser.LPAREN, 0) - def selectUnionStmt(self): - return self.getTypedRuleContext(HogQLParser.SelectUnionStmtContext,0) + def EXCEPT(self): + return self.getToken(HogQLParser.EXCEPT, 0) + def UNION(self): + return self.getToken(HogQLParser.UNION, 0) - def RPAREN(self): - return self.getToken(HogQLParser.RPAREN, 0) - - def placeholder(self): - return self.getTypedRuleContext(HogQLParser.PlaceholderContext,0) + def ALL(self): + return self.getToken(HogQLParser.ALL, 0) + def INTERSECT(self): + return self.getToken(HogQLParser.INTERSECT, 0) def getRuleIndex(self): - return HogQLParser.RULE_selectStmtWithParens + return HogQLParser.RULE_subsequentSelectSetClause def accept(self, visitor:ParseTreeVisitor): - if hasattr( visitor, "visitSelectStmtWithParens" ): - return visitor.visitSelectStmtWithParens(self) + if hasattr( visitor, "visitSubsequentSelectSetClause" ): + return visitor.visitSubsequentSelectSetClause(self) else: return visitor.visitChildren(self) - def selectStmtWithParens(self): + def subsequentSelectSetClause(self): - localctx = HogQLParser.SelectStmtWithParensContext(self, self._ctx, self.state) - self.enterRule(localctx, 46, self.RULE_selectStmtWithParens) + localctx = HogQLParser.SubsequentSelectSetClauseContext(self, self._ctx, self.state) + self.enterRule(localctx, 46, self.RULE_subsequentSelectSetClause) try: - self.state = 377 + self.enterOuterAlt(localctx, 1) + self.state = 376 self._errHandler.sync(self) token = self._input.LA(1) - if token in [80, 103]: - self.enterOuterAlt(localctx, 1) - self.state = 371 - self.selectStmt() - pass - elif token in [131]: - self.enterOuterAlt(localctx, 2) + if token in [27]: self.state = 372 - self.match(HogQLParser.LPAREN) + self.match(HogQLParser.EXCEPT) + pass + elif token in [98]: self.state = 373 - self.selectUnionStmt() + self.match(HogQLParser.UNION) self.state = 374 - self.match(HogQLParser.RPAREN) + self.match(HogQLParser.ALL) pass - elif token in [129]: - self.enterOuterAlt(localctx, 3) - self.state = 376 - self.placeholder() + elif token in [47]: + self.state = 375 + self.match(HogQLParser.INTERSECT) pass else: raise NoViableAltException(self) + self.state = 378 + self.selectStmtWithParens() + except RecognitionException as re: + localctx.exception = re + self._errHandler.reportError(self, re) + self._errHandler.recover(self, re) + finally: + self.exitRule() + return localctx + + + class SelectSetStmtContext(ParserRuleContext): + __slots__ = 'parser' + + def __init__(self, parser, parent:ParserRuleContext=None, invokingState:int=-1): + super().__init__(parent, invokingState) + self.parser = parser + + def selectStmtWithParens(self): + return self.getTypedRuleContext(HogQLParser.SelectStmtWithParensContext,0) + + + def subsequentSelectSetClause(self, i:int=None): + if i is None: + return self.getTypedRuleContexts(HogQLParser.SubsequentSelectSetClauseContext) + else: + return self.getTypedRuleContext(HogQLParser.SubsequentSelectSetClauseContext,i) + + + def getRuleIndex(self): + return HogQLParser.RULE_selectSetStmt + + def accept(self, visitor:ParseTreeVisitor): + if hasattr( visitor, "visitSelectSetStmt" ): + return visitor.visitSelectSetStmt(self) + else: + return visitor.visitChildren(self) + + + + + def selectSetStmt(self): + + localctx = HogQLParser.SelectSetStmtContext(self, self._ctx, self.state) + self.enterRule(localctx, 48, self.RULE_selectSetStmt) + self._la = 0 # Token type + try: + self.enterOuterAlt(localctx, 1) + self.state = 380 + self.selectStmtWithParens() + self.state = 384 + self._errHandler.sync(self) + _la = self._input.LA(1) + while _la==27 or _la==47 or _la==98: + self.state = 381 + self.subsequentSelectSetClause() + self.state = 386 + self._errHandler.sync(self) + _la = self._input.LA(1) + except RecognitionException as re: localctx.exception = re self._errHandler.reportError(self, re) @@ -2764,147 +2832,147 @@ def accept(self, visitor:ParseTreeVisitor): def selectStmt(self): localctx = HogQLParser.SelectStmtContext(self, self._ctx, self.state) - self.enterRule(localctx, 48, self.RULE_selectStmt) + self.enterRule(localctx, 50, self.RULE_selectStmt) self._la = 0 # Token type try: self.enterOuterAlt(localctx, 1) - self.state = 380 + self.state = 388 self._errHandler.sync(self) _la = self._input.LA(1) - if _la==103: - self.state = 379 + if _la==105: + self.state = 387 localctx.with_ = self.withClause() - self.state = 382 + self.state = 390 self.match(HogQLParser.SELECT) - self.state = 384 + self.state = 392 self._errHandler.sync(self) - la_ = self._interp.adaptivePredict(self._input,31,self._ctx) + la_ = self._interp.adaptivePredict(self._input,32,self._ctx) if la_ == 1: - self.state = 383 + self.state = 391 self.match(HogQLParser.DISTINCT) - self.state = 387 + self.state = 395 self._errHandler.sync(self) - la_ = self._interp.adaptivePredict(self._input,32,self._ctx) + la_ = self._interp.adaptivePredict(self._input,33,self._ctx) if la_ == 1: - self.state = 386 + self.state = 394 self.topClause() - self.state = 389 + self.state = 397 localctx.columns = self.columnExprList() - self.state = 391 + self.state = 399 self._errHandler.sync(self) _la = self._input.LA(1) - if _la==34: - self.state = 390 + if _la==35: + self.state = 398 localctx.from_ = self.fromClause() - self.state = 394 + self.state = 402 self._errHandler.sync(self) _la = self._input.LA(1) - if (((_la) & ~0x3f) == 0 and ((1 << _la) & 4538783999459360) != 0): - self.state = 393 + if (((_la) & ~0x3f) == 0 and ((1 << _la) & 18084767253659680) != 0): + self.state = 401 self.arrayJoinClause() - self.state = 397 + self.state = 405 self._errHandler.sync(self) _la = self._input.LA(1) - if _la==70: - self.state = 396 + if _la==72: + self.state = 404 self.prewhereClause() - self.state = 400 + self.state = 408 self._errHandler.sync(self) _la = self._input.LA(1) - if _la==100: - self.state = 399 + if _la==102: + self.state = 407 localctx.where = self.whereClause() - self.state = 403 + self.state = 411 self._errHandler.sync(self) _la = self._input.LA(1) - if _la==37: - self.state = 402 + if _la==38: + self.state = 410 self.groupByClause() - self.state = 407 + self.state = 415 self._errHandler.sync(self) - la_ = self._interp.adaptivePredict(self._input,38,self._ctx) + la_ = self._interp.adaptivePredict(self._input,39,self._ctx) if la_ == 1: - self.state = 405 + self.state = 413 self.match(HogQLParser.WITH) - self.state = 406 + self.state = 414 _la = self._input.LA(1) - if not(_la==18 or _la==75): + if not(_la==18 or _la==77): self._errHandler.recoverInline(self) else: self._errHandler.reportMatch(self) self.consume() - self.state = 411 + self.state = 419 self._errHandler.sync(self) _la = self._input.LA(1) - if _la==103: - self.state = 409 + if _la==105: + self.state = 417 self.match(HogQLParser.WITH) - self.state = 410 + self.state = 418 self.match(HogQLParser.TOTALS) - self.state = 414 + self.state = 422 self._errHandler.sync(self) _la = self._input.LA(1) - if _la==38: - self.state = 413 + if _la==39: + self.state = 421 self.havingClause() - self.state = 417 + self.state = 425 self._errHandler.sync(self) _la = self._input.LA(1) - if _la==102: - self.state = 416 + if _la==104: + self.state = 424 self.windowClause() - self.state = 420 + self.state = 428 self._errHandler.sync(self) _la = self._input.LA(1) - if _la==65: - self.state = 419 + if _la==67: + self.state = 427 self.orderByClause() - self.state = 424 + self.state = 432 self._errHandler.sync(self) token = self._input.LA(1) - if token in [55]: - self.state = 422 + if token in [57]: + self.state = 430 self.limitAndOffsetClause() pass - elif token in [62]: - self.state = 423 + elif token in [64]: + self.state = 431 self.offsetOnlyClause() pass - elif token in [-1, 82, 96, 150]: + elif token in [-1, 27, 47, 84, 98, 152]: pass else: pass - self.state = 427 + self.state = 435 self._errHandler.sync(self) _la = self._input.LA(1) - if _la==82: - self.state = 426 + if _la==84: + self.state = 434 self.settingsClause() @@ -2946,12 +3014,12 @@ def accept(self, visitor:ParseTreeVisitor): def withClause(self): localctx = HogQLParser.WithClauseContext(self, self._ctx, self.state) - self.enterRule(localctx, 50, self.RULE_withClause) + self.enterRule(localctx, 52, self.RULE_withClause) try: self.enterOuterAlt(localctx, 1) - self.state = 429 + self.state = 437 self.match(HogQLParser.WITH) - self.state = 430 + self.state = 438 self.withExprList() except RecognitionException as re: localctx.exception = re @@ -2996,20 +3064,20 @@ def accept(self, visitor:ParseTreeVisitor): def topClause(self): localctx = HogQLParser.TopClauseContext(self, self._ctx, self.state) - self.enterRule(localctx, 52, self.RULE_topClause) + self.enterRule(localctx, 54, self.RULE_topClause) try: self.enterOuterAlt(localctx, 1) - self.state = 432 + self.state = 440 self.match(HogQLParser.TOP) - self.state = 433 + self.state = 441 self.match(HogQLParser.DECIMAL_LITERAL) - self.state = 436 + self.state = 444 self._errHandler.sync(self) - la_ = self._interp.adaptivePredict(self._input,45,self._ctx) + la_ = self._interp.adaptivePredict(self._input,46,self._ctx) if la_ == 1: - self.state = 434 + self.state = 442 self.match(HogQLParser.WITH) - self.state = 435 + self.state = 443 self.match(HogQLParser.TIES) @@ -3051,12 +3119,12 @@ def accept(self, visitor:ParseTreeVisitor): def fromClause(self): localctx = HogQLParser.FromClauseContext(self, self._ctx, self.state) - self.enterRule(localctx, 54, self.RULE_fromClause) + self.enterRule(localctx, 56, self.RULE_fromClause) try: self.enterOuterAlt(localctx, 1) - self.state = 438 + self.state = 446 self.match(HogQLParser.FROM) - self.state = 439 + self.state = 447 self.joinExpr(0) except RecognitionException as re: localctx.exception = re @@ -3105,28 +3173,28 @@ def accept(self, visitor:ParseTreeVisitor): def arrayJoinClause(self): localctx = HogQLParser.ArrayJoinClauseContext(self, self._ctx, self.state) - self.enterRule(localctx, 56, self.RULE_arrayJoinClause) + self.enterRule(localctx, 58, self.RULE_arrayJoinClause) self._la = 0 # Token type try: self.enterOuterAlt(localctx, 1) - self.state = 442 + self.state = 450 self._errHandler.sync(self) _la = self._input.LA(1) - if _la==45 or _la==52: - self.state = 441 + if _la==46 or _la==54: + self.state = 449 _la = self._input.LA(1) - if not(_la==45 or _la==52): + if not(_la==46 or _la==54): self._errHandler.recoverInline(self) else: self._errHandler.reportMatch(self) self.consume() - self.state = 444 + self.state = 452 self.match(HogQLParser.ARRAY) - self.state = 445 + self.state = 453 self.match(HogQLParser.JOIN) - self.state = 446 + self.state = 454 self.columnExprList() except RecognitionException as re: localctx.exception = re @@ -3200,39 +3268,39 @@ def accept(self, visitor:ParseTreeVisitor): def windowClause(self): localctx = HogQLParser.WindowClauseContext(self, self._ctx, self.state) - self.enterRule(localctx, 58, self.RULE_windowClause) + self.enterRule(localctx, 60, self.RULE_windowClause) self._la = 0 # Token type try: self.enterOuterAlt(localctx, 1) - self.state = 448 + self.state = 456 self.match(HogQLParser.WINDOW) - self.state = 449 + self.state = 457 self.identifier() - self.state = 450 + self.state = 458 self.match(HogQLParser.AS) - self.state = 451 + self.state = 459 self.match(HogQLParser.LPAREN) - self.state = 452 + self.state = 460 self.windowExpr() - self.state = 453 + self.state = 461 self.match(HogQLParser.RPAREN) - self.state = 463 + self.state = 471 self._errHandler.sync(self) _la = self._input.LA(1) - while _la==117: - self.state = 454 + while _la==119: + self.state = 462 self.match(HogQLParser.COMMA) - self.state = 455 + self.state = 463 self.identifier() - self.state = 456 + self.state = 464 self.match(HogQLParser.AS) - self.state = 457 + self.state = 465 self.match(HogQLParser.LPAREN) - self.state = 458 + self.state = 466 self.windowExpr() - self.state = 459 + self.state = 467 self.match(HogQLParser.RPAREN) - self.state = 465 + self.state = 473 self._errHandler.sync(self) _la = self._input.LA(1) @@ -3274,12 +3342,12 @@ def accept(self, visitor:ParseTreeVisitor): def prewhereClause(self): localctx = HogQLParser.PrewhereClauseContext(self, self._ctx, self.state) - self.enterRule(localctx, 60, self.RULE_prewhereClause) + self.enterRule(localctx, 62, self.RULE_prewhereClause) try: self.enterOuterAlt(localctx, 1) - self.state = 466 + self.state = 474 self.match(HogQLParser.PREWHERE) - self.state = 467 + self.state = 475 self.columnExpr(0) except RecognitionException as re: localctx.exception = re @@ -3319,12 +3387,12 @@ def accept(self, visitor:ParseTreeVisitor): def whereClause(self): localctx = HogQLParser.WhereClauseContext(self, self._ctx, self.state) - self.enterRule(localctx, 62, self.RULE_whereClause) + self.enterRule(localctx, 64, self.RULE_whereClause) try: self.enterOuterAlt(localctx, 1) - self.state = 469 + self.state = 477 self.match(HogQLParser.WHERE) - self.state = 470 + self.state = 478 self.columnExpr(0) except RecognitionException as re: localctx.exception = re @@ -3379,35 +3447,35 @@ def accept(self, visitor:ParseTreeVisitor): def groupByClause(self): localctx = HogQLParser.GroupByClauseContext(self, self._ctx, self.state) - self.enterRule(localctx, 64, self.RULE_groupByClause) + self.enterRule(localctx, 66, self.RULE_groupByClause) self._la = 0 # Token type try: self.enterOuterAlt(localctx, 1) - self.state = 472 + self.state = 480 self.match(HogQLParser.GROUP) - self.state = 473 + self.state = 481 self.match(HogQLParser.BY) - self.state = 480 + self.state = 488 self._errHandler.sync(self) - la_ = self._interp.adaptivePredict(self._input,48,self._ctx) + la_ = self._interp.adaptivePredict(self._input,49,self._ctx) if la_ == 1: - self.state = 474 + self.state = 482 _la = self._input.LA(1) - if not(_la==18 or _la==75): + if not(_la==18 or _la==77): self._errHandler.recoverInline(self) else: self._errHandler.reportMatch(self) self.consume() - self.state = 475 + self.state = 483 self.match(HogQLParser.LPAREN) - self.state = 476 + self.state = 484 self.columnExprList() - self.state = 477 + self.state = 485 self.match(HogQLParser.RPAREN) pass elif la_ == 2: - self.state = 479 + self.state = 487 self.columnExprList() pass @@ -3450,12 +3518,12 @@ def accept(self, visitor:ParseTreeVisitor): def havingClause(self): localctx = HogQLParser.HavingClauseContext(self, self._ctx, self.state) - self.enterRule(localctx, 66, self.RULE_havingClause) + self.enterRule(localctx, 68, self.RULE_havingClause) try: self.enterOuterAlt(localctx, 1) - self.state = 482 + self.state = 490 self.match(HogQLParser.HAVING) - self.state = 483 + self.state = 491 self.columnExpr(0) except RecognitionException as re: localctx.exception = re @@ -3498,14 +3566,14 @@ def accept(self, visitor:ParseTreeVisitor): def orderByClause(self): localctx = HogQLParser.OrderByClauseContext(self, self._ctx, self.state) - self.enterRule(localctx, 68, self.RULE_orderByClause) + self.enterRule(localctx, 70, self.RULE_orderByClause) try: self.enterOuterAlt(localctx, 1) - self.state = 485 + self.state = 493 self.match(HogQLParser.ORDER) - self.state = 486 + self.state = 494 self.match(HogQLParser.BY) - self.state = 487 + self.state = 495 self.orderExprList() except RecognitionException as re: localctx.exception = re @@ -3548,14 +3616,14 @@ def accept(self, visitor:ParseTreeVisitor): def projectionOrderByClause(self): localctx = HogQLParser.ProjectionOrderByClauseContext(self, self._ctx, self.state) - self.enterRule(localctx, 70, self.RULE_projectionOrderByClause) + self.enterRule(localctx, 72, self.RULE_projectionOrderByClause) try: self.enterOuterAlt(localctx, 1) - self.state = 489 + self.state = 497 self.match(HogQLParser.ORDER) - self.state = 490 + self.state = 498 self.match(HogQLParser.BY) - self.state = 491 + self.state = 499 self.columnExprList() except RecognitionException as re: localctx.exception = re @@ -3617,44 +3685,44 @@ def accept(self, visitor:ParseTreeVisitor): def limitAndOffsetClause(self): localctx = HogQLParser.LimitAndOffsetClauseContext(self, self._ctx, self.state) - self.enterRule(localctx, 72, self.RULE_limitAndOffsetClause) + self.enterRule(localctx, 74, self.RULE_limitAndOffsetClause) self._la = 0 # Token type try: - self.state = 522 + self.state = 530 self._errHandler.sync(self) - la_ = self._interp.adaptivePredict(self._input,53,self._ctx) + la_ = self._interp.adaptivePredict(self._input,54,self._ctx) if la_ == 1: self.enterOuterAlt(localctx, 1) - self.state = 493 + self.state = 501 self.match(HogQLParser.LIMIT) - self.state = 494 + self.state = 502 self.columnExpr(0) - self.state = 497 + self.state = 505 self._errHandler.sync(self) _la = self._input.LA(1) - if _la==117: - self.state = 495 + if _la==119: + self.state = 503 self.match(HogQLParser.COMMA) - self.state = 496 + self.state = 504 self.columnExpr(0) - self.state = 503 + self.state = 511 self._errHandler.sync(self) token = self._input.LA(1) - if token in [103]: - self.state = 499 + if token in [105]: + self.state = 507 self.match(HogQLParser.WITH) - self.state = 500 + self.state = 508 self.match(HogQLParser.TIES) pass elif token in [11]: - self.state = 501 + self.state = 509 self.match(HogQLParser.BY) - self.state = 502 + self.state = 510 self.columnExprList() pass - elif token in [-1, 82, 96, 150]: + elif token in [-1, 27, 47, 84, 98, 152]: pass else: pass @@ -3662,43 +3730,43 @@ def limitAndOffsetClause(self): elif la_ == 2: self.enterOuterAlt(localctx, 2) - self.state = 505 + self.state = 513 self.match(HogQLParser.LIMIT) - self.state = 506 + self.state = 514 self.columnExpr(0) - self.state = 509 + self.state = 517 self._errHandler.sync(self) _la = self._input.LA(1) - if _la==103: - self.state = 507 + if _la==105: + self.state = 515 self.match(HogQLParser.WITH) - self.state = 508 + self.state = 516 self.match(HogQLParser.TIES) - self.state = 511 + self.state = 519 self.match(HogQLParser.OFFSET) - self.state = 512 + self.state = 520 self.columnExpr(0) pass elif la_ == 3: self.enterOuterAlt(localctx, 3) - self.state = 514 + self.state = 522 self.match(HogQLParser.LIMIT) - self.state = 515 + self.state = 523 self.columnExpr(0) - self.state = 516 + self.state = 524 self.match(HogQLParser.OFFSET) - self.state = 517 + self.state = 525 self.columnExpr(0) - self.state = 520 + self.state = 528 self._errHandler.sync(self) _la = self._input.LA(1) if _la==11: - self.state = 518 + self.state = 526 self.match(HogQLParser.BY) - self.state = 519 + self.state = 527 self.columnExprList() @@ -3743,12 +3811,12 @@ def accept(self, visitor:ParseTreeVisitor): def offsetOnlyClause(self): localctx = HogQLParser.OffsetOnlyClauseContext(self, self._ctx, self.state) - self.enterRule(localctx, 74, self.RULE_offsetOnlyClause) + self.enterRule(localctx, 76, self.RULE_offsetOnlyClause) try: self.enterOuterAlt(localctx, 1) - self.state = 524 + self.state = 532 self.match(HogQLParser.OFFSET) - self.state = 525 + self.state = 533 self.columnExpr(0) except RecognitionException as re: localctx.exception = re @@ -3788,12 +3856,12 @@ def accept(self, visitor:ParseTreeVisitor): def settingsClause(self): localctx = HogQLParser.SettingsClauseContext(self, self._ctx, self.state) - self.enterRule(localctx, 76, self.RULE_settingsClause) + self.enterRule(localctx, 78, self.RULE_settingsClause) try: self.enterOuterAlt(localctx, 1) - self.state = 527 + self.state = 535 self.match(HogQLParser.SETTINGS) - self.state = 528 + self.state = 536 self.settingExprList() except RecognitionException as re: localctx.exception = re @@ -3920,34 +3988,34 @@ def joinExpr(self, _p:int=0): _parentState = self.state localctx = HogQLParser.JoinExprContext(self, self._ctx, _parentState) _prevctx = localctx - _startState = 78 - self.enterRecursionRule(localctx, 78, self.RULE_joinExpr, _p) + _startState = 80 + self.enterRecursionRule(localctx, 80, self.RULE_joinExpr, _p) self._la = 0 # Token type try: self.enterOuterAlt(localctx, 1) - self.state = 542 + self.state = 550 self._errHandler.sync(self) - la_ = self._interp.adaptivePredict(self._input,56,self._ctx) + la_ = self._interp.adaptivePredict(self._input,57,self._ctx) if la_ == 1: localctx = HogQLParser.JoinExprTableContext(self, localctx) self._ctx = localctx _prevctx = localctx - self.state = 531 + self.state = 539 self.tableExpr(0) - self.state = 533 + self.state = 541 self._errHandler.sync(self) - la_ = self._interp.adaptivePredict(self._input,54,self._ctx) + la_ = self._interp.adaptivePredict(self._input,55,self._ctx) if la_ == 1: - self.state = 532 + self.state = 540 self.match(HogQLParser.FINAL) - self.state = 536 + self.state = 544 self._errHandler.sync(self) - la_ = self._interp.adaptivePredict(self._input,55,self._ctx) + la_ = self._interp.adaptivePredict(self._input,56,self._ctx) if la_ == 1: - self.state = 535 + self.state = 543 self.sampleClause() @@ -3957,67 +4025,67 @@ def joinExpr(self, _p:int=0): localctx = HogQLParser.JoinExprParensContext(self, localctx) self._ctx = localctx _prevctx = localctx - self.state = 538 + self.state = 546 self.match(HogQLParser.LPAREN) - self.state = 539 + self.state = 547 self.joinExpr(0) - self.state = 540 + self.state = 548 self.match(HogQLParser.RPAREN) pass self._ctx.stop = self._input.LT(-1) - self.state = 558 + self.state = 566 self._errHandler.sync(self) - _alt = self._interp.adaptivePredict(self._input,59,self._ctx) + _alt = self._interp.adaptivePredict(self._input,60,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 = 556 + self.state = 564 self._errHandler.sync(self) - la_ = self._interp.adaptivePredict(self._input,58,self._ctx) + la_ = self._interp.adaptivePredict(self._input,59,self._ctx) if la_ == 1: localctx = HogQLParser.JoinExprCrossOpContext(self, HogQLParser.JoinExprContext(self, _parentctx, _parentState)) self.pushNewRecursionContext(localctx, _startState, self.RULE_joinExpr) - self.state = 544 + self.state = 552 if not self.precpred(self._ctx, 3): from antlr4.error.Errors import FailedPredicateException raise FailedPredicateException(self, "self.precpred(self._ctx, 3)") - self.state = 545 + self.state = 553 self.joinOpCross() - self.state = 546 + self.state = 554 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 = 548 + self.state = 556 if not self.precpred(self._ctx, 4): from antlr4.error.Errors import FailedPredicateException raise FailedPredicateException(self, "self.precpred(self._ctx, 4)") - self.state = 550 + self.state = 558 self._errHandler.sync(self) _la = self._input.LA(1) - if (((_la) & ~0x3f) == 0 and ((1 << _la) & 4538818359197978) != 0) or _la==74 or _la==81: - self.state = 549 + if (((_la) & ~0x3f) == 0 and ((1 << _la) & 18084835973136666) != 0) or _la==76 or _la==83: + self.state = 557 self.joinOp() - self.state = 552 + self.state = 560 self.match(HogQLParser.JOIN) - self.state = 553 + self.state = 561 self.joinExpr(0) - self.state = 554 + self.state = 562 self.joinConstraintClause() pass - self.state = 560 + self.state = 568 self._errHandler.sync(self) - _alt = self._interp.adaptivePredict(self._input,59,self._ctx) + _alt = self._interp.adaptivePredict(self._input,60,self._ctx) except RecognitionException as re: localctx.exception = re @@ -4123,24 +4191,24 @@ def accept(self, visitor:ParseTreeVisitor): def joinOp(self): localctx = HogQLParser.JoinOpContext(self, self._ctx, self.state) - self.enterRule(localctx, 80, self.RULE_joinOp) + self.enterRule(localctx, 82, self.RULE_joinOp) self._la = 0 # Token type try: - self.state = 604 + self.state = 612 self._errHandler.sync(self) - la_ = self._interp.adaptivePredict(self._input,73,self._ctx) + la_ = self._interp.adaptivePredict(self._input,74,self._ctx) if la_ == 1: localctx = HogQLParser.JoinOpInnerContext(self, localctx) self.enterOuterAlt(localctx, 1) - self.state = 570 + self.state = 578 self._errHandler.sync(self) - la_ = self._interp.adaptivePredict(self._input,62,self._ctx) + la_ = self._interp.adaptivePredict(self._input,63,self._ctx) if la_ == 1: - self.state = 562 + self.state = 570 self._errHandler.sync(self) _la = self._input.LA(1) if (((_la) & ~0x3f) == 0 and ((1 << _la) & 274) != 0): - self.state = 561 + self.state = 569 _la = self._input.LA(1) if not((((_la) & ~0x3f) == 0 and ((1 << _la) & 274) != 0)): self._errHandler.recoverInline(self) @@ -4149,18 +4217,18 @@ def joinOp(self): self.consume() - self.state = 564 + self.state = 572 self.match(HogQLParser.INNER) pass elif la_ == 2: - self.state = 565 + self.state = 573 self.match(HogQLParser.INNER) - self.state = 567 + self.state = 575 self._errHandler.sync(self) _la = self._input.LA(1) if (((_la) & ~0x3f) == 0 and ((1 << _la) & 274) != 0): - self.state = 566 + self.state = 574 _la = self._input.LA(1) if not((((_la) & ~0x3f) == 0 and ((1 << _la) & 274) != 0)): self._errHandler.recoverInline(self) @@ -4172,7 +4240,7 @@ def joinOp(self): pass elif la_ == 3: - self.state = 569 + self.state = 577 _la = self._input.LA(1) if not((((_la) & ~0x3f) == 0 and ((1 << _la) & 274) != 0)): self._errHandler.recoverInline(self) @@ -4187,63 +4255,63 @@ def joinOp(self): elif la_ == 2: localctx = HogQLParser.JoinOpLeftRightContext(self, localctx) self.enterOuterAlt(localctx, 2) - self.state = 586 + self.state = 594 self._errHandler.sync(self) - la_ = self._interp.adaptivePredict(self._input,67,self._ctx) + la_ = self._interp.adaptivePredict(self._input,68,self._ctx) if la_ == 1: - self.state = 573 + self.state = 581 self._errHandler.sync(self) _la = self._input.LA(1) - if (((_la) & ~0x3f) == 0 and ((1 << _la) & 282) != 0) or _la==81: - self.state = 572 + if (((_la) & ~0x3f) == 0 and ((1 << _la) & 282) != 0) or _la==83: + self.state = 580 _la = self._input.LA(1) - if not((((_la) & ~0x3f) == 0 and ((1 << _la) & 282) != 0) or _la==81): + if not((((_la) & ~0x3f) == 0 and ((1 << _la) & 282) != 0) or _la==83): self._errHandler.recoverInline(self) else: self._errHandler.reportMatch(self) self.consume() - self.state = 575 + self.state = 583 _la = self._input.LA(1) - if not(_la==52 or _la==74): + if not(_la==54 or _la==76): self._errHandler.recoverInline(self) else: self._errHandler.reportMatch(self) self.consume() - self.state = 577 + self.state = 585 self._errHandler.sync(self) _la = self._input.LA(1) - if _la==66: - self.state = 576 + if _la==68: + self.state = 584 self.match(HogQLParser.OUTER) pass elif la_ == 2: - self.state = 579 + self.state = 587 _la = self._input.LA(1) - if not(_la==52 or _la==74): + if not(_la==54 or _la==76): self._errHandler.recoverInline(self) else: self._errHandler.reportMatch(self) self.consume() - self.state = 581 + self.state = 589 self._errHandler.sync(self) _la = self._input.LA(1) - if _la==66: - self.state = 580 + if _la==68: + self.state = 588 self.match(HogQLParser.OUTER) - self.state = 584 + self.state = 592 self._errHandler.sync(self) _la = self._input.LA(1) - if (((_la) & ~0x3f) == 0 and ((1 << _la) & 282) != 0) or _la==81: - self.state = 583 + if (((_la) & ~0x3f) == 0 and ((1 << _la) & 282) != 0) or _la==83: + self.state = 591 _la = self._input.LA(1) - if not((((_la) & ~0x3f) == 0 and ((1 << _la) & 282) != 0) or _la==81): + if not((((_la) & ~0x3f) == 0 and ((1 << _la) & 282) != 0) or _la==83): self._errHandler.recoverInline(self) else: self._errHandler.reportMatch(self) @@ -4258,15 +4326,15 @@ def joinOp(self): elif la_ == 3: localctx = HogQLParser.JoinOpFullContext(self, localctx) self.enterOuterAlt(localctx, 3) - self.state = 602 + self.state = 610 self._errHandler.sync(self) - la_ = self._interp.adaptivePredict(self._input,72,self._ctx) + la_ = self._interp.adaptivePredict(self._input,73,self._ctx) if la_ == 1: - self.state = 589 + self.state = 597 self._errHandler.sync(self) _la = self._input.LA(1) if _la==1 or _la==4: - self.state = 588 + self.state = 596 _la = self._input.LA(1) if not(_la==1 or _la==4): self._errHandler.recoverInline(self) @@ -4275,34 +4343,34 @@ def joinOp(self): self.consume() - self.state = 591 + self.state = 599 self.match(HogQLParser.FULL) - self.state = 593 + self.state = 601 self._errHandler.sync(self) _la = self._input.LA(1) - if _la==66: - self.state = 592 + if _la==68: + self.state = 600 self.match(HogQLParser.OUTER) pass elif la_ == 2: - self.state = 595 + self.state = 603 self.match(HogQLParser.FULL) - self.state = 597 + self.state = 605 self._errHandler.sync(self) _la = self._input.LA(1) - if _la==66: - self.state = 596 + if _la==68: + self.state = 604 self.match(HogQLParser.OUTER) - self.state = 600 + self.state = 608 self._errHandler.sync(self) _la = self._input.LA(1) if _la==1 or _la==4: - self.state = 599 + self.state = 607 _la = self._input.LA(1) if not(_la==1 or _la==4): self._errHandler.recoverInline(self) @@ -4357,21 +4425,21 @@ def accept(self, visitor:ParseTreeVisitor): def joinOpCross(self): localctx = HogQLParser.JoinOpCrossContext(self, self._ctx, self.state) - self.enterRule(localctx, 82, self.RULE_joinOpCross) + self.enterRule(localctx, 84, self.RULE_joinOpCross) try: - self.state = 609 + self.state = 617 self._errHandler.sync(self) token = self._input.LA(1) if token in [17]: self.enterOuterAlt(localctx, 1) - self.state = 606 + self.state = 614 self.match(HogQLParser.CROSS) - self.state = 607 + self.state = 615 self.match(HogQLParser.JOIN) pass - elif token in [117]: + elif token in [119]: self.enterOuterAlt(localctx, 2) - self.state = 608 + self.state = 616 self.match(HogQLParser.COMMA) pass else: @@ -4424,36 +4492,36 @@ def accept(self, visitor:ParseTreeVisitor): def joinConstraintClause(self): localctx = HogQLParser.JoinConstraintClauseContext(self, self._ctx, self.state) - self.enterRule(localctx, 84, self.RULE_joinConstraintClause) + self.enterRule(localctx, 86, self.RULE_joinConstraintClause) try: - self.state = 620 + self.state = 628 self._errHandler.sync(self) - la_ = self._interp.adaptivePredict(self._input,75,self._ctx) + la_ = self._interp.adaptivePredict(self._input,76,self._ctx) if la_ == 1: self.enterOuterAlt(localctx, 1) - self.state = 611 + self.state = 619 self.match(HogQLParser.ON) - self.state = 612 + self.state = 620 self.columnExprList() pass elif la_ == 2: self.enterOuterAlt(localctx, 2) - self.state = 613 + self.state = 621 self.match(HogQLParser.USING) - self.state = 614 + self.state = 622 self.match(HogQLParser.LPAREN) - self.state = 615 + self.state = 623 self.columnExprList() - self.state = 616 + self.state = 624 self.match(HogQLParser.RPAREN) pass elif la_ == 3: self.enterOuterAlt(localctx, 3) - self.state = 618 + self.state = 626 self.match(HogQLParser.USING) - self.state = 619 + self.state = 627 self.columnExprList() pass @@ -4502,20 +4570,20 @@ def accept(self, visitor:ParseTreeVisitor): def sampleClause(self): localctx = HogQLParser.SampleClauseContext(self, self._ctx, self.state) - self.enterRule(localctx, 86, self.RULE_sampleClause) + self.enterRule(localctx, 88, self.RULE_sampleClause) try: self.enterOuterAlt(localctx, 1) - self.state = 622 + self.state = 630 self.match(HogQLParser.SAMPLE) - self.state = 623 + self.state = 631 self.ratioExpr() - self.state = 626 + self.state = 634 self._errHandler.sync(self) - la_ = self._interp.adaptivePredict(self._input,76,self._ctx) + la_ = self._interp.adaptivePredict(self._input,77,self._ctx) if la_ == 1: - self.state = 624 + self.state = 632 self.match(HogQLParser.OFFSET) - self.state = 625 + self.state = 633 self.ratioExpr() @@ -4563,21 +4631,21 @@ def accept(self, visitor:ParseTreeVisitor): def orderExprList(self): localctx = HogQLParser.OrderExprListContext(self, self._ctx, self.state) - self.enterRule(localctx, 88, self.RULE_orderExprList) + self.enterRule(localctx, 90, self.RULE_orderExprList) self._la = 0 # Token type try: self.enterOuterAlt(localctx, 1) - self.state = 628 + self.state = 636 self.orderExpr() - self.state = 633 + self.state = 641 self._errHandler.sync(self) _la = self._input.LA(1) - while _la==117: - self.state = 629 + while _la==119: + self.state = 637 self.match(HogQLParser.COMMA) - self.state = 630 + self.state = 638 self.orderExpr() - self.state = 635 + self.state = 643 self._errHandler.sync(self) _la = self._input.LA(1) @@ -4640,17 +4708,17 @@ def accept(self, visitor:ParseTreeVisitor): def orderExpr(self): localctx = HogQLParser.OrderExprContext(self, self._ctx, self.state) - self.enterRule(localctx, 90, self.RULE_orderExpr) + self.enterRule(localctx, 92, self.RULE_orderExpr) self._la = 0 # Token type try: self.enterOuterAlt(localctx, 1) - self.state = 636 + self.state = 644 self.columnExpr(0) - self.state = 638 + self.state = 646 self._errHandler.sync(self) _la = self._input.LA(1) if (((_la) & ~0x3f) == 0 and ((1 << _la) & 12583040) != 0): - self.state = 637 + self.state = 645 _la = self._input.LA(1) if not((((_la) & ~0x3f) == 0 and ((1 << _la) & 12583040) != 0)): self._errHandler.recoverInline(self) @@ -4659,28 +4727,28 @@ def orderExpr(self): self.consume() - self.state = 642 + self.state = 650 self._errHandler.sync(self) _la = self._input.LA(1) - if _la==61: - self.state = 640 + if _la==63: + self.state = 648 self.match(HogQLParser.NULLS) - self.state = 641 + self.state = 649 _la = self._input.LA(1) - if not(_la==30 or _la==50): + if not(_la==31 or _la==52): self._errHandler.recoverInline(self) else: self._errHandler.reportMatch(self) self.consume() - self.state = 646 + self.state = 654 self._errHandler.sync(self) _la = self._input.LA(1) if _la==16: - self.state = 644 + self.state = 652 self.match(HogQLParser.COLLATE) - self.state = 645 + self.state = 653 self.match(HogQLParser.STRING_LITERAL) @@ -4729,27 +4797,27 @@ def accept(self, visitor:ParseTreeVisitor): def ratioExpr(self): localctx = HogQLParser.RatioExprContext(self, self._ctx, self.state) - self.enterRule(localctx, 92, self.RULE_ratioExpr) + self.enterRule(localctx, 94, self.RULE_ratioExpr) try: - self.state = 654 + self.state = 662 self._errHandler.sync(self) token = self._input.LA(1) - if token in [129]: + if token in [131]: self.enterOuterAlt(localctx, 1) - self.state = 648 + self.state = 656 self.placeholder() pass - elif token in [44, 58, 107, 108, 109, 110, 119, 121, 140]: + elif token in [45, 60, 109, 110, 111, 112, 121, 123, 142]: self.enterOuterAlt(localctx, 2) - self.state = 649 + self.state = 657 self.numberLiteral() - self.state = 652 + self.state = 660 self._errHandler.sync(self) - la_ = self._interp.adaptivePredict(self._input,81,self._ctx) + la_ = self._interp.adaptivePredict(self._input,82,self._ctx) if la_ == 1: - self.state = 650 + self.state = 658 self.match(HogQLParser.SLASH) - self.state = 651 + self.state = 659 self.numberLiteral() @@ -4801,21 +4869,21 @@ def accept(self, visitor:ParseTreeVisitor): def settingExprList(self): localctx = HogQLParser.SettingExprListContext(self, self._ctx, self.state) - self.enterRule(localctx, 94, self.RULE_settingExprList) + self.enterRule(localctx, 96, self.RULE_settingExprList) self._la = 0 # Token type try: self.enterOuterAlt(localctx, 1) - self.state = 656 + self.state = 664 self.settingExpr() - self.state = 661 + self.state = 669 self._errHandler.sync(self) _la = self._input.LA(1) - while _la==117: - self.state = 657 + while _la==119: + self.state = 665 self.match(HogQLParser.COMMA) - self.state = 658 + self.state = 666 self.settingExpr() - self.state = 663 + self.state = 671 self._errHandler.sync(self) _la = self._input.LA(1) @@ -4861,14 +4929,14 @@ def accept(self, visitor:ParseTreeVisitor): def settingExpr(self): localctx = HogQLParser.SettingExprContext(self, self._ctx, self.state) - self.enterRule(localctx, 96, self.RULE_settingExpr) + self.enterRule(localctx, 98, self.RULE_settingExpr) try: self.enterOuterAlt(localctx, 1) - self.state = 664 + self.state = 672 self.identifier() - self.state = 665 + self.state = 673 self.match(HogQLParser.EQ_SINGLE) - self.state = 666 + self.state = 674 self.literal() except RecognitionException as re: localctx.exception = re @@ -4913,31 +4981,31 @@ def accept(self, visitor:ParseTreeVisitor): def windowExpr(self): localctx = HogQLParser.WindowExprContext(self, self._ctx, self.state) - self.enterRule(localctx, 98, self.RULE_windowExpr) + self.enterRule(localctx, 100, self.RULE_windowExpr) self._la = 0 # Token type try: self.enterOuterAlt(localctx, 1) - self.state = 669 + self.state = 677 self._errHandler.sync(self) _la = self._input.LA(1) - if _la==68: - self.state = 668 + if _la==70: + self.state = 676 self.winPartitionByClause() - self.state = 672 + self.state = 680 self._errHandler.sync(self) _la = self._input.LA(1) - if _la==65: - self.state = 671 + if _la==67: + self.state = 679 self.winOrderByClause() - self.state = 675 + self.state = 683 self._errHandler.sync(self) _la = self._input.LA(1) - if _la==72 or _la==77: - self.state = 674 + if _la==74 or _la==79: + self.state = 682 self.winFrameClause() @@ -4982,14 +5050,14 @@ def accept(self, visitor:ParseTreeVisitor): def winPartitionByClause(self): localctx = HogQLParser.WinPartitionByClauseContext(self, self._ctx, self.state) - self.enterRule(localctx, 100, self.RULE_winPartitionByClause) + self.enterRule(localctx, 102, self.RULE_winPartitionByClause) try: self.enterOuterAlt(localctx, 1) - self.state = 677 + self.state = 685 self.match(HogQLParser.PARTITION) - self.state = 678 + self.state = 686 self.match(HogQLParser.BY) - self.state = 679 + self.state = 687 self.columnExprList() except RecognitionException as re: localctx.exception = re @@ -5032,14 +5100,14 @@ def accept(self, visitor:ParseTreeVisitor): def winOrderByClause(self): localctx = HogQLParser.WinOrderByClauseContext(self, self._ctx, self.state) - self.enterRule(localctx, 102, self.RULE_winOrderByClause) + self.enterRule(localctx, 104, self.RULE_winOrderByClause) try: self.enterOuterAlt(localctx, 1) - self.state = 681 + self.state = 689 self.match(HogQLParser.ORDER) - self.state = 682 + self.state = 690 self.match(HogQLParser.BY) - self.state = 683 + self.state = 691 self.orderExprList() except RecognitionException as re: localctx.exception = re @@ -5082,18 +5150,18 @@ def accept(self, visitor:ParseTreeVisitor): def winFrameClause(self): localctx = HogQLParser.WinFrameClauseContext(self, self._ctx, self.state) - self.enterRule(localctx, 104, self.RULE_winFrameClause) + self.enterRule(localctx, 106, self.RULE_winFrameClause) self._la = 0 # Token type try: self.enterOuterAlt(localctx, 1) - self.state = 685 + self.state = 693 _la = self._input.LA(1) - if not(_la==72 or _la==77): + if not(_la==74 or _la==79): self._errHandler.recoverInline(self) else: self._errHandler.reportMatch(self) self.consume() - self.state = 686 + self.state = 694 self.winFrameExtend() except RecognitionException as re: localctx.exception = re @@ -5166,27 +5234,27 @@ def accept(self, visitor:ParseTreeVisitor): def winFrameExtend(self): localctx = HogQLParser.WinFrameExtendContext(self, self._ctx, self.state) - self.enterRule(localctx, 106, self.RULE_winFrameExtend) + self.enterRule(localctx, 108, self.RULE_winFrameExtend) try: - self.state = 694 + self.state = 702 self._errHandler.sync(self) token = self._input.LA(1) - if token in [19, 44, 58, 95, 107, 108, 109, 110, 119, 121, 140]: + if token in [19, 45, 60, 97, 109, 110, 111, 112, 121, 123, 142]: localctx = HogQLParser.FrameStartContext(self, localctx) self.enterOuterAlt(localctx, 1) - self.state = 688 + self.state = 696 self.winFrameBound() pass elif token in [9]: localctx = HogQLParser.FrameBetweenContext(self, localctx) self.enterOuterAlt(localctx, 2) - self.state = 689 + self.state = 697 self.match(HogQLParser.BETWEEN) - self.state = 690 + self.state = 698 self.winFrameBound() - self.state = 691 + self.state = 699 self.match(HogQLParser.AND) - self.state = 692 + self.state = 700 self.winFrameBound() pass else: @@ -5242,44 +5310,44 @@ def accept(self, visitor:ParseTreeVisitor): def winFrameBound(self): localctx = HogQLParser.WinFrameBoundContext(self, self._ctx, self.state) - self.enterRule(localctx, 108, self.RULE_winFrameBound) + self.enterRule(localctx, 110, self.RULE_winFrameBound) try: self.enterOuterAlt(localctx, 1) - self.state = 708 + self.state = 716 self._errHandler.sync(self) - la_ = self._interp.adaptivePredict(self._input,88,self._ctx) + la_ = self._interp.adaptivePredict(self._input,89,self._ctx) if la_ == 1: - self.state = 696 + self.state = 704 self.match(HogQLParser.CURRENT) - self.state = 697 + self.state = 705 self.match(HogQLParser.ROW) pass elif la_ == 2: - self.state = 698 + self.state = 706 self.match(HogQLParser.UNBOUNDED) - self.state = 699 + self.state = 707 self.match(HogQLParser.PRECEDING) pass elif la_ == 3: - self.state = 700 + self.state = 708 self.match(HogQLParser.UNBOUNDED) - self.state = 701 + self.state = 709 self.match(HogQLParser.FOLLOWING) pass elif la_ == 4: - self.state = 702 + self.state = 710 self.numberLiteral() - self.state = 703 + self.state = 711 self.match(HogQLParser.PRECEDING) pass elif la_ == 5: - self.state = 705 + self.state = 713 self.numberLiteral() - self.state = 706 + self.state = 714 self.match(HogQLParser.FOLLOWING) pass @@ -5322,12 +5390,12 @@ def accept(self, visitor:ParseTreeVisitor): def expr(self): localctx = HogQLParser.ExprContext(self, self._ctx, self.state) - self.enterRule(localctx, 110, self.RULE_expr) + self.enterRule(localctx, 112, self.RULE_expr) try: self.enterOuterAlt(localctx, 1) - self.state = 710 + self.state = 718 self.columnExpr(0) - self.state = 711 + self.state = 719 self.match(HogQLParser.EOF) except RecognitionException as re: localctx.exception = re @@ -5499,141 +5567,141 @@ def accept(self, visitor:ParseTreeVisitor): def columnTypeExpr(self): localctx = HogQLParser.ColumnTypeExprContext(self, self._ctx, self.state) - self.enterRule(localctx, 112, self.RULE_columnTypeExpr) + self.enterRule(localctx, 114, self.RULE_columnTypeExpr) self._la = 0 # Token type try: - self.state = 769 + self.state = 777 self._errHandler.sync(self) - la_ = self._interp.adaptivePredict(self._input,96,self._ctx) + la_ = self._interp.adaptivePredict(self._input,97,self._ctx) if la_ == 1: localctx = HogQLParser.ColumnTypeExprSimpleContext(self, localctx) self.enterOuterAlt(localctx, 1) - self.state = 713 + self.state = 721 self.identifier() pass elif la_ == 2: localctx = HogQLParser.ColumnTypeExprNestedContext(self, localctx) self.enterOuterAlt(localctx, 2) - self.state = 714 + self.state = 722 self.identifier() - self.state = 715 + self.state = 723 self.match(HogQLParser.LPAREN) - self.state = 716 + self.state = 724 self.identifier() - self.state = 717 + self.state = 725 self.columnTypeExpr() - self.state = 724 + self.state = 732 self._errHandler.sync(self) - _alt = self._interp.adaptivePredict(self._input,89,self._ctx) + _alt = self._interp.adaptivePredict(self._input,90,self._ctx) while _alt!=2 and _alt!=ATN.INVALID_ALT_NUMBER: if _alt==1: - self.state = 718 + self.state = 726 self.match(HogQLParser.COMMA) - self.state = 719 + self.state = 727 self.identifier() - self.state = 720 + self.state = 728 self.columnTypeExpr() - self.state = 726 + self.state = 734 self._errHandler.sync(self) - _alt = self._interp.adaptivePredict(self._input,89,self._ctx) + _alt = self._interp.adaptivePredict(self._input,90,self._ctx) - self.state = 728 + self.state = 736 self._errHandler.sync(self) _la = self._input.LA(1) - if _la==117: - self.state = 727 + if _la==119: + self.state = 735 self.match(HogQLParser.COMMA) - self.state = 730 + self.state = 738 self.match(HogQLParser.RPAREN) pass elif la_ == 3: localctx = HogQLParser.ColumnTypeExprEnumContext(self, localctx) self.enterOuterAlt(localctx, 3) - self.state = 732 + self.state = 740 self.identifier() - self.state = 733 + self.state = 741 self.match(HogQLParser.LPAREN) - self.state = 734 + self.state = 742 self.enumValue() - self.state = 739 + self.state = 747 self._errHandler.sync(self) - _alt = self._interp.adaptivePredict(self._input,91,self._ctx) + _alt = self._interp.adaptivePredict(self._input,92,self._ctx) while _alt!=2 and _alt!=ATN.INVALID_ALT_NUMBER: if _alt==1: - self.state = 735 + self.state = 743 self.match(HogQLParser.COMMA) - self.state = 736 + self.state = 744 self.enumValue() - self.state = 741 + self.state = 749 self._errHandler.sync(self) - _alt = self._interp.adaptivePredict(self._input,91,self._ctx) + _alt = self._interp.adaptivePredict(self._input,92,self._ctx) - self.state = 743 + self.state = 751 self._errHandler.sync(self) _la = self._input.LA(1) - if _la==117: - self.state = 742 + if _la==119: + self.state = 750 self.match(HogQLParser.COMMA) - self.state = 745 + self.state = 753 self.match(HogQLParser.RPAREN) pass elif la_ == 4: localctx = HogQLParser.ColumnTypeExprComplexContext(self, localctx) self.enterOuterAlt(localctx, 4) - self.state = 747 + self.state = 755 self.identifier() - self.state = 748 + self.state = 756 self.match(HogQLParser.LPAREN) - self.state = 749 + self.state = 757 self.columnTypeExpr() - self.state = 754 + self.state = 762 self._errHandler.sync(self) - _alt = self._interp.adaptivePredict(self._input,93,self._ctx) + _alt = self._interp.adaptivePredict(self._input,94,self._ctx) while _alt!=2 and _alt!=ATN.INVALID_ALT_NUMBER: if _alt==1: - self.state = 750 + self.state = 758 self.match(HogQLParser.COMMA) - self.state = 751 + self.state = 759 self.columnTypeExpr() - self.state = 756 + self.state = 764 self._errHandler.sync(self) - _alt = self._interp.adaptivePredict(self._input,93,self._ctx) + _alt = self._interp.adaptivePredict(self._input,94,self._ctx) - self.state = 758 + self.state = 766 self._errHandler.sync(self) _la = self._input.LA(1) - if _la==117: - self.state = 757 + if _la==119: + self.state = 765 self.match(HogQLParser.COMMA) - self.state = 760 + self.state = 768 self.match(HogQLParser.RPAREN) pass elif la_ == 5: localctx = HogQLParser.ColumnTypeExprParamContext(self, localctx) self.enterOuterAlt(localctx, 5) - self.state = 762 + self.state = 770 self.identifier() - self.state = 763 + self.state = 771 self.match(HogQLParser.LPAREN) - self.state = 765 + self.state = 773 self._errHandler.sync(self) _la = self._input.LA(1) - if (((_la) & ~0x3f) == 0 and ((1 << _la) & -9007270658588674) != 0) or ((((_la - 64)) & ~0x3f) == 0 and ((1 << (_la - 64)) & 180986072486903807) != 0) or ((((_la - 129)) & ~0x3f) == 0 and ((1 << (_la - 129)) & 18455) != 0): - self.state = 764 + if (((_la) & ~0x3f) == 0 and ((1 << _la) & -36169677449216002) != 0) or ((((_la - 64)) & ~0x3f) == 0 and ((1 << (_la - 64)) & 723944289947615231) != 0) or ((((_la - 131)) & ~0x3f) == 0 and ((1 << (_la - 131)) & 18455) != 0): + self.state = 772 self.columnExprList() - self.state = 767 + self.state = 775 self.match(HogQLParser.RPAREN) pass @@ -5682,29 +5750,29 @@ def accept(self, visitor:ParseTreeVisitor): def columnExprList(self): localctx = HogQLParser.ColumnExprListContext(self, self._ctx, self.state) - self.enterRule(localctx, 114, self.RULE_columnExprList) + self.enterRule(localctx, 116, self.RULE_columnExprList) try: self.enterOuterAlt(localctx, 1) - self.state = 771 + self.state = 779 self.columnExpr(0) - self.state = 776 + self.state = 784 self._errHandler.sync(self) - _alt = self._interp.adaptivePredict(self._input,97,self._ctx) + _alt = self._interp.adaptivePredict(self._input,98,self._ctx) while _alt!=2 and _alt!=ATN.INVALID_ALT_NUMBER: if _alt==1: - self.state = 772 + self.state = 780 self.match(HogQLParser.COMMA) - self.state = 773 + self.state = 781 self.columnExpr(0) - self.state = 778 + self.state = 786 self._errHandler.sync(self) - _alt = self._interp.adaptivePredict(self._input,97,self._ctx) + _alt = self._interp.adaptivePredict(self._input,98,self._ctx) - self.state = 780 + self.state = 788 self._errHandler.sync(self) - la_ = self._interp.adaptivePredict(self._input,98,self._ctx) + la_ = self._interp.adaptivePredict(self._input,99,self._ctx) if la_ == 1: - self.state = 779 + self.state = 787 self.match(HogQLParser.COMMA) @@ -5829,8 +5897,8 @@ def __init__(self, parser, ctx:ParserRuleContext): # actually a HogQLParser.Colu def LPAREN(self): return self.getToken(HogQLParser.LPAREN, 0) - def selectUnionStmt(self): - return self.getTypedRuleContext(HogQLParser.SelectUnionStmtContext,0) + def selectSetStmt(self): + return self.getTypedRuleContext(HogQLParser.SelectSetStmtContext,0) def RPAREN(self): return self.getToken(HogQLParser.RPAREN, 0) @@ -6739,58 +6807,58 @@ def columnExpr(self, _p:int=0): _parentState = self.state localctx = HogQLParser.ColumnExprContext(self, self._ctx, _parentState) _prevctx = localctx - _startState = 116 - self.enterRecursionRule(localctx, 116, self.RULE_columnExpr, _p) + _startState = 118 + self.enterRecursionRule(localctx, 118, self.RULE_columnExpr, _p) self._la = 0 # Token type try: self.enterOuterAlt(localctx, 1) - self.state = 932 + self.state = 940 self._errHandler.sync(self) - la_ = self._interp.adaptivePredict(self._input,118,self._ctx) + la_ = self._interp.adaptivePredict(self._input,119,self._ctx) if la_ == 1: localctx = HogQLParser.ColumnExprCaseContext(self, localctx) self._ctx = localctx _prevctx = localctx - self.state = 783 + self.state = 791 self.match(HogQLParser.CASE) - self.state = 785 + self.state = 793 self._errHandler.sync(self) - la_ = self._interp.adaptivePredict(self._input,99,self._ctx) + la_ = self._interp.adaptivePredict(self._input,100,self._ctx) if la_ == 1: - self.state = 784 + self.state = 792 localctx.caseExpr = self.columnExpr(0) - self.state = 792 + self.state = 800 self._errHandler.sync(self) _la = self._input.LA(1) while True: - self.state = 787 + self.state = 795 self.match(HogQLParser.WHEN) - self.state = 788 + self.state = 796 localctx.whenExpr = self.columnExpr(0) - self.state = 789 + self.state = 797 self.match(HogQLParser.THEN) - self.state = 790 + self.state = 798 localctx.thenExpr = self.columnExpr(0) - self.state = 794 + self.state = 802 self._errHandler.sync(self) _la = self._input.LA(1) - if not (_la==99): + if not (_la==101): break - self.state = 798 + self.state = 806 self._errHandler.sync(self) _la = self._input.LA(1) if _la==25: - self.state = 796 + self.state = 804 self.match(HogQLParser.ELSE) - self.state = 797 + self.state = 805 localctx.elseExpr = self.columnExpr(0) - self.state = 800 + self.state = 808 self.match(HogQLParser.END) pass @@ -6798,17 +6866,17 @@ def columnExpr(self, _p:int=0): localctx = HogQLParser.ColumnExprCastContext(self, localctx) self._ctx = localctx _prevctx = localctx - self.state = 802 + self.state = 810 self.match(HogQLParser.CAST) - self.state = 803 + self.state = 811 self.match(HogQLParser.LPAREN) - self.state = 804 + self.state = 812 self.columnExpr(0) - self.state = 805 + self.state = 813 self.match(HogQLParser.AS) - self.state = 806 + self.state = 814 self.columnTypeExpr() - self.state = 807 + self.state = 815 self.match(HogQLParser.RPAREN) pass @@ -6816,9 +6884,9 @@ def columnExpr(self, _p:int=0): localctx = HogQLParser.ColumnExprDateContext(self, localctx) self._ctx = localctx _prevctx = localctx - self.state = 809 + self.state = 817 self.match(HogQLParser.DATE) - self.state = 810 + self.state = 818 self.match(HogQLParser.STRING_LITERAL) pass @@ -6826,11 +6894,11 @@ def columnExpr(self, _p:int=0): localctx = HogQLParser.ColumnExprIntervalContext(self, localctx) self._ctx = localctx _prevctx = localctx - self.state = 811 + self.state = 819 self.match(HogQLParser.INTERVAL) - self.state = 812 + self.state = 820 self.columnExpr(0) - self.state = 813 + self.state = 821 self.interval() pass @@ -6838,27 +6906,27 @@ def columnExpr(self, _p:int=0): localctx = HogQLParser.ColumnExprSubstringContext(self, localctx) self._ctx = localctx _prevctx = localctx - self.state = 815 + self.state = 823 self.match(HogQLParser.SUBSTRING) - self.state = 816 + self.state = 824 self.match(HogQLParser.LPAREN) - self.state = 817 + self.state = 825 self.columnExpr(0) - self.state = 818 + self.state = 826 self.match(HogQLParser.FROM) - self.state = 819 + self.state = 827 self.columnExpr(0) - self.state = 822 + self.state = 830 self._errHandler.sync(self) _la = self._input.LA(1) - if _la==33: - self.state = 820 + if _la==34: + self.state = 828 self.match(HogQLParser.FOR) - self.state = 821 + self.state = 829 self.columnExpr(0) - self.state = 824 + self.state = 832 self.match(HogQLParser.RPAREN) pass @@ -6866,9 +6934,9 @@ def columnExpr(self, _p:int=0): localctx = HogQLParser.ColumnExprTimestampContext(self, localctx) self._ctx = localctx _prevctx = localctx - self.state = 826 + self.state = 834 self.match(HogQLParser.TIMESTAMP) - self.state = 827 + self.state = 835 self.match(HogQLParser.STRING_LITERAL) pass @@ -6876,24 +6944,24 @@ def columnExpr(self, _p:int=0): localctx = HogQLParser.ColumnExprTrimContext(self, localctx) self._ctx = localctx _prevctx = localctx - self.state = 828 + self.state = 836 self.match(HogQLParser.TRIM) - self.state = 829 + self.state = 837 self.match(HogQLParser.LPAREN) - self.state = 830 + self.state = 838 _la = self._input.LA(1) - if not(_la==10 or _la==51 or _la==91): + if not(_la==10 or _la==53 or _la==93): self._errHandler.recoverInline(self) else: self._errHandler.reportMatch(self) self.consume() - self.state = 831 + self.state = 839 self.string() - self.state = 832 + self.state = 840 self.match(HogQLParser.FROM) - self.state = 833 + self.state = 841 self.columnExpr(0) - self.state = 834 + self.state = 842 self.match(HogQLParser.RPAREN) pass @@ -6901,54 +6969,54 @@ def columnExpr(self, _p:int=0): localctx = HogQLParser.ColumnExprWinFunctionContext(self, localctx) self._ctx = localctx _prevctx = localctx - self.state = 836 + self.state = 844 self.identifier() - self.state = 837 + self.state = 845 self.match(HogQLParser.LPAREN) - self.state = 839 + self.state = 847 self._errHandler.sync(self) _la = self._input.LA(1) - if (((_la) & ~0x3f) == 0 and ((1 << _la) & -9007270658588674) != 0) or ((((_la - 64)) & ~0x3f) == 0 and ((1 << (_la - 64)) & 180986072486903807) != 0) or ((((_la - 129)) & ~0x3f) == 0 and ((1 << (_la - 129)) & 18455) != 0): - self.state = 838 + if (((_la) & ~0x3f) == 0 and ((1 << _la) & -36169677449216002) != 0) or ((((_la - 64)) & ~0x3f) == 0 and ((1 << (_la - 64)) & 723944289947615231) != 0) or ((((_la - 131)) & ~0x3f) == 0 and ((1 << (_la - 131)) & 18455) != 0): + self.state = 846 localctx.columnExprs = self.columnExprList() - self.state = 841 + self.state = 849 self.match(HogQLParser.RPAREN) - self.state = 851 + self.state = 859 self._errHandler.sync(self) _la = self._input.LA(1) - if _la==131: - self.state = 843 + if _la==133: + self.state = 851 self.match(HogQLParser.LPAREN) - self.state = 845 + self.state = 853 self._errHandler.sync(self) - la_ = self._interp.adaptivePredict(self._input,104,self._ctx) + la_ = self._interp.adaptivePredict(self._input,105,self._ctx) if la_ == 1: - self.state = 844 + self.state = 852 self.match(HogQLParser.DISTINCT) - self.state = 848 + self.state = 856 self._errHandler.sync(self) _la = self._input.LA(1) - if (((_la) & ~0x3f) == 0 and ((1 << _la) & -9007270658588674) != 0) or ((((_la - 64)) & ~0x3f) == 0 and ((1 << (_la - 64)) & 180986072486903807) != 0) or ((((_la - 129)) & ~0x3f) == 0 and ((1 << (_la - 129)) & 18455) != 0): - self.state = 847 + if (((_la) & ~0x3f) == 0 and ((1 << _la) & -36169677449216002) != 0) or ((((_la - 64)) & ~0x3f) == 0 and ((1 << (_la - 64)) & 723944289947615231) != 0) or ((((_la - 131)) & ~0x3f) == 0 and ((1 << (_la - 131)) & 18455) != 0): + self.state = 855 localctx.columnArgList = self.columnExprList() - self.state = 850 + self.state = 858 self.match(HogQLParser.RPAREN) - self.state = 853 + self.state = 861 self.match(HogQLParser.OVER) - self.state = 854 + self.state = 862 self.match(HogQLParser.LPAREN) - self.state = 855 + self.state = 863 self.windowExpr() - self.state = 856 + self.state = 864 self.match(HogQLParser.RPAREN) pass @@ -6956,50 +7024,50 @@ def columnExpr(self, _p:int=0): localctx = HogQLParser.ColumnExprWinFunctionTargetContext(self, localctx) self._ctx = localctx _prevctx = localctx - self.state = 858 + self.state = 866 self.identifier() - self.state = 859 + self.state = 867 self.match(HogQLParser.LPAREN) - self.state = 861 + self.state = 869 self._errHandler.sync(self) _la = self._input.LA(1) - if (((_la) & ~0x3f) == 0 and ((1 << _la) & -9007270658588674) != 0) or ((((_la - 64)) & ~0x3f) == 0 and ((1 << (_la - 64)) & 180986072486903807) != 0) or ((((_la - 129)) & ~0x3f) == 0 and ((1 << (_la - 129)) & 18455) != 0): - self.state = 860 + if (((_la) & ~0x3f) == 0 and ((1 << _la) & -36169677449216002) != 0) or ((((_la - 64)) & ~0x3f) == 0 and ((1 << (_la - 64)) & 723944289947615231) != 0) or ((((_la - 131)) & ~0x3f) == 0 and ((1 << (_la - 131)) & 18455) != 0): + self.state = 868 localctx.columnExprs = self.columnExprList() - self.state = 863 + self.state = 871 self.match(HogQLParser.RPAREN) - self.state = 873 + self.state = 881 self._errHandler.sync(self) _la = self._input.LA(1) - if _la==131: - self.state = 865 + if _la==133: + self.state = 873 self.match(HogQLParser.LPAREN) - self.state = 867 + self.state = 875 self._errHandler.sync(self) - la_ = self._interp.adaptivePredict(self._input,108,self._ctx) + la_ = self._interp.adaptivePredict(self._input,109,self._ctx) if la_ == 1: - self.state = 866 + self.state = 874 self.match(HogQLParser.DISTINCT) - self.state = 870 + self.state = 878 self._errHandler.sync(self) _la = self._input.LA(1) - if (((_la) & ~0x3f) == 0 and ((1 << _la) & -9007270658588674) != 0) or ((((_la - 64)) & ~0x3f) == 0 and ((1 << (_la - 64)) & 180986072486903807) != 0) or ((((_la - 129)) & ~0x3f) == 0 and ((1 << (_la - 129)) & 18455) != 0): - self.state = 869 + if (((_la) & ~0x3f) == 0 and ((1 << _la) & -36169677449216002) != 0) or ((((_la - 64)) & ~0x3f) == 0 and ((1 << (_la - 64)) & 723944289947615231) != 0) or ((((_la - 131)) & ~0x3f) == 0 and ((1 << (_la - 131)) & 18455) != 0): + self.state = 877 localctx.columnArgList = self.columnExprList() - self.state = 872 + self.state = 880 self.match(HogQLParser.RPAREN) - self.state = 875 + self.state = 883 self.match(HogQLParser.OVER) - self.state = 876 + self.state = 884 self.identifier() pass @@ -7007,45 +7075,45 @@ def columnExpr(self, _p:int=0): localctx = HogQLParser.ColumnExprFunctionContext(self, localctx) self._ctx = localctx _prevctx = localctx - self.state = 878 + self.state = 886 self.identifier() - self.state = 884 + self.state = 892 self._errHandler.sync(self) - la_ = self._interp.adaptivePredict(self._input,112,self._ctx) + la_ = self._interp.adaptivePredict(self._input,113,self._ctx) if la_ == 1: - self.state = 879 + self.state = 887 self.match(HogQLParser.LPAREN) - self.state = 881 + self.state = 889 self._errHandler.sync(self) _la = self._input.LA(1) - if (((_la) & ~0x3f) == 0 and ((1 << _la) & -9007270658588674) != 0) or ((((_la - 64)) & ~0x3f) == 0 and ((1 << (_la - 64)) & 180986072486903807) != 0) or ((((_la - 129)) & ~0x3f) == 0 and ((1 << (_la - 129)) & 18455) != 0): - self.state = 880 + if (((_la) & ~0x3f) == 0 and ((1 << _la) & -36169677449216002) != 0) or ((((_la - 64)) & ~0x3f) == 0 and ((1 << (_la - 64)) & 723944289947615231) != 0) or ((((_la - 131)) & ~0x3f) == 0 and ((1 << (_la - 131)) & 18455) != 0): + self.state = 888 localctx.columnExprs = self.columnExprList() - self.state = 883 + self.state = 891 self.match(HogQLParser.RPAREN) - self.state = 886 + self.state = 894 self.match(HogQLParser.LPAREN) - self.state = 888 + self.state = 896 self._errHandler.sync(self) - la_ = self._interp.adaptivePredict(self._input,113,self._ctx) + la_ = self._interp.adaptivePredict(self._input,114,self._ctx) if la_ == 1: - self.state = 887 + self.state = 895 self.match(HogQLParser.DISTINCT) - self.state = 891 + self.state = 899 self._errHandler.sync(self) _la = self._input.LA(1) - if (((_la) & ~0x3f) == 0 and ((1 << _la) & -9007270658588674) != 0) or ((((_la - 64)) & ~0x3f) == 0 and ((1 << (_la - 64)) & 180986072486903807) != 0) or ((((_la - 129)) & ~0x3f) == 0 and ((1 << (_la - 129)) & 18455) != 0): - self.state = 890 + if (((_la) & ~0x3f) == 0 and ((1 << _la) & -36169677449216002) != 0) or ((((_la - 64)) & ~0x3f) == 0 and ((1 << (_la - 64)) & 723944289947615231) != 0) or ((((_la - 131)) & ~0x3f) == 0 and ((1 << (_la - 131)) & 18455) != 0): + self.state = 898 localctx.columnArgList = self.columnExprList() - self.state = 893 + self.state = 901 self.match(HogQLParser.RPAREN) pass @@ -7053,7 +7121,7 @@ def columnExpr(self, _p:int=0): localctx = HogQLParser.ColumnExprTagElementContext(self, localctx) self._ctx = localctx _prevctx = localctx - self.state = 895 + self.state = 903 self.hogqlxTagElement() pass @@ -7061,7 +7129,7 @@ def columnExpr(self, _p:int=0): localctx = HogQLParser.ColumnExprTemplateStringContext(self, localctx) self._ctx = localctx _prevctx = localctx - self.state = 896 + self.state = 904 self.templateString() pass @@ -7069,7 +7137,7 @@ def columnExpr(self, _p:int=0): localctx = HogQLParser.ColumnExprLiteralContext(self, localctx) self._ctx = localctx _prevctx = localctx - self.state = 897 + self.state = 905 self.literal() pass @@ -7077,9 +7145,9 @@ def columnExpr(self, _p:int=0): localctx = HogQLParser.ColumnExprNegateContext(self, localctx) self._ctx = localctx _prevctx = localctx - self.state = 898 + self.state = 906 self.match(HogQLParser.DASH) - self.state = 899 + self.state = 907 self.columnExpr(20) pass @@ -7087,9 +7155,9 @@ def columnExpr(self, _p:int=0): localctx = HogQLParser.ColumnExprNotContext(self, localctx) self._ctx = localctx _prevctx = localctx - self.state = 900 + self.state = 908 self.match(HogQLParser.NOT) - self.state = 901 + self.state = 909 self.columnExpr(14) pass @@ -7097,17 +7165,17 @@ def columnExpr(self, _p:int=0): localctx = HogQLParser.ColumnExprAsteriskContext(self, localctx) self._ctx = localctx _prevctx = localctx - self.state = 905 + self.state = 913 self._errHandler.sync(self) _la = self._input.LA(1) - if (((_la) & ~0x3f) == 0 and ((1 << _la) & -1450176743603191810) != 0) or ((((_la - 64)) & ~0x3f) == 0 and ((1 << (_la - 64)) & 6458554974207) != 0): - self.state = 902 + if (((_la) & ~0x3f) == 0 and ((1 << _la) & -5800812384855539714) != 0) or ((((_la - 64)) & ~0x3f) == 0 and ((1 << (_la - 64)) & 25834219896831) != 0): + self.state = 910 self.tableIdentifier() - self.state = 903 + self.state = 911 self.match(HogQLParser.DOT) - self.state = 907 + self.state = 915 self.match(HogQLParser.ASTERISK) pass @@ -7115,11 +7183,11 @@ def columnExpr(self, _p:int=0): localctx = HogQLParser.ColumnExprSubqueryContext(self, localctx) self._ctx = localctx _prevctx = localctx - self.state = 908 + self.state = 916 self.match(HogQLParser.LPAREN) - self.state = 909 - self.selectUnionStmt() - self.state = 910 + self.state = 917 + self.selectSetStmt() + self.state = 918 self.match(HogQLParser.RPAREN) pass @@ -7127,11 +7195,11 @@ def columnExpr(self, _p:int=0): localctx = HogQLParser.ColumnExprParensContext(self, localctx) self._ctx = localctx _prevctx = localctx - self.state = 912 + self.state = 920 self.match(HogQLParser.LPAREN) - self.state = 913 + self.state = 921 self.columnExpr(0) - self.state = 914 + self.state = 922 self.match(HogQLParser.RPAREN) pass @@ -7139,11 +7207,11 @@ def columnExpr(self, _p:int=0): localctx = HogQLParser.ColumnExprTupleContext(self, localctx) self._ctx = localctx _prevctx = localctx - self.state = 916 + self.state = 924 self.match(HogQLParser.LPAREN) - self.state = 917 + self.state = 925 self.columnExprList() - self.state = 918 + self.state = 926 self.match(HogQLParser.RPAREN) pass @@ -7151,17 +7219,17 @@ def columnExpr(self, _p:int=0): localctx = HogQLParser.ColumnExprArrayContext(self, localctx) self._ctx = localctx _prevctx = localctx - self.state = 920 + self.state = 928 self.match(HogQLParser.LBRACKET) - self.state = 922 + self.state = 930 self._errHandler.sync(self) _la = self._input.LA(1) - if (((_la) & ~0x3f) == 0 and ((1 << _la) & -9007270658588674) != 0) or ((((_la - 64)) & ~0x3f) == 0 and ((1 << (_la - 64)) & 180986072486903807) != 0) or ((((_la - 129)) & ~0x3f) == 0 and ((1 << (_la - 129)) & 18455) != 0): - self.state = 921 + if (((_la) & ~0x3f) == 0 and ((1 << _la) & -36169677449216002) != 0) or ((((_la - 64)) & ~0x3f) == 0 and ((1 << (_la - 64)) & 723944289947615231) != 0) or ((((_la - 131)) & ~0x3f) == 0 and ((1 << (_la - 131)) & 18455) != 0): + self.state = 929 self.columnExprList() - self.state = 924 + self.state = 932 self.match(HogQLParser.RBRACKET) pass @@ -7169,17 +7237,17 @@ def columnExpr(self, _p:int=0): localctx = HogQLParser.ColumnExprDictContext(self, localctx) self._ctx = localctx _prevctx = localctx - self.state = 925 + self.state = 933 self.match(HogQLParser.LBRACE) - self.state = 927 + self.state = 935 self._errHandler.sync(self) _la = self._input.LA(1) - if (((_la) & ~0x3f) == 0 and ((1 << _la) & -9007270658588674) != 0) or ((((_la - 64)) & ~0x3f) == 0 and ((1 << (_la - 64)) & 180986072486903807) != 0) or ((((_la - 129)) & ~0x3f) == 0 and ((1 << (_la - 129)) & 18455) != 0): - self.state = 926 + if (((_la) & ~0x3f) == 0 and ((1 << _la) & -36169677449216002) != 0) or ((((_la - 64)) & ~0x3f) == 0 and ((1 << (_la - 64)) & 723944289947615231) != 0) or ((((_la - 131)) & ~0x3f) == 0 and ((1 << (_la - 131)) & 18455) != 0): + self.state = 934 self.kvPairList() - self.state = 929 + self.state = 937 self.match(HogQLParser.RBRACE) pass @@ -7187,7 +7255,7 @@ def columnExpr(self, _p:int=0): localctx = HogQLParser.ColumnExprLambdaContext(self, localctx) self._ctx = localctx _prevctx = localctx - self.state = 930 + self.state = 938 self.columnLambdaExpr() pass @@ -7195,50 +7263,50 @@ def columnExpr(self, _p:int=0): localctx = HogQLParser.ColumnExprIdentifierContext(self, localctx) self._ctx = localctx _prevctx = localctx - self.state = 931 + self.state = 939 self.columnIdentifier() pass self._ctx.stop = self._input.LT(-1) - self.state = 1044 + self.state = 1052 self._errHandler.sync(self) - _alt = self._interp.adaptivePredict(self._input,130,self._ctx) + _alt = self._interp.adaptivePredict(self._input,131,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 = 1042 + self.state = 1050 self._errHandler.sync(self) - la_ = self._interp.adaptivePredict(self._input,129,self._ctx) + la_ = self._interp.adaptivePredict(self._input,130,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 = 934 + self.state = 942 if not self.precpred(self._ctx, 19): from antlr4.error.Errors import FailedPredicateException raise FailedPredicateException(self, "self.precpred(self._ctx, 19)") - self.state = 938 + self.state = 946 self._errHandler.sync(self) token = self._input.LA(1) - if token in [113]: - self.state = 935 + if token in [115]: + self.state = 943 localctx.operator = self.match(HogQLParser.ASTERISK) pass - elif token in [152]: - self.state = 936 + elif token in [154]: + self.state = 944 localctx.operator = self.match(HogQLParser.SLASH) pass - elif token in [139]: - self.state = 937 + elif token in [141]: + self.state = 945 localctx.operator = self.match(HogQLParser.PERCENT) pass else: raise NoViableAltException(self) - self.state = 940 + self.state = 948 localctx.right = self.columnExpr(20) pass @@ -7246,29 +7314,29 @@ def columnExpr(self, _p:int=0): localctx = HogQLParser.ColumnExprPrecedence2Context(self, HogQLParser.ColumnExprContext(self, _parentctx, _parentState)) localctx.left = _prevctx self.pushNewRecursionContext(localctx, _startState, self.RULE_columnExpr) - self.state = 941 + self.state = 949 if not self.precpred(self._ctx, 18): from antlr4.error.Errors import FailedPredicateException raise FailedPredicateException(self, "self.precpred(self._ctx, 18)") - self.state = 945 + self.state = 953 self._errHandler.sync(self) token = self._input.LA(1) - if token in [140]: - self.state = 942 + if token in [142]: + self.state = 950 localctx.operator = self.match(HogQLParser.PLUS) pass - elif token in [119]: - self.state = 943 + elif token in [121]: + self.state = 951 localctx.operator = self.match(HogQLParser.DASH) pass - elif token in [118]: - self.state = 944 + elif token in [120]: + self.state = 952 localctx.operator = self.match(HogQLParser.CONCAT) pass else: raise NoViableAltException(self) - self.state = 947 + self.state = 955 localctx.right = self.columnExpr(19) pass @@ -7276,81 +7344,81 @@ def columnExpr(self, _p:int=0): localctx = HogQLParser.ColumnExprPrecedence3Context(self, HogQLParser.ColumnExprContext(self, _parentctx, _parentState)) localctx.left = _prevctx self.pushNewRecursionContext(localctx, _startState, self.RULE_columnExpr) - self.state = 948 + self.state = 956 if not self.precpred(self._ctx, 17): from antlr4.error.Errors import FailedPredicateException raise FailedPredicateException(self, "self.precpred(self._ctx, 17)") - self.state = 973 + self.state = 981 self._errHandler.sync(self) - la_ = self._interp.adaptivePredict(self._input,124,self._ctx) + la_ = self._interp.adaptivePredict(self._input,125,self._ctx) if la_ == 1: - self.state = 949 + self.state = 957 localctx.operator = self.match(HogQLParser.EQ_DOUBLE) pass elif la_ == 2: - self.state = 950 + self.state = 958 localctx.operator = self.match(HogQLParser.EQ_SINGLE) pass elif la_ == 3: - self.state = 951 + self.state = 959 localctx.operator = self.match(HogQLParser.NOT_EQ) pass elif la_ == 4: - self.state = 952 + self.state = 960 localctx.operator = self.match(HogQLParser.LT_EQ) pass elif la_ == 5: - self.state = 953 + self.state = 961 localctx.operator = self.match(HogQLParser.LT) pass elif la_ == 6: - self.state = 954 + self.state = 962 localctx.operator = self.match(HogQLParser.GT_EQ) pass elif la_ == 7: - self.state = 955 + self.state = 963 localctx.operator = self.match(HogQLParser.GT) pass elif la_ == 8: - self.state = 957 + self.state = 965 self._errHandler.sync(self) _la = self._input.LA(1) - if _la==59: - self.state = 956 + if _la==61: + self.state = 964 localctx.operator = self.match(HogQLParser.NOT) - self.state = 959 + self.state = 967 self.match(HogQLParser.IN) - self.state = 961 + self.state = 969 self._errHandler.sync(self) - la_ = self._interp.adaptivePredict(self._input,122,self._ctx) + la_ = self._interp.adaptivePredict(self._input,123,self._ctx) if la_ == 1: - self.state = 960 + self.state = 968 self.match(HogQLParser.COHORT) pass elif la_ == 9: - self.state = 964 + self.state = 972 self._errHandler.sync(self) _la = self._input.LA(1) - if _la==59: - self.state = 963 + if _la==61: + self.state = 971 localctx.operator = self.match(HogQLParser.NOT) - self.state = 966 + self.state = 974 _la = self._input.LA(1) - if not(_la==42 or _la==54): + if not(_la==43 or _la==56): self._errHandler.recoverInline(self) else: self._errHandler.reportMatch(self) @@ -7358,268 +7426,268 @@ def columnExpr(self, _p:int=0): pass elif la_ == 10: - self.state = 967 + self.state = 975 localctx.operator = self.match(HogQLParser.REGEX_SINGLE) pass elif la_ == 11: - self.state = 968 + self.state = 976 localctx.operator = self.match(HogQLParser.REGEX_DOUBLE) pass elif la_ == 12: - self.state = 969 + self.state = 977 localctx.operator = self.match(HogQLParser.NOT_REGEX) pass elif la_ == 13: - self.state = 970 + self.state = 978 localctx.operator = self.match(HogQLParser.IREGEX_SINGLE) pass elif la_ == 14: - self.state = 971 + self.state = 979 localctx.operator = self.match(HogQLParser.IREGEX_DOUBLE) pass elif la_ == 15: - self.state = 972 + self.state = 980 localctx.operator = self.match(HogQLParser.NOT_IREGEX) pass - self.state = 975 + self.state = 983 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 = 976 + self.state = 984 if not self.precpred(self._ctx, 15): from antlr4.error.Errors import FailedPredicateException raise FailedPredicateException(self, "self.precpred(self._ctx, 15)") - self.state = 977 + self.state = 985 self.match(HogQLParser.NULLISH) - self.state = 978 + self.state = 986 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 = 979 + self.state = 987 if not self.precpred(self._ctx, 13): from antlr4.error.Errors import FailedPredicateException raise FailedPredicateException(self, "self.precpred(self._ctx, 13)") - self.state = 980 + self.state = 988 self.match(HogQLParser.AND) - self.state = 981 + self.state = 989 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 = 982 + self.state = 990 if not self.precpred(self._ctx, 12): from antlr4.error.Errors import FailedPredicateException raise FailedPredicateException(self, "self.precpred(self._ctx, 12)") - self.state = 983 + self.state = 991 self.match(HogQLParser.OR) - self.state = 984 + self.state = 992 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 = 985 + self.state = 993 if not self.precpred(self._ctx, 11): from antlr4.error.Errors import FailedPredicateException raise FailedPredicateException(self, "self.precpred(self._ctx, 11)") - self.state = 987 + self.state = 995 self._errHandler.sync(self) _la = self._input.LA(1) - if _la==59: - self.state = 986 + if _la==61: + self.state = 994 self.match(HogQLParser.NOT) - self.state = 989 + self.state = 997 self.match(HogQLParser.BETWEEN) - self.state = 990 + self.state = 998 self.columnExpr(0) - self.state = 991 + self.state = 999 self.match(HogQLParser.AND) - self.state = 992 + self.state = 1000 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 = 994 + self.state = 1002 if not self.precpred(self._ctx, 10): from antlr4.error.Errors import FailedPredicateException raise FailedPredicateException(self, "self.precpred(self._ctx, 10)") - self.state = 995 + self.state = 1003 self.match(HogQLParser.QUERY) - self.state = 996 + self.state = 1004 self.columnExpr(0) - self.state = 997 + self.state = 1005 self.match(HogQLParser.COLON) - self.state = 998 + self.state = 1006 self.columnExpr(10) pass elif la_ == 9: localctx = HogQLParser.ColumnExprCallContext(self, HogQLParser.ColumnExprContext(self, _parentctx, _parentState)) self.pushNewRecursionContext(localctx, _startState, self.RULE_columnExpr) - self.state = 1000 + self.state = 1008 if not self.precpred(self._ctx, 30): from antlr4.error.Errors import FailedPredicateException raise FailedPredicateException(self, "self.precpred(self._ctx, 30)") - self.state = 1001 + self.state = 1009 self.match(HogQLParser.LPAREN) - self.state = 1003 + self.state = 1011 self._errHandler.sync(self) _la = self._input.LA(1) - if (((_la) & ~0x3f) == 0 and ((1 << _la) & -9007270658588674) != 0) or ((((_la - 64)) & ~0x3f) == 0 and ((1 << (_la - 64)) & 180986072486903807) != 0) or ((((_la - 129)) & ~0x3f) == 0 and ((1 << (_la - 129)) & 18455) != 0): - self.state = 1002 + if (((_la) & ~0x3f) == 0 and ((1 << _la) & -36169677449216002) != 0) or ((((_la - 64)) & ~0x3f) == 0 and ((1 << (_la - 64)) & 723944289947615231) != 0) or ((((_la - 131)) & ~0x3f) == 0 and ((1 << (_la - 131)) & 18455) != 0): + self.state = 1010 self.columnExprList() - self.state = 1005 + self.state = 1013 self.match(HogQLParser.RPAREN) pass elif la_ == 10: localctx = HogQLParser.ColumnExprArrayAccessContext(self, HogQLParser.ColumnExprContext(self, _parentctx, _parentState)) self.pushNewRecursionContext(localctx, _startState, self.RULE_columnExpr) - self.state = 1006 + self.state = 1014 if not self.precpred(self._ctx, 26): from antlr4.error.Errors import FailedPredicateException raise FailedPredicateException(self, "self.precpred(self._ctx, 26)") - self.state = 1007 + self.state = 1015 self.match(HogQLParser.LBRACKET) - self.state = 1008 + self.state = 1016 self.columnExpr(0) - self.state = 1009 + self.state = 1017 self.match(HogQLParser.RBRACKET) pass elif la_ == 11: localctx = HogQLParser.ColumnExprTupleAccessContext(self, HogQLParser.ColumnExprContext(self, _parentctx, _parentState)) self.pushNewRecursionContext(localctx, _startState, self.RULE_columnExpr) - self.state = 1011 + self.state = 1019 if not self.precpred(self._ctx, 25): from antlr4.error.Errors import FailedPredicateException raise FailedPredicateException(self, "self.precpred(self._ctx, 25)") - self.state = 1012 + self.state = 1020 self.match(HogQLParser.DOT) - self.state = 1013 + self.state = 1021 self.match(HogQLParser.DECIMAL_LITERAL) pass elif la_ == 12: localctx = HogQLParser.ColumnExprPropertyAccessContext(self, HogQLParser.ColumnExprContext(self, _parentctx, _parentState)) self.pushNewRecursionContext(localctx, _startState, self.RULE_columnExpr) - self.state = 1014 + self.state = 1022 if not self.precpred(self._ctx, 24): from antlr4.error.Errors import FailedPredicateException raise FailedPredicateException(self, "self.precpred(self._ctx, 24)") - self.state = 1015 + self.state = 1023 self.match(HogQLParser.DOT) - self.state = 1016 + self.state = 1024 self.identifier() pass elif la_ == 13: localctx = HogQLParser.ColumnExprNullArrayAccessContext(self, HogQLParser.ColumnExprContext(self, _parentctx, _parentState)) self.pushNewRecursionContext(localctx, _startState, self.RULE_columnExpr) - self.state = 1017 + self.state = 1025 if not self.precpred(self._ctx, 23): from antlr4.error.Errors import FailedPredicateException raise FailedPredicateException(self, "self.precpred(self._ctx, 23)") - self.state = 1018 + self.state = 1026 self.match(HogQLParser.NULL_PROPERTY) - self.state = 1019 + self.state = 1027 self.match(HogQLParser.LBRACKET) - self.state = 1020 + self.state = 1028 self.columnExpr(0) - self.state = 1021 + self.state = 1029 self.match(HogQLParser.RBRACKET) pass elif la_ == 14: localctx = HogQLParser.ColumnExprNullTupleAccessContext(self, HogQLParser.ColumnExprContext(self, _parentctx, _parentState)) self.pushNewRecursionContext(localctx, _startState, self.RULE_columnExpr) - self.state = 1023 + self.state = 1031 if not self.precpred(self._ctx, 22): from antlr4.error.Errors import FailedPredicateException raise FailedPredicateException(self, "self.precpred(self._ctx, 22)") - self.state = 1024 + self.state = 1032 self.match(HogQLParser.NULL_PROPERTY) - self.state = 1025 + self.state = 1033 self.match(HogQLParser.DECIMAL_LITERAL) pass elif la_ == 15: localctx = HogQLParser.ColumnExprNullPropertyAccessContext(self, HogQLParser.ColumnExprContext(self, _parentctx, _parentState)) self.pushNewRecursionContext(localctx, _startState, self.RULE_columnExpr) - self.state = 1026 + self.state = 1034 if not self.precpred(self._ctx, 21): from antlr4.error.Errors import FailedPredicateException raise FailedPredicateException(self, "self.precpred(self._ctx, 21)") - self.state = 1027 + self.state = 1035 self.match(HogQLParser.NULL_PROPERTY) - self.state = 1028 + self.state = 1036 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 + self.state = 1037 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.state = 1038 self.match(HogQLParser.IS) - self.state = 1032 + self.state = 1040 self._errHandler.sync(self) _la = self._input.LA(1) - if _la==59: - self.state = 1031 + if _la==61: + self.state = 1039 self.match(HogQLParser.NOT) - self.state = 1034 + self.state = 1042 self.match(HogQLParser.NULL_SQL) pass elif la_ == 17: localctx = HogQLParser.ColumnExprAliasContext(self, HogQLParser.ColumnExprContext(self, _parentctx, _parentState)) self.pushNewRecursionContext(localctx, _startState, self.RULE_columnExpr) - self.state = 1035 + self.state = 1043 if not self.precpred(self._ctx, 9): from antlr4.error.Errors import FailedPredicateException raise FailedPredicateException(self, "self.precpred(self._ctx, 9)") - self.state = 1040 + self.state = 1048 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: - self.state = 1036 + self.state = 1044 self.match(HogQLParser.AS) - self.state = 1037 + self.state = 1045 self.identifier() pass elif la_ == 2: - self.state = 1038 + self.state = 1046 self.match(HogQLParser.AS) - self.state = 1039 + self.state = 1047 self.match(HogQLParser.STRING_LITERAL) pass @@ -7627,9 +7695,9 @@ def columnExpr(self, _p:int=0): pass - self.state = 1046 + self.state = 1054 self._errHandler.sync(self) - _alt = self._interp.adaptivePredict(self._input,130,self._ctx) + _alt = self._interp.adaptivePredict(self._input,131,self._ctx) except RecognitionException as re: localctx.exception = re @@ -7692,89 +7760,89 @@ def accept(self, visitor:ParseTreeVisitor): def columnLambdaExpr(self): localctx = HogQLParser.ColumnLambdaExprContext(self, self._ctx, self.state) - self.enterRule(localctx, 118, self.RULE_columnLambdaExpr) + self.enterRule(localctx, 120, self.RULE_columnLambdaExpr) self._la = 0 # Token type try: self.enterOuterAlt(localctx, 1) - self.state = 1074 + self.state = 1082 self._errHandler.sync(self) - la_ = self._interp.adaptivePredict(self._input,135,self._ctx) + la_ = self._interp.adaptivePredict(self._input,136,self._ctx) if la_ == 1: - self.state = 1047 + self.state = 1055 self.match(HogQLParser.LPAREN) - self.state = 1048 + self.state = 1056 self.identifier() - self.state = 1053 + self.state = 1061 self._errHandler.sync(self) - _alt = self._interp.adaptivePredict(self._input,131,self._ctx) + _alt = self._interp.adaptivePredict(self._input,132,self._ctx) while _alt!=2 and _alt!=ATN.INVALID_ALT_NUMBER: if _alt==1: - self.state = 1049 + self.state = 1057 self.match(HogQLParser.COMMA) - self.state = 1050 + self.state = 1058 self.identifier() - self.state = 1055 + self.state = 1063 self._errHandler.sync(self) - _alt = self._interp.adaptivePredict(self._input,131,self._ctx) + _alt = self._interp.adaptivePredict(self._input,132,self._ctx) - self.state = 1057 + self.state = 1065 self._errHandler.sync(self) _la = self._input.LA(1) - if _la==117: - self.state = 1056 + if _la==119: + self.state = 1064 self.match(HogQLParser.COMMA) - self.state = 1059 + self.state = 1067 self.match(HogQLParser.RPAREN) pass elif la_ == 2: - self.state = 1061 + self.state = 1069 self.identifier() - self.state = 1066 + self.state = 1074 self._errHandler.sync(self) - _alt = self._interp.adaptivePredict(self._input,133,self._ctx) + _alt = self._interp.adaptivePredict(self._input,134,self._ctx) while _alt!=2 and _alt!=ATN.INVALID_ALT_NUMBER: if _alt==1: - self.state = 1062 + self.state = 1070 self.match(HogQLParser.COMMA) - self.state = 1063 + self.state = 1071 self.identifier() - self.state = 1068 + self.state = 1076 self._errHandler.sync(self) - _alt = self._interp.adaptivePredict(self._input,133,self._ctx) + _alt = self._interp.adaptivePredict(self._input,134,self._ctx) - self.state = 1070 + self.state = 1078 self._errHandler.sync(self) _la = self._input.LA(1) - if _la==117: - self.state = 1069 + if _la==119: + self.state = 1077 self.match(HogQLParser.COMMA) pass elif la_ == 3: - self.state = 1072 + self.state = 1080 self.match(HogQLParser.LPAREN) - self.state = 1073 + self.state = 1081 self.match(HogQLParser.RPAREN) pass - self.state = 1076 + self.state = 1084 self.match(HogQLParser.ARROW) - self.state = 1079 + self.state = 1087 self._errHandler.sync(self) - la_ = self._interp.adaptivePredict(self._input,136,self._ctx) + la_ = self._interp.adaptivePredict(self._input,137,self._ctx) if la_ == 1: - self.state = 1077 + self.state = 1085 self.columnExpr(0) pass elif la_ == 2: - self.state = 1078 + self.state = 1086 self.block() pass @@ -7886,77 +7954,77 @@ def accept(self, visitor:ParseTreeVisitor): def hogqlxTagElement(self): localctx = HogQLParser.HogqlxTagElementContext(self, self._ctx, self.state) - self.enterRule(localctx, 120, self.RULE_hogqlxTagElement) + self.enterRule(localctx, 122, self.RULE_hogqlxTagElement) self._la = 0 # Token type try: - self.state = 1113 + self.state = 1121 self._errHandler.sync(self) - la_ = self._interp.adaptivePredict(self._input,140,self._ctx) + la_ = self._interp.adaptivePredict(self._input,141,self._ctx) if la_ == 1: localctx = HogQLParser.HogqlxTagElementClosedContext(self, localctx) self.enterOuterAlt(localctx, 1) - self.state = 1081 + self.state = 1089 self.match(HogQLParser.LT) - self.state = 1082 + self.state = 1090 self.identifier() - self.state = 1086 + self.state = 1094 self._errHandler.sync(self) _la = self._input.LA(1) - while (((_la) & ~0x3f) == 0 and ((1 << _la) & -1450176743603191810) != 0) or ((((_la - 64)) & ~0x3f) == 0 and ((1 << (_la - 64)) & 6458554974207) != 0): - self.state = 1083 + while (((_la) & ~0x3f) == 0 and ((1 << _la) & -5800812384855539714) != 0) or ((((_la - 64)) & ~0x3f) == 0 and ((1 << (_la - 64)) & 25834219896831) != 0): + self.state = 1091 self.hogqlxTagAttribute() - self.state = 1088 + self.state = 1096 self._errHandler.sync(self) _la = self._input.LA(1) - self.state = 1089 + self.state = 1097 self.match(HogQLParser.SLASH) - self.state = 1090 + self.state = 1098 self.match(HogQLParser.GT) pass elif la_ == 2: localctx = HogQLParser.HogqlxTagElementNestedContext(self, localctx) self.enterOuterAlt(localctx, 2) - self.state = 1092 + self.state = 1100 self.match(HogQLParser.LT) - self.state = 1093 + self.state = 1101 self.identifier() - self.state = 1097 + self.state = 1105 self._errHandler.sync(self) _la = self._input.LA(1) - while (((_la) & ~0x3f) == 0 and ((1 << _la) & -1450176743603191810) != 0) or ((((_la - 64)) & ~0x3f) == 0 and ((1 << (_la - 64)) & 6458554974207) != 0): - self.state = 1094 + while (((_la) & ~0x3f) == 0 and ((1 << _la) & -5800812384855539714) != 0) or ((((_la - 64)) & ~0x3f) == 0 and ((1 << (_la - 64)) & 25834219896831) != 0): + self.state = 1102 self.hogqlxTagAttribute() - self.state = 1099 + self.state = 1107 self._errHandler.sync(self) _la = self._input.LA(1) - self.state = 1100 + self.state = 1108 self.match(HogQLParser.GT) - self.state = 1106 + self.state = 1114 self._errHandler.sync(self) - la_ = self._interp.adaptivePredict(self._input,139,self._ctx) + la_ = self._interp.adaptivePredict(self._input,140,self._ctx) if la_ == 1: - self.state = 1101 + self.state = 1109 self.hogqlxTagElement() elif la_ == 2: - self.state = 1102 + self.state = 1110 self.match(HogQLParser.LBRACE) - self.state = 1103 + self.state = 1111 self.columnExpr(0) - self.state = 1104 + self.state = 1112 self.match(HogQLParser.RBRACE) - self.state = 1108 + self.state = 1116 self.match(HogQLParser.LT) - self.state = 1109 + self.state = 1117 self.match(HogQLParser.SLASH) - self.state = 1110 + self.state = 1118 self.identifier() - self.state = 1111 + self.state = 1119 self.match(HogQLParser.GT) pass @@ -8013,38 +8081,38 @@ def accept(self, visitor:ParseTreeVisitor): def hogqlxTagAttribute(self): localctx = HogQLParser.HogqlxTagAttributeContext(self, self._ctx, self.state) - self.enterRule(localctx, 122, self.RULE_hogqlxTagAttribute) + self.enterRule(localctx, 124, self.RULE_hogqlxTagAttribute) try: - self.state = 1126 + self.state = 1134 self._errHandler.sync(self) - la_ = self._interp.adaptivePredict(self._input,141,self._ctx) + la_ = self._interp.adaptivePredict(self._input,142,self._ctx) if la_ == 1: self.enterOuterAlt(localctx, 1) - self.state = 1115 + self.state = 1123 self.identifier() - self.state = 1116 + self.state = 1124 self.match(HogQLParser.EQ_SINGLE) - self.state = 1117 + self.state = 1125 self.string() pass elif la_ == 2: self.enterOuterAlt(localctx, 2) - self.state = 1119 + self.state = 1127 self.identifier() - self.state = 1120 + self.state = 1128 self.match(HogQLParser.EQ_SINGLE) - self.state = 1121 + self.state = 1129 self.match(HogQLParser.LBRACE) - self.state = 1122 + self.state = 1130 self.columnExpr(0) - self.state = 1123 + self.state = 1131 self.match(HogQLParser.RBRACE) pass elif la_ == 3: self.enterOuterAlt(localctx, 3) - self.state = 1125 + self.state = 1133 self.identifier() pass @@ -8093,30 +8161,30 @@ def accept(self, visitor:ParseTreeVisitor): def withExprList(self): localctx = HogQLParser.WithExprListContext(self, self._ctx, self.state) - self.enterRule(localctx, 124, self.RULE_withExprList) + self.enterRule(localctx, 126, self.RULE_withExprList) self._la = 0 # Token type try: self.enterOuterAlt(localctx, 1) - self.state = 1128 + self.state = 1136 self.withExpr() - self.state = 1133 + self.state = 1141 self._errHandler.sync(self) - _alt = self._interp.adaptivePredict(self._input,142,self._ctx) + _alt = self._interp.adaptivePredict(self._input,143,self._ctx) while _alt!=2 and _alt!=ATN.INVALID_ALT_NUMBER: if _alt==1: - self.state = 1129 + self.state = 1137 self.match(HogQLParser.COMMA) - self.state = 1130 + self.state = 1138 self.withExpr() - self.state = 1135 + self.state = 1143 self._errHandler.sync(self) - _alt = self._interp.adaptivePredict(self._input,142,self._ctx) + _alt = self._interp.adaptivePredict(self._input,143,self._ctx) - self.state = 1137 + self.state = 1145 self._errHandler.sync(self) _la = self._input.LA(1) - if _la==117: - self.state = 1136 + if _la==119: + self.state = 1144 self.match(HogQLParser.COMMA) @@ -8181,8 +8249,8 @@ def AS(self): return self.getToken(HogQLParser.AS, 0) def LPAREN(self): return self.getToken(HogQLParser.LPAREN, 0) - def selectUnionStmt(self): - return self.getTypedRuleContext(HogQLParser.SelectUnionStmtContext,0) + def selectSetStmt(self): + return self.getTypedRuleContext(HogQLParser.SelectSetStmtContext,0) def RPAREN(self): return self.getToken(HogQLParser.RPAREN, 0) @@ -8198,34 +8266,34 @@ def accept(self, visitor:ParseTreeVisitor): def withExpr(self): localctx = HogQLParser.WithExprContext(self, self._ctx, self.state) - self.enterRule(localctx, 126, self.RULE_withExpr) + self.enterRule(localctx, 128, self.RULE_withExpr) try: - self.state = 1149 + self.state = 1157 self._errHandler.sync(self) - la_ = self._interp.adaptivePredict(self._input,144,self._ctx) + la_ = self._interp.adaptivePredict(self._input,145,self._ctx) if la_ == 1: localctx = HogQLParser.WithExprSubqueryContext(self, localctx) self.enterOuterAlt(localctx, 1) - self.state = 1139 + self.state = 1147 self.identifier() - self.state = 1140 + self.state = 1148 self.match(HogQLParser.AS) - self.state = 1141 + self.state = 1149 self.match(HogQLParser.LPAREN) - self.state = 1142 - self.selectUnionStmt() - self.state = 1143 + self.state = 1150 + self.selectSetStmt() + self.state = 1151 self.match(HogQLParser.RPAREN) pass elif la_ == 2: localctx = HogQLParser.WithExprColumnContext(self, localctx) self.enterOuterAlt(localctx, 2) - self.state = 1145 + self.state = 1153 self.columnExpr(0) - self.state = 1146 + self.state = 1154 self.match(HogQLParser.AS) - self.state = 1147 + self.state = 1155 self.identifier() pass @@ -8276,29 +8344,29 @@ def accept(self, visitor:ParseTreeVisitor): def columnIdentifier(self): localctx = HogQLParser.ColumnIdentifierContext(self, self._ctx, self.state) - self.enterRule(localctx, 128, self.RULE_columnIdentifier) + self.enterRule(localctx, 130, self.RULE_columnIdentifier) try: - self.state = 1158 + self.state = 1166 self._errHandler.sync(self) token = self._input.LA(1) - if token in [129]: + if token in [131]: self.enterOuterAlt(localctx, 1) - self.state = 1151 + self.state = 1159 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, 37, 38, 39, 40, 41, 42, 43, 45, 46, 47, 48, 49, 50, 51, 52, 54, 55, 56, 57, 59, 61, 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 81, 82, 83, 84, 86, 87, 88, 89, 90, 91, 92, 93, 95, 96, 97, 98, 99, 100, 102, 103, 104, 106]: + 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, 28, 29, 31, 33, 34, 35, 36, 38, 39, 40, 41, 42, 43, 44, 46, 48, 49, 50, 51, 52, 53, 54, 56, 57, 58, 59, 61, 63, 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 81, 82, 83, 84, 85, 86, 88, 89, 90, 91, 92, 93, 94, 95, 97, 98, 99, 100, 101, 102, 104, 105, 106, 108]: self.enterOuterAlt(localctx, 2) - self.state = 1155 + self.state = 1163 self._errHandler.sync(self) - la_ = self._interp.adaptivePredict(self._input,145,self._ctx) + la_ = self._interp.adaptivePredict(self._input,146,self._ctx) if la_ == 1: - self.state = 1152 + self.state = 1160 self.tableIdentifier() - self.state = 1153 + self.state = 1161 self.match(HogQLParser.DOT) - self.state = 1157 + self.state = 1165 self.nestedIdentifier() pass else: @@ -8348,23 +8416,23 @@ def accept(self, visitor:ParseTreeVisitor): def nestedIdentifier(self): localctx = HogQLParser.NestedIdentifierContext(self, self._ctx, self.state) - self.enterRule(localctx, 130, self.RULE_nestedIdentifier) + self.enterRule(localctx, 132, self.RULE_nestedIdentifier) try: self.enterOuterAlt(localctx, 1) - self.state = 1160 + self.state = 1168 self.identifier() - self.state = 1165 + self.state = 1173 self._errHandler.sync(self) - _alt = self._interp.adaptivePredict(self._input,147,self._ctx) + _alt = self._interp.adaptivePredict(self._input,148,self._ctx) while _alt!=2 and _alt!=ATN.INVALID_ALT_NUMBER: if _alt==1: - self.state = 1161 + self.state = 1169 self.match(HogQLParser.DOT) - self.state = 1162 + self.state = 1170 self.identifier() - self.state = 1167 + self.state = 1175 self._errHandler.sync(self) - _alt = self._interp.adaptivePredict(self._input,147,self._ctx) + _alt = self._interp.adaptivePredict(self._input,148,self._ctx) except RecognitionException as re: localctx.exception = re @@ -8450,8 +8518,8 @@ def __init__(self, parser, ctx:ParserRuleContext): # actually a HogQLParser.Tabl def LPAREN(self): return self.getToken(HogQLParser.LPAREN, 0) - def selectUnionStmt(self): - return self.getTypedRuleContext(HogQLParser.SelectUnionStmtContext,0) + def selectSetStmt(self): + return self.getTypedRuleContext(HogQLParser.SelectSetStmtContext,0) def RPAREN(self): return self.getToken(HogQLParser.RPAREN, 0) @@ -8511,19 +8579,19 @@ def tableExpr(self, _p:int=0): _parentState = self.state localctx = HogQLParser.TableExprContext(self, self._ctx, _parentState) _prevctx = localctx - _startState = 132 - self.enterRecursionRule(localctx, 132, self.RULE_tableExpr, _p) + _startState = 134 + self.enterRecursionRule(localctx, 134, self.RULE_tableExpr, _p) try: self.enterOuterAlt(localctx, 1) - self.state = 1177 + self.state = 1185 self._errHandler.sync(self) - la_ = self._interp.adaptivePredict(self._input,148,self._ctx) + la_ = self._interp.adaptivePredict(self._input,149,self._ctx) if la_ == 1: localctx = HogQLParser.TableExprIdentifierContext(self, localctx) self._ctx = localctx _prevctx = localctx - self.state = 1169 + self.state = 1177 self.tableIdentifier() pass @@ -8531,7 +8599,7 @@ def tableExpr(self, _p:int=0): localctx = HogQLParser.TableExprFunctionContext(self, localctx) self._ctx = localctx _prevctx = localctx - self.state = 1170 + self.state = 1178 self.tableFunctionExpr() pass @@ -8539,11 +8607,11 @@ def tableExpr(self, _p:int=0): localctx = HogQLParser.TableExprSubqueryContext(self, localctx) self._ctx = localctx _prevctx = localctx - self.state = 1171 + self.state = 1179 self.match(HogQLParser.LPAREN) - self.state = 1172 - self.selectUnionStmt() - self.state = 1173 + self.state = 1180 + self.selectSetStmt() + self.state = 1181 self.match(HogQLParser.RPAREN) pass @@ -8551,7 +8619,7 @@ def tableExpr(self, _p:int=0): localctx = HogQLParser.TableExprTagContext(self, localctx) self._ctx = localctx _prevctx = localctx - self.state = 1175 + self.state = 1183 self.hogqlxTagElement() pass @@ -8559,15 +8627,15 @@ def tableExpr(self, _p:int=0): localctx = HogQLParser.TableExprPlaceholderContext(self, localctx) self._ctx = localctx _prevctx = localctx - self.state = 1176 + self.state = 1184 self.placeholder() pass self._ctx.stop = self._input.LT(-1) - self.state = 1187 + self.state = 1195 self._errHandler.sync(self) - _alt = self._interp.adaptivePredict(self._input,150,self._ctx) + _alt = self._interp.adaptivePredict(self._input,151,self._ctx) while _alt!=2 and _alt!=ATN.INVALID_ALT_NUMBER: if _alt==1: if self._parseListeners is not None: @@ -8575,29 +8643,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 = 1179 + self.state = 1187 if not self.precpred(self._ctx, 3): from antlr4.error.Errors import FailedPredicateException raise FailedPredicateException(self, "self.precpred(self._ctx, 3)") - self.state = 1183 + self.state = 1191 self._errHandler.sync(self) token = self._input.LA(1) - if token in [20, 30, 40, 49, 106]: - self.state = 1180 + if token in [20, 31, 41, 51, 108]: + self.state = 1188 self.alias() pass elif token in [6]: - self.state = 1181 + self.state = 1189 self.match(HogQLParser.AS) - self.state = 1182 + self.state = 1190 self.identifier() pass else: raise NoViableAltException(self) - self.state = 1189 + self.state = 1197 self._errHandler.sync(self) - _alt = self._interp.adaptivePredict(self._input,150,self._ctx) + _alt = self._interp.adaptivePredict(self._input,151,self._ctx) except RecognitionException as re: localctx.exception = re @@ -8644,23 +8712,23 @@ def accept(self, visitor:ParseTreeVisitor): def tableFunctionExpr(self): localctx = HogQLParser.TableFunctionExprContext(self, self._ctx, self.state) - self.enterRule(localctx, 134, self.RULE_tableFunctionExpr) + self.enterRule(localctx, 136, self.RULE_tableFunctionExpr) self._la = 0 # Token type try: self.enterOuterAlt(localctx, 1) - self.state = 1190 + self.state = 1198 self.identifier() - self.state = 1191 + self.state = 1199 self.match(HogQLParser.LPAREN) - self.state = 1193 + self.state = 1201 self._errHandler.sync(self) _la = self._input.LA(1) - if (((_la) & ~0x3f) == 0 and ((1 << _la) & -9007270658588674) != 0) or ((((_la - 64)) & ~0x3f) == 0 and ((1 << (_la - 64)) & 180986072486903807) != 0) or ((((_la - 129)) & ~0x3f) == 0 and ((1 << (_la - 129)) & 18455) != 0): - self.state = 1192 + if (((_la) & ~0x3f) == 0 and ((1 << _la) & -36169677449216002) != 0) or ((((_la - 64)) & ~0x3f) == 0 and ((1 << (_la - 64)) & 723944289947615231) != 0) or ((((_la - 131)) & ~0x3f) == 0 and ((1 << (_la - 131)) & 18455) != 0): + self.state = 1200 self.tableArgList() - self.state = 1195 + self.state = 1203 self.match(HogQLParser.RPAREN) except RecognitionException as re: localctx.exception = re @@ -8704,20 +8772,20 @@ def accept(self, visitor:ParseTreeVisitor): def tableIdentifier(self): localctx = HogQLParser.TableIdentifierContext(self, self._ctx, self.state) - self.enterRule(localctx, 136, self.RULE_tableIdentifier) + self.enterRule(localctx, 138, self.RULE_tableIdentifier) try: self.enterOuterAlt(localctx, 1) - self.state = 1200 + self.state = 1208 self._errHandler.sync(self) - la_ = self._interp.adaptivePredict(self._input,152,self._ctx) + la_ = self._interp.adaptivePredict(self._input,153,self._ctx) if la_ == 1: - self.state = 1197 + self.state = 1205 self.databaseIdentifier() - self.state = 1198 + self.state = 1206 self.match(HogQLParser.DOT) - self.state = 1202 + self.state = 1210 self.identifier() except RecognitionException as re: localctx.exception = re @@ -8763,30 +8831,30 @@ def accept(self, visitor:ParseTreeVisitor): def tableArgList(self): localctx = HogQLParser.TableArgListContext(self, self._ctx, self.state) - self.enterRule(localctx, 138, self.RULE_tableArgList) + self.enterRule(localctx, 140, self.RULE_tableArgList) self._la = 0 # Token type try: self.enterOuterAlt(localctx, 1) - self.state = 1204 + self.state = 1212 self.columnExpr(0) - self.state = 1209 + self.state = 1217 self._errHandler.sync(self) - _alt = self._interp.adaptivePredict(self._input,153,self._ctx) + _alt = self._interp.adaptivePredict(self._input,154,self._ctx) while _alt!=2 and _alt!=ATN.INVALID_ALT_NUMBER: if _alt==1: - self.state = 1205 + self.state = 1213 self.match(HogQLParser.COMMA) - self.state = 1206 + self.state = 1214 self.columnExpr(0) - self.state = 1211 + self.state = 1219 self._errHandler.sync(self) - _alt = self._interp.adaptivePredict(self._input,153,self._ctx) + _alt = self._interp.adaptivePredict(self._input,154,self._ctx) - self.state = 1213 + self.state = 1221 self._errHandler.sync(self) _la = self._input.LA(1) - if _la==117: - self.state = 1212 + if _la==119: + self.state = 1220 self.match(HogQLParser.COMMA) @@ -8825,10 +8893,10 @@ def accept(self, visitor:ParseTreeVisitor): def databaseIdentifier(self): localctx = HogQLParser.DatabaseIdentifierContext(self, self._ctx, self.state) - self.enterRule(localctx, 140, self.RULE_databaseIdentifier) + self.enterRule(localctx, 142, self.RULE_databaseIdentifier) try: self.enterOuterAlt(localctx, 1) - self.state = 1215 + self.state = 1223 self.identifier() except RecognitionException as re: localctx.exception = re @@ -8876,42 +8944,42 @@ def accept(self, visitor:ParseTreeVisitor): def floatingLiteral(self): localctx = HogQLParser.FloatingLiteralContext(self, self._ctx, self.state) - self.enterRule(localctx, 142, self.RULE_floatingLiteral) + self.enterRule(localctx, 144, self.RULE_floatingLiteral) self._la = 0 # Token type try: - self.state = 1225 + self.state = 1233 self._errHandler.sync(self) token = self._input.LA(1) - if token in [107]: + if token in [109]: self.enterOuterAlt(localctx, 1) - self.state = 1217 + self.state = 1225 self.match(HogQLParser.FLOATING_LITERAL) pass - elif token in [121]: + elif token in [123]: self.enterOuterAlt(localctx, 2) - self.state = 1218 + self.state = 1226 self.match(HogQLParser.DOT) - self.state = 1219 + self.state = 1227 _la = self._input.LA(1) - if not(_la==108 or _la==109): + if not(_la==110 or _la==111): self._errHandler.recoverInline(self) else: self._errHandler.reportMatch(self) self.consume() pass - elif token in [109]: + elif token in [111]: self.enterOuterAlt(localctx, 3) - self.state = 1220 + self.state = 1228 self.match(HogQLParser.DECIMAL_LITERAL) - self.state = 1221 + self.state = 1229 self.match(HogQLParser.DOT) - self.state = 1223 + self.state = 1231 self._errHandler.sync(self) - la_ = self._interp.adaptivePredict(self._input,155,self._ctx) + la_ = self._interp.adaptivePredict(self._input,156,self._ctx) if la_ == 1: - self.state = 1222 + self.state = 1230 _la = self._input.LA(1) - if not(_la==108 or _la==109): + if not(_la==110 or _la==111): self._errHandler.recoverInline(self) else: self._errHandler.reportMatch(self) @@ -8978,53 +9046,53 @@ def accept(self, visitor:ParseTreeVisitor): def numberLiteral(self): localctx = HogQLParser.NumberLiteralContext(self, self._ctx, self.state) - self.enterRule(localctx, 144, self.RULE_numberLiteral) + self.enterRule(localctx, 146, self.RULE_numberLiteral) self._la = 0 # Token type try: self.enterOuterAlt(localctx, 1) - self.state = 1228 + self.state = 1236 self._errHandler.sync(self) _la = self._input.LA(1) - if _la==119 or _la==140: - self.state = 1227 + if _la==121 or _la==142: + self.state = 1235 _la = self._input.LA(1) - if not(_la==119 or _la==140): + if not(_la==121 or _la==142): self._errHandler.recoverInline(self) else: self._errHandler.reportMatch(self) self.consume() - self.state = 1236 + self.state = 1244 self._errHandler.sync(self) - la_ = self._interp.adaptivePredict(self._input,158,self._ctx) + la_ = self._interp.adaptivePredict(self._input,159,self._ctx) if la_ == 1: - self.state = 1230 + self.state = 1238 self.floatingLiteral() pass elif la_ == 2: - self.state = 1231 + self.state = 1239 self.match(HogQLParser.OCTAL_LITERAL) pass elif la_ == 3: - self.state = 1232 + self.state = 1240 self.match(HogQLParser.DECIMAL_LITERAL) pass elif la_ == 4: - self.state = 1233 + self.state = 1241 self.match(HogQLParser.HEXADECIMAL_LITERAL) pass elif la_ == 5: - self.state = 1234 + self.state = 1242 self.match(HogQLParser.INF) pass elif la_ == 6: - self.state = 1235 + self.state = 1243 self.match(HogQLParser.NAN_SQL) pass @@ -9070,24 +9138,24 @@ def accept(self, visitor:ParseTreeVisitor): def literal(self): localctx = HogQLParser.LiteralContext(self, self._ctx, self.state) - self.enterRule(localctx, 146, self.RULE_literal) + self.enterRule(localctx, 148, self.RULE_literal) try: - self.state = 1241 + self.state = 1249 self._errHandler.sync(self) token = self._input.LA(1) - if token in [44, 58, 107, 108, 109, 110, 119, 121, 140]: + if token in [45, 60, 109, 110, 111, 112, 121, 123, 142]: self.enterOuterAlt(localctx, 1) - self.state = 1238 + self.state = 1246 self.numberLiteral() pass - elif token in [111]: + elif token in [113]: self.enterOuterAlt(localctx, 2) - self.state = 1239 + self.state = 1247 self.match(HogQLParser.STRING_LITERAL) pass - elif token in [60]: + elif token in [62]: self.enterOuterAlt(localctx, 3) - self.state = 1240 + self.state = 1248 self.match(HogQLParser.NULL_SQL) pass else: @@ -9148,13 +9216,13 @@ def accept(self, visitor:ParseTreeVisitor): def interval(self): localctx = HogQLParser.IntervalContext(self, self._ctx, self.state) - self.enterRule(localctx, 148, self.RULE_interval) + self.enterRule(localctx, 150, self.RULE_interval) self._la = 0 # Token type try: self.enterOuterAlt(localctx, 1) - self.state = 1243 + self.state = 1251 _la = self._input.LA(1) - if not((((_la) & ~0x3f) == 0 and ((1 << _la) & 216173331871694848) != 0) or ((((_la - 71)) & ~0x3f) == 0 and ((1 << (_la - 71)) & 8724152577) != 0)): + if not((((_la) & ~0x3f) == 0 and ((1 << _la) & 864692227968860160) != 0) or ((((_la - 73)) & ~0x3f) == 0 and ((1 << (_la - 73)) & 8724152577) != 0)): self._errHandler.recoverInline(self) else: self._errHandler.reportMatch(self) @@ -9445,13 +9513,13 @@ def accept(self, visitor:ParseTreeVisitor): def keyword(self): localctx = HogQLParser.KeywordContext(self, self._ctx, self.state) - self.enterRule(localctx, 150, self.RULE_keyword) + self.enterRule(localctx, 152, self.RULE_keyword) self._la = 0 # Token type try: self.enterOuterAlt(localctx, 1) - self.state = 1245 + self.state = 1253 _la = self._input.LA(1) - if not((((_la) & ~0x3f) == 0 and ((1 << _la) & -1666350075474886658) != 0) or ((((_la - 64)) & ~0x3f) == 0 and ((1 << (_la - 64)) & 943816933247) != 0)): + if not((((_la) & ~0x3f) == 0 and ((1 << _la) & -6665504612824399874) != 0) or ((((_la - 64)) & ~0x3f) == 0 and ((1 << (_la - 64)) & 3775267732991) != 0)): self._errHandler.recoverInline(self) else: self._errHandler.reportMatch(self) @@ -9499,13 +9567,13 @@ def accept(self, visitor:ParseTreeVisitor): def keywordForAlias(self): localctx = HogQLParser.KeywordForAliasContext(self, self._ctx, self.state) - self.enterRule(localctx, 152, self.RULE_keywordForAlias) + self.enterRule(localctx, 154, self.RULE_keywordForAlias) self._la = 0 # Token type try: self.enterOuterAlt(localctx, 1) - self.state = 1247 + self.state = 1255 _la = self._input.LA(1) - if not((((_la) & ~0x3f) == 0 and ((1 << _la) & 564050539839488) != 0)): + if not((((_la) & ~0x3f) == 0 and ((1 << _la) & 2254000985473024) != 0)): self._errHandler.recoverInline(self) else: self._errHandler.reportMatch(self) @@ -9548,19 +9616,19 @@ def accept(self, visitor:ParseTreeVisitor): def alias(self): localctx = HogQLParser.AliasContext(self, self._ctx, self.state) - self.enterRule(localctx, 154, self.RULE_alias) + self.enterRule(localctx, 156, self.RULE_alias) try: - self.state = 1251 + self.state = 1259 self._errHandler.sync(self) token = self._input.LA(1) - if token in [106]: + if token in [108]: self.enterOuterAlt(localctx, 1) - self.state = 1249 + self.state = 1257 self.match(HogQLParser.IDENTIFIER) pass - elif token in [20, 30, 40, 49]: + elif token in [20, 31, 41, 51]: self.enterOuterAlt(localctx, 2) - self.state = 1250 + self.state = 1258 self.keywordForAlias() pass else: @@ -9608,24 +9676,24 @@ def accept(self, visitor:ParseTreeVisitor): def identifier(self): localctx = HogQLParser.IdentifierContext(self, self._ctx, self.state) - self.enterRule(localctx, 156, self.RULE_identifier) + self.enterRule(localctx, 158, self.RULE_identifier) try: - self.state = 1256 + self.state = 1264 self._errHandler.sync(self) token = self._input.LA(1) - if token in [106]: + if token in [108]: self.enterOuterAlt(localctx, 1) - self.state = 1253 + self.state = 1261 self.match(HogQLParser.IDENTIFIER) pass - elif token in [21, 39, 56, 57, 71, 79, 98, 104]: + elif token in [21, 40, 58, 59, 73, 81, 100, 106]: self.enterOuterAlt(localctx, 2) - self.state = 1254 + self.state = 1262 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, 37, 38, 40, 41, 42, 43, 45, 46, 47, 48, 49, 50, 51, 52, 54, 55, 59, 61, 62, 63, 64, 65, 66, 67, 68, 69, 70, 72, 73, 74, 75, 76, 77, 78, 80, 81, 82, 83, 84, 86, 87, 88, 89, 90, 91, 92, 93, 95, 96, 97, 99, 100, 102, 103]: + 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, 28, 29, 31, 33, 34, 35, 36, 38, 39, 41, 42, 43, 44, 46, 48, 49, 50, 51, 52, 53, 54, 56, 57, 61, 63, 64, 65, 66, 67, 68, 69, 70, 71, 72, 74, 75, 76, 77, 78, 79, 80, 82, 83, 84, 85, 86, 88, 89, 90, 91, 92, 93, 94, 95, 97, 98, 99, 101, 102, 104, 105]: self.enterOuterAlt(localctx, 3) - self.state = 1255 + self.state = 1263 self.keyword() pass else: @@ -9673,14 +9741,14 @@ def accept(self, visitor:ParseTreeVisitor): def enumValue(self): localctx = HogQLParser.EnumValueContext(self, self._ctx, self.state) - self.enterRule(localctx, 158, self.RULE_enumValue) + self.enterRule(localctx, 160, self.RULE_enumValue) try: self.enterOuterAlt(localctx, 1) - self.state = 1258 + self.state = 1266 self.string() - self.state = 1259 + self.state = 1267 self.match(HogQLParser.EQ_SINGLE) - self.state = 1260 + self.state = 1268 self.numberLiteral() except RecognitionException as re: localctx.exception = re @@ -9723,14 +9791,14 @@ def accept(self, visitor:ParseTreeVisitor): def placeholder(self): localctx = HogQLParser.PlaceholderContext(self, self._ctx, self.state) - self.enterRule(localctx, 160, self.RULE_placeholder) + self.enterRule(localctx, 162, self.RULE_placeholder) try: self.enterOuterAlt(localctx, 1) - self.state = 1262 + self.state = 1270 self.match(HogQLParser.LBRACE) - self.state = 1263 + self.state = 1271 self.columnExpr(0) - self.state = 1264 + self.state = 1272 self.match(HogQLParser.RBRACE) except RecognitionException as re: localctx.exception = re @@ -9770,19 +9838,19 @@ def accept(self, visitor:ParseTreeVisitor): def string(self): localctx = HogQLParser.StringContext(self, self._ctx, self.state) - self.enterRule(localctx, 162, self.RULE_string) + self.enterRule(localctx, 164, self.RULE_string) try: - self.state = 1268 + self.state = 1276 self._errHandler.sync(self) token = self._input.LA(1) - if token in [111]: + if token in [113]: self.enterOuterAlt(localctx, 1) - self.state = 1266 + self.state = 1274 self.match(HogQLParser.STRING_LITERAL) pass - elif token in [143]: + elif token in [145]: self.enterOuterAlt(localctx, 2) - self.state = 1267 + self.state = 1275 self.templateString() pass else: @@ -9832,23 +9900,23 @@ def accept(self, visitor:ParseTreeVisitor): def templateString(self): localctx = HogQLParser.TemplateStringContext(self, self._ctx, self.state) - self.enterRule(localctx, 164, self.RULE_templateString) + self.enterRule(localctx, 166, self.RULE_templateString) self._la = 0 # Token type try: self.enterOuterAlt(localctx, 1) - self.state = 1270 + self.state = 1278 self.match(HogQLParser.QUOTE_SINGLE_TEMPLATE) - self.state = 1274 + self.state = 1282 self._errHandler.sync(self) _la = self._input.LA(1) - while _la==157 or _la==158: - self.state = 1271 + while _la==159 or _la==160: + self.state = 1279 self.stringContents() - self.state = 1276 + self.state = 1284 self._errHandler.sync(self) _la = self._input.LA(1) - self.state = 1277 + self.state = 1285 self.match(HogQLParser.QUOTE_SINGLE) except RecognitionException as re: localctx.exception = re @@ -9894,23 +9962,23 @@ def accept(self, visitor:ParseTreeVisitor): def stringContents(self): localctx = HogQLParser.StringContentsContext(self, self._ctx, self.state) - self.enterRule(localctx, 166, self.RULE_stringContents) + self.enterRule(localctx, 168, self.RULE_stringContents) try: - self.state = 1284 + self.state = 1292 self._errHandler.sync(self) token = self._input.LA(1) - if token in [158]: + if token in [160]: self.enterOuterAlt(localctx, 1) - self.state = 1279 + self.state = 1287 self.match(HogQLParser.STRING_ESCAPE_TRIGGER) - self.state = 1280 + self.state = 1288 self.columnExpr(0) - self.state = 1281 + self.state = 1289 self.match(HogQLParser.RBRACE) pass - elif token in [157]: + elif token in [159]: self.enterOuterAlt(localctx, 2) - self.state = 1283 + self.state = 1291 self.match(HogQLParser.STRING_TEXT) pass else: @@ -9960,23 +10028,23 @@ def accept(self, visitor:ParseTreeVisitor): def fullTemplateString(self): localctx = HogQLParser.FullTemplateStringContext(self, self._ctx, self.state) - self.enterRule(localctx, 168, self.RULE_fullTemplateString) + self.enterRule(localctx, 170, self.RULE_fullTemplateString) self._la = 0 # Token type try: self.enterOuterAlt(localctx, 1) - self.state = 1286 + self.state = 1294 self.match(HogQLParser.QUOTE_SINGLE_TEMPLATE_FULL) - self.state = 1290 + self.state = 1298 self._errHandler.sync(self) _la = self._input.LA(1) - while _la==159 or _la==160: - self.state = 1287 + while _la==161 or _la==162: + self.state = 1295 self.stringContentsFull() - self.state = 1292 + self.state = 1300 self._errHandler.sync(self) _la = self._input.LA(1) - self.state = 1293 + self.state = 1301 self.match(HogQLParser.EOF) except RecognitionException as re: localctx.exception = re @@ -10022,23 +10090,23 @@ def accept(self, visitor:ParseTreeVisitor): def stringContentsFull(self): localctx = HogQLParser.StringContentsFullContext(self, self._ctx, self.state) - self.enterRule(localctx, 170, self.RULE_stringContentsFull) + self.enterRule(localctx, 172, self.RULE_stringContentsFull) try: - self.state = 1300 + self.state = 1308 self._errHandler.sync(self) token = self._input.LA(1) - if token in [160]: + if token in [162]: self.enterOuterAlt(localctx, 1) - self.state = 1295 + self.state = 1303 self.match(HogQLParser.FULL_STRING_ESCAPE_TRIGGER) - self.state = 1296 + self.state = 1304 self.columnExpr(0) - self.state = 1297 + self.state = 1305 self.match(HogQLParser.RBRACE) pass - elif token in [159]: + elif token in [161]: self.enterOuterAlt(localctx, 2) - self.state = 1299 + self.state = 1307 self.match(HogQLParser.FULL_STRING_TEXT) pass else: @@ -10057,9 +10125,9 @@ def stringContentsFull(self): def sempred(self, localctx:RuleContext, ruleIndex:int, predIndex:int): if self._predicates == None: self._predicates = dict() - self._predicates[39] = self.joinExpr_sempred - self._predicates[58] = self.columnExpr_sempred - self._predicates[66] = self.tableExpr_sempred + self._predicates[40] = self.joinExpr_sempred + self._predicates[59] = self.columnExpr_sempred + self._predicates[67] = self.tableExpr_sempred pred = self._predicates.get(ruleIndex, None) if pred is None: raise Exception("No predicate with index:" + str(ruleIndex)) diff --git a/posthog/hogql/grammar/HogQLParser.tokens b/posthog/hogql/grammar/HogQLParser.tokens index 8658dc473b899..f370b819d5a0d 100644 --- a/posthog/hogql/grammar/HogQLParser.tokens +++ b/posthog/hogql/grammar/HogQLParser.tokens @@ -24,178 +24,180 @@ DESCENDING=23 DISTINCT=24 ELSE=25 END=26 -EXTRACT=27 -FINAL=28 -FINALLY=29 -FIRST=30 -FN=31 -FOLLOWING=32 -FOR=33 -FROM=34 -FULL=35 -FUN=36 -GROUP=37 -HAVING=38 -HOUR=39 -ID=40 -IF=41 -ILIKE=42 -IN=43 -INF=44 -INNER=45 -INTERVAL=46 -IS=47 -JOIN=48 -KEY=49 -LAST=50 -LEADING=51 -LEFT=52 -LET=53 -LIKE=54 -LIMIT=55 -MINUTE=56 -MONTH=57 -NAN_SQL=58 -NOT=59 -NULL_SQL=60 -NULLS=61 -OFFSET=62 -ON=63 -OR=64 -ORDER=65 -OUTER=66 -OVER=67 -PARTITION=68 -PRECEDING=69 -PREWHERE=70 -QUARTER=71 -RANGE=72 -RETURN=73 -RIGHT=74 -ROLLUP=75 -ROW=76 -ROWS=77 -SAMPLE=78 -SECOND=79 -SELECT=80 -SEMI=81 -SETTINGS=82 -SUBSTRING=83 -THEN=84 -THROW=85 -TIES=86 -TIMESTAMP=87 -TO=88 -TOP=89 -TOTALS=90 -TRAILING=91 -TRIM=92 -TRUNCATE=93 -TRY=94 -UNBOUNDED=95 -UNION=96 -USING=97 -WEEK=98 -WHEN=99 -WHERE=100 -WHILE=101 -WINDOW=102 -WITH=103 -YEAR=104 -ESCAPE_CHAR_COMMON=105 -IDENTIFIER=106 -FLOATING_LITERAL=107 -OCTAL_LITERAL=108 -DECIMAL_LITERAL=109 -HEXADECIMAL_LITERAL=110 -STRING_LITERAL=111 -ARROW=112 -ASTERISK=113 -BACKQUOTE=114 -BACKSLASH=115 -COLON=116 -COMMA=117 -CONCAT=118 -DASH=119 -DOLLAR=120 -DOT=121 -EQ_DOUBLE=122 -EQ_SINGLE=123 -GT_EQ=124 -GT=125 -HASH=126 -IREGEX_SINGLE=127 -IREGEX_DOUBLE=128 -LBRACE=129 -LBRACKET=130 -LPAREN=131 -LT_EQ=132 -LT=133 -NOT_EQ=134 -NOT_IREGEX=135 -NOT_REGEX=136 -NULL_PROPERTY=137 -NULLISH=138 -PERCENT=139 -PLUS=140 -QUERY=141 -QUOTE_DOUBLE=142 -QUOTE_SINGLE_TEMPLATE=143 -QUOTE_SINGLE_TEMPLATE_FULL=144 -QUOTE_SINGLE=145 -REGEX_SINGLE=146 -REGEX_DOUBLE=147 -RBRACE=148 -RBRACKET=149 -RPAREN=150 -SEMICOLON=151 -SLASH=152 -UNDERSCORE=153 -MULTI_LINE_COMMENT=154 -SINGLE_LINE_COMMENT=155 -WHITESPACE=156 -STRING_TEXT=157 -STRING_ESCAPE_TRIGGER=158 -FULL_STRING_TEXT=159 -FULL_STRING_ESCAPE_TRIGGER=160 -'->'=112 -'*'=113 -'`'=114 -'\\'=115 -':'=116 -','=117 -'||'=118 -'-'=119 -'$'=120 -'.'=121 -'=='=122 -'='=123 -'>='=124 -'>'=125 -'#'=126 -'~*'=127 -'=~*'=128 -'{'=129 -'['=130 -'('=131 -'<='=132 -'<'=133 -'!~*'=135 -'!~'=136 -'?.'=137 -'??'=138 -'%'=139 -'+'=140 -'?'=141 -'"'=142 -'f\''=143 -'F\''=144 -'\''=145 -'~'=146 -'=~'=147 -'}'=148 -']'=149 -')'=150 -';'=151 -'/'=152 -'_'=153 +EXCEPT=27 +EXTRACT=28 +FINAL=29 +FINALLY=30 +FIRST=31 +FN=32 +FOLLOWING=33 +FOR=34 +FROM=35 +FULL=36 +FUN=37 +GROUP=38 +HAVING=39 +HOUR=40 +ID=41 +IF=42 +ILIKE=43 +IN=44 +INF=45 +INNER=46 +INTERSECT=47 +INTERVAL=48 +IS=49 +JOIN=50 +KEY=51 +LAST=52 +LEADING=53 +LEFT=54 +LET=55 +LIKE=56 +LIMIT=57 +MINUTE=58 +MONTH=59 +NAN_SQL=60 +NOT=61 +NULL_SQL=62 +NULLS=63 +OFFSET=64 +ON=65 +OR=66 +ORDER=67 +OUTER=68 +OVER=69 +PARTITION=70 +PRECEDING=71 +PREWHERE=72 +QUARTER=73 +RANGE=74 +RETURN=75 +RIGHT=76 +ROLLUP=77 +ROW=78 +ROWS=79 +SAMPLE=80 +SECOND=81 +SELECT=82 +SEMI=83 +SETTINGS=84 +SUBSTRING=85 +THEN=86 +THROW=87 +TIES=88 +TIMESTAMP=89 +TO=90 +TOP=91 +TOTALS=92 +TRAILING=93 +TRIM=94 +TRUNCATE=95 +TRY=96 +UNBOUNDED=97 +UNION=98 +USING=99 +WEEK=100 +WHEN=101 +WHERE=102 +WHILE=103 +WINDOW=104 +WITH=105 +YEAR=106 +ESCAPE_CHAR_COMMON=107 +IDENTIFIER=108 +FLOATING_LITERAL=109 +OCTAL_LITERAL=110 +DECIMAL_LITERAL=111 +HEXADECIMAL_LITERAL=112 +STRING_LITERAL=113 +ARROW=114 +ASTERISK=115 +BACKQUOTE=116 +BACKSLASH=117 +COLON=118 +COMMA=119 +CONCAT=120 +DASH=121 +DOLLAR=122 +DOT=123 +EQ_DOUBLE=124 +EQ_SINGLE=125 +GT_EQ=126 +GT=127 +HASH=128 +IREGEX_SINGLE=129 +IREGEX_DOUBLE=130 +LBRACE=131 +LBRACKET=132 +LPAREN=133 +LT_EQ=134 +LT=135 +NOT_EQ=136 +NOT_IREGEX=137 +NOT_REGEX=138 +NULL_PROPERTY=139 +NULLISH=140 +PERCENT=141 +PLUS=142 +QUERY=143 +QUOTE_DOUBLE=144 +QUOTE_SINGLE_TEMPLATE=145 +QUOTE_SINGLE_TEMPLATE_FULL=146 +QUOTE_SINGLE=147 +REGEX_SINGLE=148 +REGEX_DOUBLE=149 +RBRACE=150 +RBRACKET=151 +RPAREN=152 +SEMICOLON=153 +SLASH=154 +UNDERSCORE=155 +MULTI_LINE_COMMENT=156 +SINGLE_LINE_COMMENT=157 +WHITESPACE=158 +STRING_TEXT=159 +STRING_ESCAPE_TRIGGER=160 +FULL_STRING_TEXT=161 +FULL_STRING_ESCAPE_TRIGGER=162 +'->'=114 +'*'=115 +'`'=116 +'\\'=117 +':'=118 +','=119 +'||'=120 +'-'=121 +'$'=122 +'.'=123 +'=='=124 +'='=125 +'>='=126 +'>'=127 +'#'=128 +'~*'=129 +'=~*'=130 +'{'=131 +'['=132 +'('=133 +'<='=134 +'<'=135 +'!~*'=137 +'!~'=138 +'?.'=139 +'??'=140 +'%'=141 +'+'=142 +'?'=143 +'"'=144 +'f\''=145 +'F\''=146 +'\''=147 +'~'=148 +'=~'=149 +'}'=150 +']'=151 +')'=152 +';'=153 +'/'=154 +'_'=155 diff --git a/posthog/hogql/grammar/HogQLParserVisitor.py b/posthog/hogql/grammar/HogQLParserVisitor.py index be0ba9f0e29da..98cef12617913 100644 --- a/posthog/hogql/grammar/HogQLParserVisitor.py +++ b/posthog/hogql/grammar/HogQLParserVisitor.py @@ -119,13 +119,18 @@ def visitSelect(self, ctx:HogQLParser.SelectContext): return self.visitChildren(ctx) - # Visit a parse tree produced by HogQLParser#selectUnionStmt. - def visitSelectUnionStmt(self, ctx:HogQLParser.SelectUnionStmtContext): + # Visit a parse tree produced by HogQLParser#selectStmtWithParens. + def visitSelectStmtWithParens(self, ctx:HogQLParser.SelectStmtWithParensContext): return self.visitChildren(ctx) - # Visit a parse tree produced by HogQLParser#selectStmtWithParens. - def visitSelectStmtWithParens(self, ctx:HogQLParser.SelectStmtWithParensContext): + # Visit a parse tree produced by HogQLParser#subsequentSelectSetClause. + def visitSubsequentSelectSetClause(self, ctx:HogQLParser.SubsequentSelectSetClauseContext): + return self.visitChildren(ctx) + + + # Visit a parse tree produced by HogQLParser#selectSetStmt. + def visitSelectSetStmt(self, ctx:HogQLParser.SelectSetStmtContext): return self.visitChildren(ctx) diff --git a/posthog/hogql/metadata.py b/posthog/hogql/metadata.py index 34730b7b1a19b..fdfaa8bcde774 100644 --- a/posthog/hogql/metadata.py +++ b/posthog/hogql/metadata.py @@ -13,6 +13,7 @@ from posthog.hogql.visitor import clone_expr from posthog.hogql_queries.query_runner import get_query_runner from posthog.models import Team +from posthog.hogql.resolver_utils import extract_select_queries from posthog.schema import HogQLMetadataResponse, HogQLMetadata, HogQLNotice, HogLanguage from posthog.hogql import ast @@ -99,7 +100,7 @@ def get_hogql_metadata( def process_expr_on_table( node: ast.Expr, context: HogQLContext, - source_query: Optional[ast.SelectQuery | ast.SelectUnionQuery] = None, + source_query: Optional[ast.SelectQuery | ast.SelectSetQuery] = None, ): try: if source_query is not None: @@ -114,15 +115,9 @@ def process_expr_on_table( raise -def is_valid_view(select_query: ast.SelectQuery | ast.SelectUnionQuery) -> bool: - if isinstance(select_query, ast.SelectQuery): - for field in select_query.select: +def is_valid_view(select_query: ast.SelectQuery | ast.SelectSetQuery) -> bool: + for query in extract_select_queries(select_query): + for field in query.select: if not isinstance(field, ast.Alias): return False - elif isinstance(select_query, ast.SelectUnionQuery): - for select in select_query.select_queries: - for field in select.select: - if not isinstance(field, ast.Alias): - return False - return True diff --git a/posthog/hogql/parser.py b/posthog/hogql/parser.py index 960dbe3ebf824..29a0d4dd09130 100644 --- a/posthog/hogql/parser.py +++ b/posthog/hogql/parser.py @@ -6,6 +6,7 @@ from prometheus_client import Histogram from posthog.hogql import ast +from posthog.hogql.ast import SelectSetNode from posthog.hogql.base import AST from posthog.hogql.constants import RESERVED_KEYWORDS from posthog.hogql.errors import BaseHogQLError, NotImplementedError, SyntaxError @@ -132,7 +133,7 @@ def parse_select( timings: Optional[HogQLTimings] = None, *, backend: Literal["python", "cpp"] = "cpp", -) -> ast.SelectQuery | ast.SelectUnionQuery: +) -> ast.SelectQuery | ast.SelectSetQuery: if timings is None: timings = HogQLTimings() with timings.measure(f"parse_select_{backend}"): @@ -327,28 +328,33 @@ def visitBlock(self, ctx: HogQLParser.BlockContext): ##### HogQL rules def visitSelect(self, ctx: HogQLParser.SelectContext): - return self.visit(ctx.selectUnionStmt() or ctx.selectStmt() or ctx.hogqlxTagElement()) - - def visitSelectUnionStmt(self, ctx: HogQLParser.SelectUnionStmtContext): - select_queries: list[ast.SelectQuery | ast.SelectUnionQuery | ast.Placeholder] = [ - self.visit(select) for select in ctx.selectStmtWithParens() - ] - flattened_queries: list[ast.SelectQuery] = [] - for query in select_queries: - if isinstance(query, ast.SelectQuery): - flattened_queries.append(query) - elif isinstance(query, ast.SelectUnionQuery): - flattened_queries.extend(query.select_queries) - elif isinstance(query, ast.Placeholder): - flattened_queries.append(query) # type: ignore + return self.visit(ctx.selectSetStmt() or ctx.selectStmt() or ctx.hogqlxTagElement()) + + def visitSelectSetStmt(self, ctx: HogQLParser.SelectSetStmtContext): + select_queries: list[SelectSetNode] = [] + + initial_query = self.visit(ctx.selectStmtWithParens()) + + for subsequent in ctx.subsequentSelectSetClause(): + if subsequent.UNION() and subsequent.ALL(): + union_type = "UNION ALL" + elif subsequent.INTERSECT(): + union_type = "INTERSECT" + elif subsequent.EXCEPT(): + union_type = "EXCEPT" else: - raise Exception(f"Unexpected query node type {type(query).__name__}") - if len(flattened_queries) == 1: - return flattened_queries[0] - return ast.SelectUnionQuery(select_queries=flattened_queries) + raise SyntaxError("Set operator must be one of UNION ALL, INTERSECT, and EXCEPT") + select_query = self.visit(subsequent.selectStmtWithParens()) + select_queries.append( + SelectSetNode(select_query=select_query, set_operator=cast(ast.SetOperator, union_type)) + ) + + if len(select_queries) == 0: + return initial_query + return ast.SelectSetQuery(initial_select_query=initial_query, subsequent_select_queries=select_queries) def visitSelectStmtWithParens(self, ctx: HogQLParser.SelectStmtWithParensContext): - return self.visit(ctx.selectStmt() or ctx.selectUnionStmt() or ctx.placeholder()) + return self.visit(ctx.selectStmt() or ctx.selectSetStmt() or ctx.placeholder()) def visitSelectStmt(self, ctx: HogQLParser.SelectStmtContext): select_query = ast.SelectQuery( @@ -673,7 +679,7 @@ def visitColumnExprDict(self, ctx: HogQLParser.ColumnExprDictContext): return ast.Dict(items=self.visit(ctx.kvPairList()) if ctx.kvPairList() else []) def visitColumnExprSubquery(self, ctx: HogQLParser.ColumnExprSubqueryContext): - return self.visit(ctx.selectUnionStmt()) + return self.visit(ctx.selectSetStmt()) def visitColumnExprLiteral(self, ctx: HogQLParser.ColumnExprLiteralContext): return self.visitChildren(ctx) @@ -958,7 +964,7 @@ def visitWithExprList(self, ctx: HogQLParser.WithExprListContext): return ctes def visitWithExprSubquery(self, ctx: HogQLParser.WithExprSubqueryContext): - subquery = self.visit(ctx.selectUnionStmt()) + subquery = self.visit(ctx.selectSetStmt()) name = self.visit(ctx.identifier()) return ast.CTE(name=name, expr=subquery, cte_type="subquery") @@ -992,7 +998,7 @@ def visitTableExprIdentifier(self, ctx: HogQLParser.TableExprIdentifierContext): return ast.Field(chain=chain) def visitTableExprSubquery(self, ctx: HogQLParser.TableExprSubqueryContext): - return self.visit(ctx.selectUnionStmt()) + return self.visit(ctx.selectSetStmt()) def visitTableExprPlaceholder(self, ctx: HogQLParser.TableExprPlaceholderContext): return self.visit(ctx.placeholder()) diff --git a/posthog/hogql/printer.py b/posthog/hogql/printer.py index 535057b8feea1..66f662f225fcc 100644 --- a/posthog/hogql/printer.py +++ b/posthog/hogql/printer.py @@ -266,7 +266,7 @@ def visit(self, node: AST | None): self.stack.pop() if len(self.stack) == 0 and self.dialect == "clickhouse" and self.settings: - if not isinstance(node, ast.SelectQuery) and not isinstance(node, ast.SelectUnionQuery): + if not isinstance(node, ast.SelectQuery) and not isinstance(node, ast.SelectSetQuery): raise QueryError("Settings can only be applied to SELECT queries") settings = self._print_settings(self.settings) if settings is not None: @@ -274,17 +274,25 @@ def visit(self, node: AST | None): return response - def visit_select_union_query(self, node: ast.SelectUnionQuery): + def visit_select_set_query(self, node: ast.SelectSetQuery): self._indent -= 1 - queries = [self.visit(expr) for expr in node.select_queries] + ret = self.visit(node.initial_select_query) if self.pretty: - query = f"\n{self.indent(1)}UNION ALL\n{self.indent(1)}".join([query.strip() for query in queries]) - else: - query = " UNION ALL ".join(queries) + ret = ret.strip() + for expr in node.subsequent_select_queries: + query = self.visit(expr.select_query) + if self.pretty: + query = query.strip() + if expr.set_operator is not None: + if self.pretty: + ret += f"\n{self.indent(1)}{expr.set_operator}\n{self.indent(1)}" + else: + ret += f" {expr.set_operator} " + ret += query self._indent += 1 if len(self.stack) > 1: - return f"({query.strip()})" - return query + return f"({ret.strip()})" + return ret def visit_select_query(self, node: ast.SelectQuery): if self.dialect == "clickhouse": @@ -293,8 +301,8 @@ def visit_select_query(self, node: ast.SelectQuery): if not self.context.team_id: raise InternalHogQLError("Full SELECT queries are disabled if context.team_id is not set") - # if we are the first parsed node in the tree, or a child of a SelectUnionQuery, mark us as a top level query - part_of_select_union = len(self.stack) >= 2 and isinstance(self.stack[-2], ast.SelectUnionQuery) + # if we are the first parsed node in the tree, or a child of a SelectSetQuery, mark us as a top level query + part_of_select_union = len(self.stack) >= 2 and isinstance(self.stack[-2], ast.SelectSetQuery) is_top_level_query = len(self.stack) <= 1 or (len(self.stack) == 2 and part_of_select_union) # We will add extra clauses onto this from the joined tables @@ -507,7 +515,7 @@ def visit_join_expr(self, node: ast.JoinExpr) -> JoinExprResponse: elif isinstance(node.type, ast.SelectQueryType): join_strings.append(self.visit(node.table)) - elif isinstance(node.type, ast.SelectUnionQueryType): + elif isinstance(node.type, ast.SelectSetQueryType): join_strings.append(self.visit(node.table)) elif isinstance(node.type, ast.SelectViewType) and node.alias is not None: @@ -1251,7 +1259,7 @@ def visit_field_type(self, type: ast.FieldType): isinstance(type.table_type, ast.SelectQueryType) or isinstance(type.table_type, ast.SelectQueryAliasType) or isinstance(type.table_type, ast.SelectViewType) - or isinstance(type.table_type, ast.SelectUnionQueryType) + or isinstance(type.table_type, ast.SelectSetQueryType) ): field_sql = self._print_identifier(type.name) if isinstance(type.table_type, ast.SelectQueryAliasType) or isinstance(type.table_type, ast.SelectViewType): diff --git a/posthog/hogql/query.py b/posthog/hogql/query.py index 2516d8007d815..1a556e1298b28 100644 --- a/posthog/hogql/query.py +++ b/posthog/hogql/query.py @@ -19,6 +19,7 @@ from posthog.hogql.timings import HogQLTimings from posthog.hogql.variables import replace_variables from posthog.hogql.visitor import clone_expr +from posthog.hogql.resolver_utils import extract_select_queries from posthog.models.team import Team from posthog.clickhouse.query_tagging import tag_queries from posthog.client import sync_execute @@ -35,7 +36,7 @@ def execute_hogql_query( - query: Union[str, ast.SelectQuery, ast.SelectUnionQuery], + query: Union[str, ast.SelectQuery, ast.SelectSetQuery], team: Team, *, query_type: str = "hogql_query", @@ -65,7 +66,7 @@ def execute_hogql_query( metadata: Optional[HogQLMetadataResponse] = None with timings.measure("query"): - if isinstance(query, ast.SelectQuery) or isinstance(query, ast.SelectUnionQuery): + if isinstance(query, ast.SelectQuery) or isinstance(query, ast.SelectSetQuery): select_query = query query = None else: @@ -105,10 +106,7 @@ def execute_hogql_query( select_query = replace_placeholders(select_query, placeholders) with timings.measure("max_limit"): - select_queries = ( - select_query.select_queries if isinstance(select_query, ast.SelectUnionQuery) else [select_query] - ) - for one_query in select_queries: + for one_query in extract_select_queries(select_query): if one_query.limit is None: one_query.limit = ast.Constant(value=get_default_limit_for_context(limit_context)) @@ -138,8 +136,8 @@ def execute_hogql_query( ) print_columns = [] columns_query = ( - select_query_hogql.select_queries[0] - if isinstance(select_query_hogql, ast.SelectUnionQuery) + next(extract_select_queries(select_query_hogql)) + if isinstance(select_query_hogql, ast.SelectSetQuery) else select_query_hogql ) for node in columns_query.select: diff --git a/posthog/hogql/resolver.py b/posthog/hogql/resolver.py index b263843598f87..e1ddae4c545f0 100644 --- a/posthog/hogql/resolver.py +++ b/posthog/hogql/resolver.py @@ -24,7 +24,12 @@ from posthog.hogql.functions.sparkline import sparkline from posthog.hogql.hogqlx import HOGQLX_COMPONENTS, convert_to_hx from posthog.hogql.parser import parse_select -from posthog.hogql.resolver_utils import expand_hogqlx_query, lookup_cte_by_name, lookup_field_by_name +from posthog.hogql.resolver_utils import ( + expand_hogqlx_query, + lookup_cte_by_name, + lookup_field_by_name, + extract_select_queries, +) from posthog.hogql.visitor import CloningVisitor, TraversingVisitor, clone_expr from posthog.models.utils import UUIDT @@ -123,15 +128,17 @@ def visit(self, node: ast.AST | None): raise QueryError("Too many CTE expansions (50+). Probably a CTE loop.") return super().visit(node) - def visit_select_union_query(self, node: ast.SelectUnionQuery): + def visit_select_set_query(self, node: ast.SelectSetQuery): # all expressions combined by UNION ALL can use CTEs from the first expression # so we put these CTEs to the scope - default_ctes = node.select_queries[0].ctes if node.select_queries else None + default_ctes = next(extract_select_queries(node)).ctes if default_ctes: self.scopes.append(ast.SelectQueryType(ctes=default_ctes)) - node = super().visit_select_union_query(node) - node.type = ast.SelectUnionQueryType(types=[expr.type for expr in node.select_queries]) + node = super().visit_select_set_query(node) + node.type = ast.SelectSetQueryType( + types=[node.initial_select_query.type, *(x.select_query.type for x in node.subsequent_select_queries)] # type: ignore + ) if default_ctes: self.scopes.pop() @@ -254,7 +261,7 @@ def _asterisk_columns(self, asterisk: ast.AsteriskType) -> list[ast.Expr]: database_fields = table.get_asterisk() return [ast.Field(chain=[key]) for key in database_fields.keys()] elif ( - isinstance(asterisk.table_type, ast.SelectUnionQueryType) + isinstance(asterisk.table_type, ast.SelectSetQueryType) or isinstance(asterisk.table_type, ast.SelectQueryType) or isinstance(asterisk.table_type, ast.SelectQueryAliasType) or isinstance(asterisk.table_type, ast.SelectViewType) @@ -262,7 +269,7 @@ def _asterisk_columns(self, asterisk: ast.AsteriskType) -> list[ast.Expr]: select = asterisk.table_type while isinstance(select, ast.SelectQueryAliasType) or isinstance(select, ast.SelectViewType): select = select.select_query_type - if isinstance(select, ast.SelectUnionQueryType): + if isinstance(select, ast.SelectSetQueryType): select = select.types[0] if isinstance(select, ast.SelectQueryType): return [ast.Field(chain=[key]) for key in select.columns.keys()] @@ -369,7 +376,7 @@ def visit_join_expr(self, node: ast.JoinExpr): return node - elif isinstance(node.table, ast.SelectQuery) or isinstance(node.table, ast.SelectUnionQuery): + elif isinstance(node.table, ast.SelectQuery) or isinstance(node.table, ast.SelectSetQuery): node = cast(ast.JoinExpr, clone_expr(node)) if node.constraint and node.constraint.constraint_type == "USING": # visit USING constraint before adding the table to avoid ambiguous names diff --git a/posthog/hogql/resolver_utils.py b/posthog/hogql/resolver_utils.py index f67f683449b02..6ed44a9643d2a 100644 --- a/posthog/hogql/resolver_utils.py +++ b/posthog/hogql/resolver_utils.py @@ -1,4 +1,5 @@ from typing import Optional +from collections.abc import Generator from posthog import schema from posthog.hogql import ast @@ -86,3 +87,12 @@ def expand_hogqlx_query(node: ast.HogQLXTag, team_id: Optional[int]): return query except Exception as e: raise ResolutionError(f"Error parsing query tag: {e}", start=node.start, end=node.end) + + +def extract_select_queries(select: ast.SelectSetQuery | ast.SelectQuery) -> Generator[ast.SelectQuery, None, None]: + if isinstance(select, ast.SelectQuery): + yield select + else: + yield from extract_select_queries(select.initial_select_query) + for select_query in select.subsequent_select_queries: + yield from extract_select_queries(select_query.select_query) diff --git a/posthog/hogql/test/__snapshots__/test_resolver.ambr b/posthog/hogql/test/__snapshots__/test_resolver.ambr index d38d909cc43e7..0131376631bcc 100644 --- a/posthog/hogql/test/__snapshots__/test_resolver.ambr +++ b/posthog/hogql/test/__snapshots__/test_resolver.ambr @@ -2065,925 +2065,928 @@ ] select_from: { table: { - select_queries: [ - { - select: [ - { - alias: "uuid" - expr: { - chain: [ - "uuid" - ] - type: - } - hidden: True + initial_select_query: { + select: [ + { + alias: "uuid" + expr: { + chain: [ + "uuid" + ] type: - }, - { - alias: "event" - expr: { - chain: [ - "event" - ] - type: - } - hidden: True + } + hidden: True + type: + }, + { + alias: "event" + expr: { + chain: [ + "event" + ] type: - }, - { - alias: "properties" - expr: { - chain: [ - "properties" - ] - type: - } - hidden: True + } + hidden: True + type: + }, + { + alias: "properties" + expr: { + chain: [ + "properties" + ] type: - }, - { - alias: "timestamp" - expr: { - chain: [ - "timestamp" - ] - type: - } - hidden: True + } + hidden: True + type: + }, + { + alias: "timestamp" + expr: { + chain: [ + "timestamp" + ] type: - }, - { - alias: "distinct_id" - expr: { - chain: [ - "distinct_id" - ] - type: - } - hidden: True + } + hidden: True + type: + }, + { + alias: "distinct_id" + expr: { + chain: [ + "distinct_id" + ] type: - }, - { - alias: "elements_chain" - expr: { - chain: [ - "elements_chain" - ] - type: - } - hidden: True + } + hidden: True + type: + }, + { + alias: "elements_chain" + expr: { + chain: [ + "elements_chain" + ] type: - }, - { - alias: "created_at" - expr: { - chain: [ - "created_at" - ] - type: - } - hidden: True + } + hidden: True + type: + }, + { + alias: "created_at" + expr: { + chain: [ + "created_at" + ] type: - }, - { - alias: "$session_id" - expr: { - chain: [ - "$session_id" - ] - type: - } - hidden: True + } + hidden: True + type: + }, + { + alias: "$session_id" + expr: { + chain: [ + "$session_id" + ] type: - }, - { - alias: "$window_id" - expr: { - chain: [ - "$window_id" - ] - type: - } - hidden: True + } + hidden: True + type: + }, + { + alias: "$window_id" + expr: { + chain: [ + "$window_id" + ] type: - }, - { - alias: "person_id" - expr: { - args: [ - { - args: [ - { - args: [ - { - alias: "distinct_id" - expr: { - chain: [ - "override", - "distinct_id" - ] - type: { - name: "distinct_id" - table_type: { - field: "override" - lazy_join: { - from_field: [ - "distinct_id" - ], - join_function: , - join_table: { - fields: { - distinct_id: {}, - person: {}, - person_id: {}, - team_id: {} - } - }, - to_field: None - } - table_type: + } + hidden: True + type: + }, + { + alias: "person_id" + expr: { + args: [ + { + args: [ + { + args: [ + { + alias: "distinct_id" + expr: { + chain: [ + "override", + "distinct_id" + ] + type: { + name: "distinct_id" + table_type: { + field: "override" + lazy_join: { + from_field: [ + "distinct_id" + ], + join_function: , + join_table: { + fields: { + distinct_id: {}, + person: {}, + person_id: {}, + team_id: {} + } + }, + to_field: None } + table_type: } } - hidden: True - type: { - alias: "distinct_id" - type: - } } - ] - distinct: False - name: "empty" - type: { - arg_types: [ - { - data_type: "str" - nullable: False - } - ] - name: "empty" - return_type: { - data_type: "unknown" - nullable: True + hidden: True + type: { + alias: "distinct_id" + type: } } - } - ] - distinct: False - name: "not" - type: { - arg_types: [ - - ] - name: "not" - return_type: - } - }, - { - alias: "person_id" - expr: { - chain: [ - "override", - "person_id" ] + distinct: False + name: "empty" type: { - name: "person_id" - table_type: { - field: "override" - lazy_join: { - from_field: [ - "distinct_id" - ], - join_function: , - join_table: { - fields: { - distinct_id: {}, - person: {}, - person_id: {}, - team_id: {} - } - }, - to_field: None + arg_types: [ + { + data_type: "str" + nullable: False } - table_type: + ] + name: "empty" + return_type: { + data_type: "unknown" + nullable: True } } } - hidden: True + ] + distinct: False + name: "not" + type: { + arg_types: [ + + ] + name: "not" + return_type: + } + }, + { + alias: "person_id" + expr: { + chain: [ + "override", + "person_id" + ] type: { - alias: "person_id" - type: - } - }, - { - alias: "event_person_id" - expr: { - chain: [ - "event_person_id" - ] - type: { - name: "event_person_id" + name: "person_id" + table_type: { + field: "override" + lazy_join: { + from_field: [ + "distinct_id" + ], + join_function: , + join_table: { + fields: { + distinct_id: {}, + person: {}, + person_id: {}, + team_id: {} + } + }, + to_field: None + } table_type: } } - hidden: True + } + hidden: True + type: { + alias: "person_id" + type: + } + }, + { + alias: "event_person_id" + expr: { + chain: [ + "event_person_id" + ] type: { - alias: "event_person_id" - type: + name: "event_person_id" + table_type: } } - ] - distinct: False - name: "if" - type: - } - hidden: True - type: - }, - { - alias: "$group_0" - expr: { - chain: [ - "$group_0" - ] - type: - } - hidden: True + hidden: True + type: { + alias: "event_person_id" + type: + } + } + ] + distinct: False + name: "if" type: - }, - { - alias: "$group_1" - expr: { - chain: [ - "$group_1" - ] - type: - } - hidden: True + } + hidden: True + type: + }, + { + alias: "$group_0" + expr: { + chain: [ + "$group_0" + ] type: - }, - { - alias: "$group_2" - expr: { - chain: [ - "$group_2" - ] - type: - } - hidden: True + } + hidden: True + type: + }, + { + alias: "$group_1" + expr: { + chain: [ + "$group_1" + ] type: - }, - { - alias: "$group_3" - expr: { - chain: [ - "$group_3" - ] - type: - } - hidden: True + } + hidden: True + type: + }, + { + alias: "$group_2" + expr: { + chain: [ + "$group_2" + ] type: - }, - { - alias: "$group_4" - expr: { - chain: [ - "$group_4" - ] - type: - } - hidden: True + } + hidden: True + type: + }, + { + alias: "$group_3" + expr: { + chain: [ + "$group_3" + ] type: - }, - { - alias: "elements_chain_href" - expr: { - chain: [ - "elements_chain_href" - ] - type: - } - hidden: True + } + hidden: True + type: + }, + { + alias: "$group_4" + expr: { + chain: [ + "$group_4" + ] type: - }, - { - alias: "elements_chain_texts" - expr: { - chain: [ - "elements_chain_texts" - ] - type: - } - hidden: True + } + hidden: True + type: + }, + { + alias: "elements_chain_href" + expr: { + chain: [ + "elements_chain_href" + ] type: - }, - { - alias: "elements_chain_ids" - expr: { - chain: [ - "elements_chain_ids" - ] - type: - } - hidden: True + } + hidden: True + type: + }, + { + alias: "elements_chain_texts" + expr: { + chain: [ + "elements_chain_texts" + ] type: - }, - { - alias: "elements_chain_elements" - expr: { - chain: [ - "elements_chain_elements" - ] - type: - } - hidden: True + } + hidden: True + type: + }, + { + alias: "elements_chain_ids" + expr: { + chain: [ + "elements_chain_ids" + ] type: - }, - { - alias: "event_person_id" - expr: { - chain: [ - "event_person_id" - ] - type: - } - hidden: True + } + hidden: True + type: + }, + { + alias: "elements_chain_elements" + expr: { + chain: [ + "elements_chain_elements" + ] type: } - ] - select_from: { - table: { + hidden: True + type: + }, + { + alias: "event_person_id" + expr: { chain: [ - "events" + "event_person_id" ] type: } + hidden: True + type: + } + ] + select_from: { + table: { + chain: [ + "events" + ] type: } type: - }, + } + type: + } + subsequent_select_queries: [ { - select: [ - { - alias: "uuid" - expr: { - chain: [ - "uuid" - ] - type: { - name: "uuid" - table_type: { - table: { - fields: { - $group_0: {}, - $group_1: {}, - $group_2: {}, - $group_3: {}, - $group_4: {}, - $session_id: {}, - $window_id: {}, - created_at: {}, - distinct_id: {}, - elements_chain: {}, - elements_chain_elements: {}, - elements_chain_href: {}, - elements_chain_ids: {}, - elements_chain_texts: {}, - event: {}, - event_person_id: {}, - goe_0: {}, - goe_1: {}, - goe_2: {}, - goe_3: {}, - goe_4: {}, - group_0: {}, - group_1: {}, - group_2: {}, - group_3: {}, - group_4: {}, - override: {}, - pdi: {}, - person: {}, - person_id: {}, - poe: {}, - properties: {}, - session: {}, - team_id: {}, - timestamp: {}, - uuid: {} + select_query: { + select: [ + { + alias: "uuid" + expr: { + chain: [ + "uuid" + ] + type: { + name: "uuid" + table_type: { + table: { + fields: { + $group_0: {}, + $group_1: {}, + $group_2: {}, + $group_3: {}, + $group_4: {}, + $session_id: {}, + $window_id: {}, + created_at: {}, + distinct_id: {}, + elements_chain: {}, + elements_chain_elements: {}, + elements_chain_href: {}, + elements_chain_ids: {}, + elements_chain_texts: {}, + event: {}, + event_person_id: {}, + goe_0: {}, + goe_1: {}, + goe_2: {}, + goe_3: {}, + goe_4: {}, + group_0: {}, + group_1: {}, + group_2: {}, + group_3: {}, + group_4: {}, + override: {}, + pdi: {}, + person: {}, + person_id: {}, + poe: {}, + properties: {}, + session: {}, + team_id: {}, + timestamp: {}, + uuid: {} + } } } } } - } - hidden: True - type: { - alias: "uuid" - type: - } - }, - { - alias: "event" - expr: { - chain: [ - "event" - ] + hidden: True type: { - name: "event" - table_type: + alias: "uuid" + type: } - } - hidden: True - type: { + }, + { alias: "event" - type: - } - }, - { - alias: "properties" - expr: { - chain: [ - "properties" - ] + expr: { + chain: [ + "event" + ] + type: { + name: "event" + table_type: + } + } + hidden: True type: { - name: "properties" - table_type: + alias: "event" + type: } - } - hidden: True - type: { + }, + { alias: "properties" - type: - } - }, - { - alias: "timestamp" - expr: { - chain: [ - "timestamp" - ] + expr: { + chain: [ + "properties" + ] + type: { + name: "properties" + table_type: + } + } + hidden: True type: { - name: "timestamp" - table_type: + alias: "properties" + type: } - } - hidden: True - type: { + }, + { alias: "timestamp" - type: - } - }, - { - alias: "distinct_id" - expr: { - chain: [ - "distinct_id" - ] + expr: { + chain: [ + "timestamp" + ] + type: { + name: "timestamp" + table_type: + } + } + hidden: True type: { - name: "distinct_id" - table_type: + alias: "timestamp" + type: } - } - hidden: True - type: { + }, + { alias: "distinct_id" - type: - } - }, - { - alias: "elements_chain" - expr: { - chain: [ - "elements_chain" - ] + expr: { + chain: [ + "distinct_id" + ] + type: { + name: "distinct_id" + table_type: + } + } + hidden: True type: { - name: "elements_chain" - table_type: + alias: "distinct_id" + type: } - } - hidden: True - type: { + }, + { alias: "elements_chain" - type: - } - }, - { - alias: "created_at" - expr: { - chain: [ - "created_at" - ] + expr: { + chain: [ + "elements_chain" + ] + type: { + name: "elements_chain" + table_type: + } + } + hidden: True type: { - name: "created_at" - table_type: + alias: "elements_chain" + type: } - } - hidden: True - type: { + }, + { alias: "created_at" - type: - } - }, - { - alias: "$session_id" - expr: { - chain: [ - "$session_id" - ] + expr: { + chain: [ + "created_at" + ] + type: { + name: "created_at" + table_type: + } + } + hidden: True type: { - name: "$session_id" - table_type: + alias: "created_at" + type: } - } - hidden: True - type: { + }, + { alias: "$session_id" - type: - } - }, - { - alias: "$window_id" - expr: { - chain: [ - "$window_id" - ] + expr: { + chain: [ + "$session_id" + ] + type: { + name: "$session_id" + table_type: + } + } + hidden: True type: { - name: "$window_id" - table_type: + alias: "$session_id" + type: } - } - hidden: True - type: { + }, + { alias: "$window_id" - type: - } - }, - { - alias: "person_id" - expr: { - args: [ - { - args: [ - { - args: [ - { - alias: "distinct_id" - expr: { - chain: [ - "override", - "distinct_id" - ] - type: { - name: "distinct_id" - table_type: { - field: "override" - lazy_join: { - from_field: [ - "distinct_id" - ], - join_function: , - join_table: { - fields: { - distinct_id: {}, - person: {}, - person_id: {}, - team_id: {} - } - }, - to_field: None + expr: { + chain: [ + "$window_id" + ] + type: { + name: "$window_id" + table_type: + } + } + hidden: True + type: { + alias: "$window_id" + type: + } + }, + { + alias: "person_id" + expr: { + args: [ + { + args: [ + { + args: [ + { + alias: "distinct_id" + expr: { + chain: [ + "override", + "distinct_id" + ] + type: { + name: "distinct_id" + table_type: { + field: "override" + lazy_join: { + from_field: [ + "distinct_id" + ], + join_function: , + join_table: { + fields: { + distinct_id: {}, + person: {}, + person_id: {}, + team_id: {} + } + }, + to_field: None + } + table_type: } - table_type: } } - } - hidden: True - type: { - alias: "distinct_id" - type: - } - } - ] - distinct: False - name: "empty" - type: { - arg_types: [ - { - data_type: "str" - nullable: False + hidden: True + type: { + alias: "distinct_id" + type: + } } ] + distinct: False name: "empty" - return_type: { - data_type: "unknown" - nullable: True + type: { + arg_types: [ + { + data_type: "str" + nullable: False + } + ] + name: "empty" + return_type: { + data_type: "unknown" + nullable: True + } } } - } - ] - distinct: False - name: "not" - type: { - arg_types: [ - ] + distinct: False name: "not" - return_type: { - data_type: "unknown" - nullable: True - } - } - }, - { - alias: "person_id" - expr: { - chain: [ - "override", - "person_id" - ] type: { - name: "person_id" - table_type: { - field: "override" - lazy_join: { - from_field: [ - "distinct_id" - ], - join_function: , - join_table: { - fields: { - distinct_id: {}, - person: {}, - person_id: {}, - team_id: {} - } - }, - to_field: None - } - table_type: + arg_types: [ + + ] + name: "not" + return_type: { + data_type: "unknown" + nullable: True } } - } - hidden: True - type: { + }, + { alias: "person_id" - type: - } - }, - { - alias: "event_person_id" - expr: { - chain: [ - "event_person_id" - ] + expr: { + chain: [ + "override", + "person_id" + ] + type: { + name: "person_id" + table_type: { + field: "override" + lazy_join: { + from_field: [ + "distinct_id" + ], + join_function: , + join_table: { + fields: { + distinct_id: {}, + person: {}, + person_id: {}, + team_id: {} + } + }, + to_field: None + } + table_type: + } + } + } + hidden: True type: { - name: "event_person_id" - table_type: + alias: "person_id" + type: } - } - hidden: True - type: { - alias: "event_person_id" - type: - } - } - ] - distinct: False - name: "if" - type: { - arg_types: [ - , - { - data_type: "str" - nullable: False }, { - data_type: "str" - nullable: False + alias: "event_person_id" + expr: { + chain: [ + "event_person_id" + ] + type: { + name: "event_person_id" + table_type: + } + } + hidden: True + type: { + alias: "event_person_id" + type: + } } ] + distinct: False name: "if" - return_type: { - data_type: "unknown" - nullable: True + type: { + arg_types: [ + , + { + data_type: "str" + nullable: False + }, + { + data_type: "str" + nullable: False + } + ] + name: "if" + return_type: { + data_type: "unknown" + nullable: True + } } } - } - hidden: True - type: { - alias: "person_id" - type: - } - }, - { - alias: "$group_0" - expr: { - chain: [ - "$group_0" - ] + hidden: True type: { - name: "$group_0" - table_type: + alias: "person_id" + type: } - } - hidden: True - type: { + }, + { alias: "$group_0" - type: - } - }, - { - alias: "$group_1" - expr: { - chain: [ - "$group_1" - ] + expr: { + chain: [ + "$group_0" + ] + type: { + name: "$group_0" + table_type: + } + } + hidden: True type: { - name: "$group_1" - table_type: + alias: "$group_0" + type: } - } - hidden: True - type: { + }, + { alias: "$group_1" - type: - } - }, - { - alias: "$group_2" - expr: { - chain: [ - "$group_2" - ] + expr: { + chain: [ + "$group_1" + ] + type: { + name: "$group_1" + table_type: + } + } + hidden: True type: { - name: "$group_2" - table_type: + alias: "$group_1" + type: } - } - hidden: True - type: { + }, + { alias: "$group_2" - type: - } - }, - { - alias: "$group_3" - expr: { - chain: [ - "$group_3" - ] + expr: { + chain: [ + "$group_2" + ] + type: { + name: "$group_2" + table_type: + } + } + hidden: True type: { - name: "$group_3" - table_type: + alias: "$group_2" + type: } - } - hidden: True - type: { + }, + { alias: "$group_3" - type: - } - }, - { - alias: "$group_4" - expr: { - chain: [ - "$group_4" - ] + expr: { + chain: [ + "$group_3" + ] + type: { + name: "$group_3" + table_type: + } + } + hidden: True type: { - name: "$group_4" - table_type: + alias: "$group_3" + type: } - } - hidden: True - type: { + }, + { alias: "$group_4" - type: - } - }, - { - alias: "elements_chain_href" - expr: { - chain: [ - "elements_chain_href" - ] + expr: { + chain: [ + "$group_4" + ] + type: { + name: "$group_4" + table_type: + } + } + hidden: True type: { - name: "elements_chain_href" - table_type: + alias: "$group_4" + type: } - } - hidden: True - type: { + }, + { alias: "elements_chain_href" - type: - } - }, - { - alias: "elements_chain_texts" - expr: { - chain: [ - "elements_chain_texts" - ] + expr: { + chain: [ + "elements_chain_href" + ] + type: { + name: "elements_chain_href" + table_type: + } + } + hidden: True type: { - name: "elements_chain_texts" - table_type: + alias: "elements_chain_href" + type: } - } - hidden: True - type: { + }, + { alias: "elements_chain_texts" - type: - } - }, - { - alias: "elements_chain_ids" - expr: { - chain: [ - "elements_chain_ids" - ] + expr: { + chain: [ + "elements_chain_texts" + ] + type: { + name: "elements_chain_texts" + table_type: + } + } + hidden: True type: { - name: "elements_chain_ids" - table_type: + alias: "elements_chain_texts" + type: } - } - hidden: True - type: { + }, + { alias: "elements_chain_ids" - type: - } - }, - { - alias: "elements_chain_elements" - expr: { - chain: [ - "elements_chain_elements" - ] + expr: { + chain: [ + "elements_chain_ids" + ] + type: { + name: "elements_chain_ids" + table_type: + } + } + hidden: True type: { - name: "elements_chain_elements" - table_type: + alias: "elements_chain_ids" + type: } - } - hidden: True - type: { + }, + { alias: "elements_chain_elements" - type: - } - }, - { - alias: "event_person_id" - expr: { - chain: [ - "event_person_id" - ] + expr: { + chain: [ + "elements_chain_elements" + ] + type: { + name: "elements_chain_elements" + table_type: + } + } + hidden: True type: { - name: "event_person_id" - table_type: + alias: "elements_chain_elements" + type: } - } - hidden: True - type: { + }, + { alias: "event_person_id" + expr: { + chain: [ + "event_person_id" + ] + type: { + name: "event_person_id" + table_type: + } + } + hidden: True + type: { + alias: "event_person_id" + type: + } + } + ] + select_from: { + table: { + chain: [ + "events" + ] type: } - } - ] - select_from: { - table: { - chain: [ - "events" - ] type: } - type: - } - type: { - aliases: {} - anonymous_tables: [] - columns: { - $group_0: , - $group_1: , - $group_2: , - $group_3: , - $group_4: , - $session_id: , - $window_id: , - created_at: , - distinct_id: , - elements_chain: , - elements_chain_elements: , - elements_chain_href: , - elements_chain_ids: , - elements_chain_texts: , - event: , - event_person_id: , - person_id: , - properties: , - timestamp: , - uuid: - } - ctes: {} - tables: { - events: + type: { + aliases: {} + anonymous_tables: [] + columns: { + $group_0: , + $group_1: , + $group_2: , + $group_3: , + $group_4: , + $session_id: , + $window_id: , + created_at: , + distinct_id: , + elements_chain: , + elements_chain_elements: , + elements_chain_href: , + elements_chain_ids: , + elements_chain_texts: , + event: , + event_person_id: , + person_id: , + properties: , + timestamp: , + uuid: + } + ctes: {} + tables: { + events: + } } } + set_operator: "UNION ALL" } ] type: { @@ -6128,206 +6131,209 @@ # name: TestResolver.test_resolve_union_all ''' { - select_queries: [ - { - select: [ - { - alias: "event" - expr: { - chain: [ - "event" - ] - type: { - name: "event" - table_type: { - table: { - fields: { - $group_0: {}, - $group_1: {}, - $group_2: {}, - $group_3: {}, - $group_4: {}, - $session_id: {}, - $window_id: {}, - created_at: {}, - distinct_id: {}, - elements_chain: {}, - elements_chain_elements: {}, - elements_chain_href: {}, - elements_chain_ids: {}, - elements_chain_texts: {}, - event: {}, - event_person_id: {}, - goe_0: {}, - goe_1: {}, - goe_2: {}, - goe_3: {}, - goe_4: {}, - group_0: {}, - group_1: {}, - group_2: {}, - group_3: {}, - group_4: {}, - override: {}, - pdi: {}, - person: {}, - person_id: {}, - poe: {}, - properties: {}, - session: {}, - team_id: {}, - timestamp: {}, - uuid: {} - } + initial_select_query: { + select: [ + { + alias: "event" + expr: { + chain: [ + "event" + ] + type: { + name: "event" + table_type: { + table: { + fields: { + $group_0: {}, + $group_1: {}, + $group_2: {}, + $group_3: {}, + $group_4: {}, + $session_id: {}, + $window_id: {}, + created_at: {}, + distinct_id: {}, + elements_chain: {}, + elements_chain_elements: {}, + elements_chain_href: {}, + elements_chain_ids: {}, + elements_chain_texts: {}, + event: {}, + event_person_id: {}, + goe_0: {}, + goe_1: {}, + goe_2: {}, + goe_3: {}, + goe_4: {}, + group_0: {}, + group_1: {}, + group_2: {}, + group_3: {}, + group_4: {}, + override: {}, + pdi: {}, + person: {}, + person_id: {}, + poe: {}, + properties: {}, + session: {}, + team_id: {}, + timestamp: {}, + uuid: {} } } } } - hidden: True - type: { - alias: "event" - type: - } - }, - { - alias: "timestamp" - expr: { - chain: [ - "timestamp" - ] - type: { - name: "timestamp" - table_type: - } - } - hidden: True - type: { - alias: "timestamp" - type: - } } - ] - select_from: { - table: { + hidden: True + type: { + alias: "event" + type: + } + }, + { + alias: "timestamp" + expr: { chain: [ - "events" + "timestamp" ] + type: { + name: "timestamp" + table_type: + } + } + hidden: True + type: { + alias: "timestamp" type: } + } + ] + select_from: { + table: { + chain: [ + "events" + ] type: } - type: { - aliases: {} - anonymous_tables: [] - columns: { - event: , - timestamp: - } - ctes: {} - tables: { - events: - } + type: + } + type: { + aliases: {} + anonymous_tables: [] + columns: { + event: , + timestamp: } - }, + ctes: {} + tables: { + events: + } + } + } + subsequent_select_queries: [ { - select: [ - { - alias: "event" - expr: { - chain: [ - "event" - ] - type: { - name: "event" - table_type: { - table: { - fields: { - $group_0: {}, - $group_1: {}, - $group_2: {}, - $group_3: {}, - $group_4: {}, - $session_id: {}, - $window_id: {}, - created_at: {}, - distinct_id: {}, - elements_chain: {}, - elements_chain_elements: {}, - elements_chain_href: {}, - elements_chain_ids: {}, - elements_chain_texts: {}, - event: {}, - event_person_id: {}, - goe_0: {}, - goe_1: {}, - goe_2: {}, - goe_3: {}, - goe_4: {}, - group_0: {}, - group_1: {}, - group_2: {}, - group_3: {}, - group_4: {}, - override: {}, - pdi: {}, - person: {}, - person_id: {}, - poe: {}, - properties: {}, - session: {}, - team_id: {}, - timestamp: {}, - uuid: {} + select_query: { + select: [ + { + alias: "event" + expr: { + chain: [ + "event" + ] + type: { + name: "event" + table_type: { + table: { + fields: { + $group_0: {}, + $group_1: {}, + $group_2: {}, + $group_3: {}, + $group_4: {}, + $session_id: {}, + $window_id: {}, + created_at: {}, + distinct_id: {}, + elements_chain: {}, + elements_chain_elements: {}, + elements_chain_href: {}, + elements_chain_ids: {}, + elements_chain_texts: {}, + event: {}, + event_person_id: {}, + goe_0: {}, + goe_1: {}, + goe_2: {}, + goe_3: {}, + goe_4: {}, + group_0: {}, + group_1: {}, + group_2: {}, + group_3: {}, + group_4: {}, + override: {}, + pdi: {}, + person: {}, + person_id: {}, + poe: {}, + properties: {}, + session: {}, + team_id: {}, + timestamp: {}, + uuid: {} + } } } } } - } - hidden: True - type: { - alias: "event" - type: - } - }, - { - alias: "timestamp" - expr: { - chain: [ - "timestamp" - ] + hidden: True type: { - name: "timestamp" - table_type: + alias: "event" + type: } - } - hidden: True - type: { + }, + { alias: "timestamp" + expr: { + chain: [ + "timestamp" + ] + type: { + name: "timestamp" + table_type: + } + } + hidden: True + type: { + alias: "timestamp" + type: + } + } + ] + select_from: { + table: { + chain: [ + "events" + ] type: } - } - ] - select_from: { - table: { - chain: [ - "events" - ] type: } - type: - } - type: { - aliases: {} - anonymous_tables: [] - columns: { - event: , - timestamp: - } - ctes: {} - tables: { - events: + type: { + aliases: {} + anonymous_tables: [] + columns: { + event: , + timestamp: + } + ctes: {} + tables: { + events: + } } } + set_operator: "UNION ALL" } ] type: { diff --git a/posthog/hogql/test/_test_parser.py b/posthog/hogql/test/_test_parser.py index 03f8dee976152..b86fca986a963 100644 --- a/posthog/hogql/test/_test_parser.py +++ b/posthog/hogql/test/_test_parser.py @@ -21,6 +21,8 @@ Array, Dict, VariableDeclaration, + SelectSetNode, + SelectSetQuery, ) from posthog.hogql.parser import parse_program @@ -50,9 +52,9 @@ def _expr(self, expr: str, placeholders: Optional[dict[str, ast.Expr]] = None) - def _select( self, query: str, placeholders: Optional[dict[str, ast.Expr]] = None - ) -> ast.SelectQuery | ast.SelectUnionQuery | ast.HogQLXTag: + ) -> ast.SelectQuery | ast.SelectSetQuery | ast.HogQLXTag: return cast( - ast.SelectQuery | ast.SelectUnionQuery | ast.HogQLXTag, + ast.SelectQuery | ast.SelectSetQuery | ast.HogQLXTag, clear_locations(parse_select(query, placeholders=placeholders, backend=backend)), ) @@ -1381,12 +1383,48 @@ def test_placeholder_expressions(self): def test_select_union_all(self): self.assertEqual( self._select("select 1 union all select 2 union all select 3"), - ast.SelectUnionQuery( - select_queries=[ - ast.SelectQuery(select=[ast.Constant(value=1)]), - ast.SelectQuery(select=[ast.Constant(value=2)]), - ast.SelectQuery(select=[ast.Constant(value=3)]), - ] + ast.SelectSetQuery( + initial_select_query=ast.SelectQuery(select=[ast.Constant(value=1)]), + subsequent_select_queries=[ + SelectSetNode(set_operator="UNION ALL", select_query=query) + for query in ( + ast.SelectQuery(select=[ast.Constant(value=2)]), + ast.SelectQuery(select=[ast.Constant(value=3)]), + ) + ], + ), + ) + + def test_nested_selects(self): + self.assertEqual( + self._select("(select 1 intersect select 2) union all (select 3 except select 4)"), + SelectSetQuery( + initial_select_query=SelectSetQuery( + initial_select_query=SelectQuery(select=[Constant(value=1)]), + subsequent_select_queries=[ + SelectSetNode( + select_query=SelectQuery( + select=[Constant(value=2)], + ), + set_operator="INTERSECT", + ) + ], + ), + subsequent_select_queries=[ + SelectSetNode( + select_query=SelectSetQuery( + initial_select_query=SelectQuery( + select=[Constant(value=3)], + ), + subsequent_select_queries=[ + SelectSetNode( + select_query=SelectQuery(select=[Constant(value=4)]), set_operator="EXCEPT" + ) + ], + ), + set_operator="UNION ALL", + ) + ], ), ) diff --git a/posthog/hogql/test/test_printer.py b/posthog/hogql/test/test_printer.py index 0a829c470d877..a26ac3ac0352b 100644 --- a/posthog/hogql/test/test_printer.py +++ b/posthog/hogql/test/test_printer.py @@ -114,6 +114,136 @@ def test_to_printed_hogql(self): repsponse, f"SELECT\n plus(1, 2),\n 3\nFROM\n events\nLIMIT {MAX_SELECT_RETURNED_ROWS}" ) + def test_intersect(self): + expr = parse_select("""select 1 as id intersect select 2 as id""") + response = to_printed_hogql(expr, self.team) + self.assertEqual( + response, + f"SELECT\n 1 AS id\nLIMIT 50000\nINTERSECT\nSELECT\n 2 AS id\nLIMIT {MAX_SELECT_RETURNED_ROWS}", + ) + + def test_except(self): + expr = parse_select("""select 1 as id except select 2 as id""") + response = to_printed_hogql(expr, self.team) + self.assertEqual( + response, + f"SELECT\n 1 AS id\nLIMIT 50000\nEXCEPT\nSELECT\n 2 AS id\nLIMIT {MAX_SELECT_RETURNED_ROWS}", + ) + + # these share the same priority, should stay in order + def test_except_and_union(self): + expr = parse_select("""select 1 as id except select 2 as id union all select 3 as id""") + response = to_printed_hogql(expr, self.team) + self.assertEqual( + response, + ( + "SELECT\n" + " 1 AS id\n" + "LIMIT 50000\n" + "EXCEPT\n" + "SELECT\n" + " 2 AS id\n" + "LIMIT 50000\n" + "UNION ALL\n" + "SELECT\n" + " 3 AS id\n" + "LIMIT 50000" + ), + ) + + def test_union_and_except(self): + expr = parse_select("""select 1 as id union all select 2 as id except select 3 as id""") + response = to_printed_hogql(expr, self.team) + self.assertEqual( + response, + ( + "SELECT\n" + " 1 AS id\n" + "LIMIT 50000\n" + "UNION ALL\n" + "SELECT\n" + " 2 AS id\n" + "LIMIT 50000\n" + "EXCEPT\n" + "SELECT\n" + " 3 AS id\n" + "LIMIT 50000" + ), + ) + + def test_intersect3(self): + expr = parse_select("""select 1 as id intersect select 2 as id intersect select 3 as id""") + response = to_printed_hogql(expr, self.team) + self.assertEqual( + response, + "SELECT\n" + " 1 AS id\n" + "LIMIT 50000\n" + "INTERSECT\n" + "SELECT\n" + " 2 AS id\n" + "LIMIT 50000\n" + "INTERSECT\n" + "SELECT\n" + " 3 AS id\n" + "LIMIT 50000", + ) + + def test_union3(self): + expr = parse_select("""select 1 as id union all select 2 as id union all select 3 as id""") + response = to_printed_hogql(expr, self.team) + self.assertEqual( + response, + "SELECT\n" + " 1 AS id\n" + "LIMIT 50000\n" + "UNION ALL\n" + "SELECT\n" + " 2 AS id\n" + "LIMIT 50000\n" + "UNION ALL\n" + "SELECT\n" + " 3 AS id\n" + "LIMIT 50000", + ) + + def test_intersect_and_union_parens(self): + expr = parse_select("""select 1 as id intersect (select 2 as id union all select 3 as id)""") + response = to_printed_hogql(expr, self.team) + self.assertEqual( + response, + "SELECT\n" + " 1 AS id\n" + "LIMIT 50000\n" + "INTERSECT\n" + "(SELECT\n" + " 2 AS id\n" + "UNION ALL\n" + "SELECT\n" + " 3 AS id)", + ) + + # INTERSECT has higher priority than union + def test_intersect_and_union(self): + expr = parse_select("""select 1 as id union all select 2 as id intersect select 3 as id""") + response = to_printed_hogql(expr, self.team) + self.assertEqual( + response, + ( + "SELECT\n" + " 1 AS id\n" + "LIMIT 50000\n" + "UNION ALL\n" + "SELECT\n" + " 2 AS id\n" + "LIMIT 50000\n" + "INTERSECT\n" + "SELECT\n" + " 3 AS id\n" + "LIMIT 50000" + ), + ) + def test_print_to_string(self): assert str(parse_select("select 1 + 2, 3 from events")) == "sql(SELECT plus(1, 2), 3 FROM events)" assert str(parse_expr("1 + 2")) == "sql(plus(1, 2))" @@ -1076,7 +1206,7 @@ def test_select_union_all(self): ) self.assertEqual( self._select("SELECT 1 UNION ALL (SELECT 1 UNION ALL SELECT 1) UNION ALL SELECT 1"), - f"SELECT 1 LIMIT {MAX_SELECT_RETURNED_ROWS} UNION ALL SELECT 1 LIMIT {MAX_SELECT_RETURNED_ROWS} UNION ALL SELECT 1 LIMIT {MAX_SELECT_RETURNED_ROWS} UNION ALL SELECT 1 LIMIT {MAX_SELECT_RETURNED_ROWS}", + f"SELECT 1 LIMIT {MAX_SELECT_RETURNED_ROWS} UNION ALL (SELECT 1 UNION ALL SELECT 1) UNION ALL SELECT 1 LIMIT {MAX_SELECT_RETURNED_ROWS}", ) self.assertEqual( self._select("SELECT 1 UNION ALL SELECT 1 UNION ALL SELECT 1 UNION ALL SELECT 1"), diff --git a/posthog/hogql/visitor.py b/posthog/hogql/visitor.py index 565346a169137..6b763b1d0812c 100644 --- a/posthog/hogql/visitor.py +++ b/posthog/hogql/visitor.py @@ -2,6 +2,7 @@ from typing import Optional, TypeVar, Generic, Any from posthog.hogql import ast +from posthog.hogql.ast import SelectSetNode from posthog.hogql.base import AST, Expr from posthog.hogql.errors import BaseHogQLError @@ -151,9 +152,10 @@ def visit_select_query(self, node: ast.SelectQuery): for expr in (node.window_exprs or {}).values(): self.visit(expr) - def visit_select_union_query(self, node: ast.SelectUnionQuery): - for expr in node.select_queries: - self.visit(expr) + def visit_select_set_query(self, node: ast.SelectSetQuery): + self.visit(node.initial_select_query) + for expr in node.subsequent_select_queries: + self.visit(expr.select_query) def visit_lambda_argument_type(self, node: ast.LambdaArgumentType): pass @@ -174,7 +176,7 @@ def visit_select_query_type(self, node: ast.SelectQueryType): for expr in node.columns.values(): self.visit(expr) - def visit_select_union_query_type(self, node: ast.SelectUnionQueryType): + def visit_select_set_query_type(self, node: ast.SelectSetQueryType): for type in node.types: self.visit(type) @@ -600,12 +602,16 @@ def visit_select_query(self, node: ast.SelectQuery): view_name=node.view_name, ) - def visit_select_union_query(self, node: ast.SelectUnionQuery): - return ast.SelectUnionQuery( + def visit_select_set_query(self, node: ast.SelectSetQuery): + return ast.SelectSetQuery( 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, - select_queries=[self.visit(expr) for expr in node.select_queries], + initial_select_query=self.visit(node.initial_select_query), + subsequent_select_queries=[ + SelectSetNode(set_operator=expr.set_operator, select_query=self.visit(expr.select_query)) + for expr in node.subsequent_select_queries + ], ) def visit_window_expr(self, node: ast.WindowExpr): diff --git a/posthog/hogql_queries/actors_query_runner.py b/posthog/hogql_queries/actors_query_runner.py index ba7301b5e0c51..cec4b7019f212 100644 --- a/posthog/hogql_queries/actors_query_runner.py +++ b/posthog/hogql_queries/actors_query_runner.py @@ -6,6 +6,7 @@ from posthog.hogql.constants import HogQLGlobalSettings from posthog.hogql.parser import parse_expr, parse_order_expr from posthog.hogql.property import has_aggregation +from posthog.hogql.resolver_utils import extract_select_queries from posthog.hogql_queries.actor_strategies import ActorStrategy, PersonStrategy, GroupStrategy from posthog.hogql_queries.insights.funnels.funnels_query_runner import FunnelsQueryRunner from posthog.hogql_queries.insights.insight_actors_query_runner import InsightActorsQueryRunner @@ -142,12 +143,12 @@ def input_columns(self) -> list[str]: return self.strategy.input_columns() # TODO: Figure out a more sure way of getting the actor id than using the alias or chain name - def source_id_column(self, source_query: ast.SelectQuery | ast.SelectUnionQuery) -> list[str]: + def source_id_column(self, source_query: ast.SelectQuery | ast.SelectSetQuery) -> list[str]: # Figure out the id column of the source query, first column that has id in the name if isinstance(source_query, ast.SelectQuery): select = source_query.select else: - select = source_query.select_queries[0].select + select = next(extract_select_queries(source_query)).select for column in select: if isinstance(column, ast.Alias) and (column.alias in ("group_key", "actor_id", "person_id")): diff --git a/posthog/hogql_queries/ai/actors_property_taxonomy_query_runner.py b/posthog/hogql_queries/ai/actors_property_taxonomy_query_runner.py index 1fdd2be57db54..167d1100f1558 100644 --- a/posthog/hogql_queries/ai/actors_property_taxonomy_query_runner.py +++ b/posthog/hogql_queries/ai/actors_property_taxonomy_query_runner.py @@ -49,7 +49,7 @@ def calculate(self): modifiers=self.modifiers, ) - def to_query(self) -> ast.SelectQuery | ast.SelectUnionQuery: + def to_query(self) -> ast.SelectQuery | ast.SelectSetQuery: query = ast.SelectQuery( select=[ ast.Call(name="groupArray", args=[ast.Field(chain=["prop"])], params=[ast.Constant(value=5)]), diff --git a/posthog/hogql_queries/ai/event_taxonomy_query_runner.py b/posthog/hogql_queries/ai/event_taxonomy_query_runner.py index 17677d23fa5d2..c00f2a4f771c4 100644 --- a/posthog/hogql_queries/ai/event_taxonomy_query_runner.py +++ b/posthog/hogql_queries/ai/event_taxonomy_query_runner.py @@ -49,7 +49,7 @@ def calculate(self): modifiers=self.modifiers, ) - def to_query(self) -> ast.SelectQuery | ast.SelectUnionQuery: + def to_query(self) -> ast.SelectQuery | ast.SelectSetQuery: query = parse_select( """ SELECT diff --git a/posthog/hogql_queries/ai/team_taxonomy_query_runner.py b/posthog/hogql_queries/ai/team_taxonomy_query_runner.py index e4c0823616898..17314fb0c74a8 100644 --- a/posthog/hogql_queries/ai/team_taxonomy_query_runner.py +++ b/posthog/hogql_queries/ai/team_taxonomy_query_runner.py @@ -43,7 +43,7 @@ def calculate(self): results=results, timings=response.timings, hogql=hogql, modifiers=self.modifiers ) - def to_query(self) -> ast.SelectQuery | ast.SelectUnionQuery: + def to_query(self) -> ast.SelectQuery | ast.SelectSetQuery: query = parse_select( """ SELECT diff --git a/posthog/hogql_queries/insights/funnels/base.py b/posthog/hogql_queries/insights/funnels/base.py index 9ddc1b4f26af2..87d7c2a4b0597 100644 --- a/posthog/hogql_queries/insights/funnels/base.py +++ b/posthog/hogql_queries/insights/funnels/base.py @@ -532,7 +532,7 @@ def _get_cohort_breakdown_join(self) -> ast.JoinExpr: return ast.JoinExpr( join_type="INNER JOIN", - table=ast.SelectUnionQuery(select_queries=cohort_queries), + table=ast.SelectSetQuery.create_from_queries(cohort_queries, "UNION ALL"), alias="cohort_join", constraint=ast.JoinConstraint( expr=ast.CompareOperation( diff --git a/posthog/hogql_queries/insights/funnels/funnel_correlation_query_runner.py b/posthog/hogql_queries/insights/funnels/funnel_correlation_query_runner.py index a633941817af0..f218976ad941c 100644 --- a/posthog/hogql_queries/insights/funnels/funnel_correlation_query_runner.py +++ b/posthog/hogql_queries/insights/funnels/funnel_correlation_query_runner.py @@ -332,7 +332,7 @@ def serialize_event_with_property(self, event: str) -> EventDefinition: return EventDefinition(event=event, properties={}, elements=[]) - def to_query(self) -> ast.SelectQuery | ast.SelectUnionQuery: + def to_query(self) -> ast.SelectQuery | ast.SelectSetQuery: """ Returns a query string and params, which are used to generate the contingency table. The query returns success and failure count for event / property values, along with total success and failure counts. @@ -345,7 +345,7 @@ def to_query(self) -> ast.SelectQuery | ast.SelectUnionQuery: return self.get_event_query() - def to_actors_query(self) -> ast.SelectQuery | ast.SelectUnionQuery: + def to_actors_query(self) -> ast.SelectQuery | ast.SelectSetQuery: assert self.correlation_actors_query is not None if self.query.funnelCorrelationType == FunnelCorrelationResultsType.PROPERTIES: @@ -362,7 +362,7 @@ def to_actors_query(self) -> ast.SelectQuery | ast.SelectUnionQuery: else: return self.events_actor_query() - def events_actor_query(self) -> ast.SelectQuery | ast.SelectUnionQuery: + def events_actor_query(self) -> ast.SelectQuery | ast.SelectSetQuery: assert self.correlation_actors_query is not None if not self.correlation_actors_query.funnelCorrelationPersonEntity: @@ -431,7 +431,7 @@ def events_actor_query(self) -> ast.SelectQuery | ast.SelectUnionQuery: def properties_actor_query( self, - ) -> ast.SelectQuery | ast.SelectUnionQuery: + ) -> ast.SelectQuery | ast.SelectSetQuery: assert self.correlation_actors_query is not None if not self.correlation_actors_query.funnelCorrelationPropertyValues: @@ -470,7 +470,7 @@ def properties_actor_query( return query - def get_event_query(self) -> ast.SelectQuery | ast.SelectUnionQuery: + def get_event_query(self) -> ast.SelectQuery | ast.SelectSetQuery: funnel_persons_query = self.get_funnel_actors_cte() event_join_query = self._get_events_join_query() target_step = self.context.max_steps @@ -548,7 +548,7 @@ def get_event_query(self) -> ast.SelectQuery | ast.SelectUnionQuery: return event_correlation_query - def get_event_property_query(self) -> ast.SelectQuery | ast.SelectUnionQuery: + def get_event_property_query(self) -> ast.SelectQuery | ast.SelectSetQuery: if not self.query.funnelCorrelationEventNames: raise ValidationError("Event Property Correlation expects atleast one event name to run correlation on") @@ -646,7 +646,7 @@ def get_event_property_query(self) -> ast.SelectQuery | ast.SelectUnionQuery: return query - def get_properties_query(self) -> ast.SelectQuery | ast.SelectUnionQuery: + def get_properties_query(self) -> ast.SelectQuery | ast.SelectSetQuery: if not self.query.funnelCorrelationNames: raise ValidationError("Property Correlation expects atleast one Property to run correlation on") diff --git a/posthog/hogql_queries/insights/funnels/funnel_unordered.py b/posthog/hogql_queries/insights/funnels/funnel_unordered.py index f718c7fe3e4df..8d39428c02449 100644 --- a/posthog/hogql_queries/insights/funnels/funnel_unordered.py +++ b/posthog/hogql_queries/insights/funnels/funnel_unordered.py @@ -115,7 +115,7 @@ def get_step_counts_without_aggregation_query(self): entities_to_use.append(entities_to_use.pop(0)) union_queries.append(formatted_query) - return ast.SelectUnionQuery(select_queries=union_queries) + return ast.SelectSetQuery.create_from_queries(union_queries, "UNION ALL") def _get_step_times(self, max_steps: int) -> list[ast.Expr]: windowInterval = self.context.funnelWindowInterval diff --git a/posthog/hogql_queries/insights/funnels/funnels_query_runner.py b/posthog/hogql_queries/insights/funnels/funnels_query_runner.py index 0e8a7919a76ec..ebafdace3acbc 100644 --- a/posthog/hogql_queries/insights/funnels/funnels_query_runner.py +++ b/posthog/hogql_queries/insights/funnels/funnels_query_runner.py @@ -76,7 +76,7 @@ def _refresh_frequency(self): def to_query(self) -> ast.SelectQuery: return self.funnel_class.get_query() - def to_actors_query(self) -> ast.SelectQuery | ast.SelectUnionQuery: + def to_actors_query(self) -> ast.SelectQuery | ast.SelectSetQuery: return self.funnel_actor_class.actor_query() def calculate(self): diff --git a/posthog/hogql_queries/insights/insight_actors_query_options_runner.py b/posthog/hogql_queries/insights/insight_actors_query_options_runner.py index 81cf2895d8c43..cb14a284774a0 100644 --- a/posthog/hogql_queries/insights/insight_actors_query_options_runner.py +++ b/posthog/hogql_queries/insights/insight_actors_query_options_runner.py @@ -21,7 +21,7 @@ class InsightActorsQueryOptionsRunner(QueryRunner): def source_runner(self) -> QueryRunner: return get_query_runner(self.query.source.source, self.team, self.timings, self.limit_context) - def to_query(self) -> ast.SelectQuery | ast.SelectUnionQuery: + def to_query(self) -> ast.SelectQuery | ast.SelectSetQuery: raise ValueError(f"Cannot convert source query of type {self.query.source.kind} to query") def calculate(self) -> InsightActorsQueryOptionsResponse: diff --git a/posthog/hogql_queries/insights/insight_actors_query_runner.py b/posthog/hogql_queries/insights/insight_actors_query_runner.py index c07c1e3687ab0..cc6ddca0fd0fd 100644 --- a/posthog/hogql_queries/insights/insight_actors_query_runner.py +++ b/posthog/hogql_queries/insights/insight_actors_query_runner.py @@ -33,7 +33,7 @@ class InsightActorsQueryRunner(QueryRunner): def source_runner(self) -> QueryRunner: return get_query_runner(self.query.source, self.team, self.timings, self.limit_context, self.modifiers) - def to_query(self) -> ast.SelectQuery | ast.SelectUnionQuery: + def to_query(self) -> ast.SelectQuery | ast.SelectSetQuery: if isinstance(self.source_runner, TrendsQueryRunner): trends_runner = cast(TrendsQueryRunner, self.source_runner) query = cast(InsightActorsQuery, self.query) @@ -73,7 +73,7 @@ def to_query(self) -> ast.SelectQuery | ast.SelectUnionQuery: raise ValueError(f"Cannot convert source query of type {self.query.source.kind} to persons query") - def to_actors_query(self) -> ast.SelectQuery | ast.SelectUnionQuery: + def to_actors_query(self) -> ast.SelectQuery | ast.SelectSetQuery: return self.to_query() @property diff --git a/posthog/hogql_queries/insights/lifecycle_query_runner.py b/posthog/hogql_queries/insights/lifecycle_query_runner.py index 1aaf3db5d01c7..d691074d3a032 100644 --- a/posthog/hogql_queries/insights/lifecycle_query_runner.py +++ b/posthog/hogql_queries/insights/lifecycle_query_runner.py @@ -33,7 +33,7 @@ class LifecycleQueryRunner(QueryRunner): response: LifecycleQueryResponse cached_response: CachedLifecycleQueryResponse - def to_query(self) -> ast.SelectQuery | ast.SelectUnionQuery: + def to_query(self) -> ast.SelectQuery | ast.SelectSetQuery: if self.query.samplingFactor == 0: counts_with_sampling = ast.Constant(value=0) elif self.query.samplingFactor is not None and self.query.samplingFactor != 1: @@ -95,7 +95,7 @@ def to_query(self) -> ast.SelectQuery | ast.SelectUnionQuery: def to_actors_query( self, day: Optional[str] = None, status: Optional[str] = None - ) -> ast.SelectQuery | ast.SelectUnionQuery: + ) -> ast.SelectQuery | ast.SelectSetQuery: with self.timings.measure("actors_query"): exprs = [] if day is not None: diff --git a/posthog/hogql_queries/insights/paths_query_runner.py b/posthog/hogql_queries/insights/paths_query_runner.py index dfacf5e90665f..09ad850140ef0 100644 --- a/posthog/hogql_queries/insights/paths_query_runner.py +++ b/posthog/hogql_queries/insights/paths_query_runner.py @@ -750,7 +750,7 @@ def get_edge_weight_exprs(self) -> list[ast.Expr]: ) return conditions - def to_query(self) -> ast.SelectQuery | ast.SelectUnionQuery: + def to_query(self) -> ast.SelectQuery | ast.SelectSetQuery: placeholders: dict[str, ast.Expr] = { "paths_per_person_query": self.paths_per_person_query(), } @@ -876,7 +876,7 @@ def calculate(self) -> PathsQueryResponse: def extra_event_fields_and_properties(self) -> list[str]: return self.extra_event_fields + self.extra_event_properties - def to_actors_query(self) -> ast.SelectQuery | ast.SelectUnionQuery: + def to_actors_query(self) -> ast.SelectQuery | ast.SelectSetQuery: # To include matching_events, we need to add extra fields and properties # TODO: Make sure going via self is the best way to do this self.extra_event_fields = ["uuid", "timestamp"] diff --git a/posthog/hogql_queries/insights/retention_query_runner.py b/posthog/hogql_queries/insights/retention_query_runner.py index 9f96ef654199b..5f1fbd57b4d95 100644 --- a/posthog/hogql_queries/insights/retention_query_runner.py +++ b/posthog/hogql_queries/insights/retention_query_runner.py @@ -316,7 +316,7 @@ def actor_query(self, breakdown_values_filter: Optional[int] = None, cumulative: return inner_query - def to_query(self) -> ast.SelectQuery | ast.SelectUnionQuery: + def to_query(self) -> ast.SelectQuery | ast.SelectSetQuery: with self.timings.measure("retention_query"): if self.query.retentionFilter.cumulative: actor_query = parse_select( diff --git a/posthog/hogql_queries/insights/stickiness_query_runner.py b/posthog/hogql_queries/insights/stickiness_query_runner.py index f0fc017165e8d..43928a4bd90e6 100644 --- a/posthog/hogql_queries/insights/stickiness_query_runner.py +++ b/posthog/hogql_queries/insights/stickiness_query_runner.py @@ -128,8 +128,8 @@ def _events_query(self, series_with_extra: SeriesWithExtras) -> ast.SelectQuery: return cast(ast.SelectQuery, select_query) - def to_query(self) -> ast.SelectUnionQuery: - return ast.SelectUnionQuery(select_queries=self.to_queries()) + def to_query(self) -> ast.SelectSetQuery: + return ast.SelectSetQuery.create_from_queries(self.to_queries(), "UNION ALL") def to_queries(self) -> list[ast.SelectQuery]: queries = [] @@ -170,7 +170,7 @@ def to_queries(self) -> list[ast.SelectQuery]: return queries - def to_actors_query(self, interval_num: Optional[int] = None) -> ast.SelectQuery | ast.SelectUnionQuery: + def to_actors_query(self, interval_num: Optional[int] = None) -> ast.SelectQuery | ast.SelectSetQuery: queries: list[ast.SelectQuery] = [] for series in self.series: @@ -194,7 +194,7 @@ def to_actors_query(self, interval_num: Optional[int] = None) -> ast.SelectQuery queries.append(events_query) - return ast.SelectUnionQuery(select_queries=queries) + return ast.SelectSetQuery.create_from_queries(queries, "UNION ALL") def calculate(self): queries = self.to_queries() diff --git a/posthog/hogql_queries/insights/trends/aggregation_operations.py b/posthog/hogql_queries/insights/trends/aggregation_operations.py index bea5230e45a1a..84e7c181f7c13 100644 --- a/posthog/hogql_queries/insights/trends/aggregation_operations.py +++ b/posthog/hogql_queries/insights/trends/aggregation_operations.py @@ -187,8 +187,8 @@ def _interval_function_name(self) -> str: return f"toStartOf{self.query_date_range.interval_name.title()}" def _actors_parent_select_query( - self, inner_query: ast.SelectQuery | ast.SelectUnionQuery - ) -> ast.SelectQuery | ast.SelectUnionQuery: + self, inner_query: ast.SelectQuery | ast.SelectSetQuery + ) -> ast.SelectQuery | ast.SelectSetQuery: if self.is_count_per_actor_variant(): query = parse_select( "SELECT total FROM {inner_query}", @@ -232,8 +232,8 @@ def _actors_parent_select_query( return query def _actors_inner_select_query( - self, cross_join_select_query: ast.SelectQuery | ast.SelectUnionQuery - ) -> ast.SelectQuery | ast.SelectUnionQuery: + self, cross_join_select_query: ast.SelectQuery | ast.SelectSetQuery + ) -> ast.SelectQuery | ast.SelectSetQuery: if self.is_count_per_actor_variant(): if self.series.math == "avg_count_per_actor": math_func = self._math_func("avg", ["total"]) @@ -308,7 +308,7 @@ def _actors_inner_select_query( def _actors_events_query( self, events_where_clause: ast.Expr, sample_value: ast.RatioExpr - ) -> ast.SelectQuery | ast.SelectUnionQuery: + ) -> ast.SelectQuery | ast.SelectSetQuery: date_from_with_lookback = "{date_from} - {inclusive_lookback}" if self.chart_display_type in NON_TIME_SERIES_DISPLAY_TYPES and self.series.math in ( BaseMathType.WEEKLY_ACTIVE, diff --git a/posthog/hogql_queries/insights/trends/display.py b/posthog/hogql_queries/insights/trends/display.py index 4a1229e7ba9c2..17d63daace954 100644 --- a/posthog/hogql_queries/insights/trends/display.py +++ b/posthog/hogql_queries/insights/trends/display.py @@ -31,7 +31,7 @@ def wrap_inner_query(self, inner_query: ast.SelectQuery, breakdown_enabled: bool def should_wrap_inner_query(self) -> bool: return self.display_type == ChartDisplayType.ACTIONS_LINE_GRAPH_CUMULATIVE - def _build_aggregate_dates(self, dates_queries: ast.SelectUnionQuery) -> ast.Expr: + def _build_aggregate_dates(self, dates_queries: ast.SelectSetQuery) -> ast.Expr: return parse_select( """ SELECT day_start @@ -49,7 +49,7 @@ def _build_aggregate_dates(self, dates_queries: ast.SelectUnionQuery) -> ast.Exp ) def modify_outer_query( - self, outer_query: ast.SelectQuery, inner_query: ast.SelectQuery, dates_queries: ast.SelectUnionQuery + self, outer_query: ast.SelectQuery, inner_query: ast.SelectQuery, dates_queries: ast.SelectSetQuery ) -> ast.SelectQuery: if not self.is_total_value(): return outer_query diff --git a/posthog/hogql_queries/insights/trends/trends_actors_query_builder.py b/posthog/hogql_queries/insights/trends/trends_actors_query_builder.py index 84f97da6e0c40..5cb5d2f669449 100644 --- a/posthog/hogql_queries/insights/trends/trends_actors_query_builder.py +++ b/posthog/hogql_queries/insights/trends/trends_actors_query_builder.py @@ -167,7 +167,7 @@ def is_explicit(self) -> bool: def is_total_value(self) -> bool: return self.trends_display.is_total_value() - def build_actors_query(self) -> ast.SelectQuery | ast.SelectUnionQuery: + def build_actors_query(self) -> ast.SelectQuery | ast.SelectSetQuery: return ast.SelectQuery( select=[ ast.Field(chain=["actor_id"]), diff --git a/posthog/hogql_queries/insights/trends/trends_query_builder.py b/posthog/hogql_queries/insights/trends/trends_query_builder.py index ee1165c41c624..ebc6f91d20186 100644 --- a/posthog/hogql_queries/insights/trends/trends_query_builder.py +++ b/posthog/hogql_queries/insights/trends/trends_query_builder.py @@ -60,7 +60,7 @@ def __init__( self.modifiers = modifiers self.limit_context = limit_context - def build_query(self) -> ast.SelectQuery | ast.SelectUnionQuery: + def build_query(self) -> ast.SelectQuery | ast.SelectSetQuery: breakdown = self.breakdown events_query = self._get_events_subquery(False, is_actors_query=False, breakdown=breakdown) @@ -73,7 +73,7 @@ def build_query(self) -> ast.SelectQuery | ast.SelectUnionQuery: def _get_wrapper_query( self, events_query: ast.SelectQuery, breakdown: Breakdown - ) -> ast.SelectQuery | ast.SelectUnionQuery: + ) -> ast.SelectQuery | ast.SelectSetQuery: if not breakdown.enabled: return events_query @@ -312,7 +312,7 @@ def _get_events_subquery( def _outer_select_query( self, breakdown: Breakdown, inner_query: ast.SelectQuery - ) -> ast.SelectQuery | ast.SelectUnionQuery: + ) -> ast.SelectQuery | ast.SelectSetQuery: total_array = parse_expr( """ arrayMap( @@ -453,7 +453,7 @@ def _get_breakdown_limit(self) -> int: ) or get_breakdown_limit_for_context(self.limit_context) def _inner_select_query( - self, breakdown: Breakdown, inner_query: ast.SelectQuery | ast.SelectUnionQuery + self, breakdown: Breakdown, inner_query: ast.SelectQuery | ast.SelectSetQuery ) -> ast.SelectQuery: query = cast( ast.SelectQuery, diff --git a/posthog/hogql_queries/insights/trends/trends_query_runner.py b/posthog/hogql_queries/insights/trends/trends_query_runner.py index 44cbf4cd5da0c..831adda7d5f14 100644 --- a/posthog/hogql_queries/insights/trends/trends_query_runner.py +++ b/posthog/hogql_queries/insights/trends/trends_query_runner.py @@ -110,16 +110,10 @@ def _refresh_frequency(self): return BASE_MINIMUM_INSIGHT_REFRESH_INTERVAL - def to_query(self) -> ast.SelectUnionQuery: - queries = [] - for query in self.to_queries(): - if isinstance(query, ast.SelectQuery): - queries.append(query) - else: - queries.extend(query.select_queries) - return ast.SelectUnionQuery(select_queries=queries) + def to_query(self) -> ast.SelectSetQuery: + return ast.SelectSetQuery.create_from_queries(self.to_queries(), "UNION ALL") - def to_queries(self) -> list[ast.SelectQuery | ast.SelectUnionQuery]: + def to_queries(self) -> list[ast.SelectQuery | ast.SelectSetQuery]: queries = [] with self.timings.measure("trends_to_query"): for series in self.series: @@ -154,7 +148,7 @@ def to_actors_query( breakdown_value: Optional[str | int | list[str]] = None, compare_value: Optional[Compare] = None, include_recordings: Optional[bool] = None, - ) -> ast.SelectQuery | ast.SelectUnionQuery: + ) -> ast.SelectQuery | ast.SelectSetQuery: with self.timings.measure("trends_to_actors_query"): if self.query.breakdownFilter and self.query.breakdownFilter.breakdown_type == BreakdownType.COHORT: if self.query.breakdownFilter.breakdown in ("all", ["all"]) or breakdown_value == "all": @@ -300,18 +294,16 @@ def to_actors_query_options(self) -> InsightActorsQueryOptionsResponse: def calculate(self): queries = self.to_queries() - if len(queries) == 1: - response_hogql_query = queries[0] + if len(queries) == 0: + response_hogql = "" else: - response_hogql_query = ast.SelectUnionQuery(select_queries=[]) - for query in queries: - if isinstance(query, ast.SelectQuery): - response_hogql_query.select_queries.append(query) - else: - response_hogql_query.select_queries.extend(query.select_queries) + if len(queries) == 1: + response_hogql_query = queries[0] + else: + response_hogql_query = ast.SelectSetQuery.create_from_queries(queries, "UNION ALL") - with self.timings.measure("printing_hogql_for_response"): - response_hogql = to_printed_hogql(response_hogql_query, self.team, self.modifiers) + with self.timings.measure("printing_hogql_for_response"): + response_hogql = to_printed_hogql(response_hogql_query, self.team, self.modifiers) res_matrix: list[list[Any] | Any | None] = [None] * len(queries) timings_matrix: list[list[QueryTiming] | None] = [None] * (2 + len(queries)) @@ -320,7 +312,7 @@ def calculate(self): def run( index: int, - query: ast.SelectQuery | ast.SelectUnionQuery, + query: ast.SelectQuery | ast.SelectSetQuery, timings: HogQLTimings, is_parallel: bool, query_tags: Optional[dict] = None, diff --git a/posthog/hogql_queries/insights/utils/aggregations.py b/posthog/hogql_queries/insights/utils/aggregations.py index 084ee58905c20..cb4fd72377759 100644 --- a/posthog/hogql_queries/insights/utils/aggregations.py +++ b/posthog/hogql_queries/insights/utils/aggregations.py @@ -11,7 +11,7 @@ class QueryAlternator: _group_bys: list[ast.Expr] _select_from: ast.JoinExpr | None - def __init__(self, query: ast.SelectQuery | ast.SelectUnionQuery): + def __init__(self, query: ast.SelectQuery | ast.SelectSetQuery): assert isinstance(query, ast.SelectQuery) self._query = query @@ -19,7 +19,7 @@ def __init__(self, query: ast.SelectQuery | ast.SelectUnionQuery): self._group_bys = [] self._select_from = None - def build(self) -> ast.SelectQuery | ast.SelectUnionQuery: + def build(self) -> ast.SelectQuery | ast.SelectSetQuery: if len(self._selects) > 0: self._query.select.extend(self._selects) diff --git a/posthog/hogql_queries/query_runner.py b/posthog/hogql_queries/query_runner.py index 44d5abfe3c16c..4c13f82346011 100644 --- a/posthog/hogql_queries/query_runner.py +++ b/posthog/hogql_queries/query_runner.py @@ -708,10 +708,10 @@ def run( return fresh_response @abstractmethod - def to_query(self) -> ast.SelectQuery | ast.SelectUnionQuery: + def to_query(self) -> ast.SelectQuery | ast.SelectSetQuery: raise NotImplementedError() - def to_actors_query(self, *args, **kwargs) -> ast.SelectQuery | ast.SelectUnionQuery: + def to_actors_query(self, *args, **kwargs) -> ast.SelectQuery | ast.SelectSetQuery: # TODO: add support for selecting and filtering by breakdowns raise NotImplementedError() diff --git a/posthog/hogql_queries/web_analytics/top_clicks.py b/posthog/hogql_queries/web_analytics/top_clicks.py index c2324e7ec10f9..38c4e35dacd42 100644 --- a/posthog/hogql_queries/web_analytics/top_clicks.py +++ b/posthog/hogql_queries/web_analytics/top_clicks.py @@ -16,7 +16,7 @@ class WebTopClicksQueryRunner(WebAnalyticsQueryRunner): response: WebTopClicksQueryResponse cached_response: CachedWebTopClicksQueryResponse - def to_query(self) -> ast.SelectQuery | ast.SelectUnionQuery: + def to_query(self) -> ast.SelectQuery | ast.SelectSetQuery: with self.timings.measure("top_clicks_query"): top_sources_query = parse_select( """ diff --git a/posthog/hogql_queries/web_analytics/web_goals.py b/posthog/hogql_queries/web_analytics/web_goals.py index 2b14c6236f6f8..0d03b8b0a64b4 100644 --- a/posthog/hogql_queries/web_analytics/web_goals.py +++ b/posthog/hogql_queries/web_analytics/web_goals.py @@ -24,7 +24,7 @@ class WebGoalsQueryRunner(WebAnalyticsQueryRunner): response: WebGoalsQueryResponse cached_response: CachedWebGoalsQueryResponse - def to_query(self) -> ast.SelectQuery | ast.SelectUnionQuery: + def to_query(self) -> ast.SelectQuery | ast.SelectSetQuery: with self.timings.measure("date_expr"): start = self.query_date_range.date_from_as_hogql() end = self.query_date_range.date_to_as_hogql() diff --git a/posthog/hogql_queries/web_analytics/web_overview.py b/posthog/hogql_queries/web_analytics/web_overview.py index 022f918e0913e..6e7e3ac7d6bd5 100644 --- a/posthog/hogql_queries/web_analytics/web_overview.py +++ b/posthog/hogql_queries/web_analytics/web_overview.py @@ -28,7 +28,7 @@ class WebOverviewQueryRunner(WebAnalyticsQueryRunner): response: WebOverviewQueryResponse cached_response: CachedWebOverviewQueryResponse - def to_query(self) -> ast.SelectQuery | ast.SelectUnionQuery: + def to_query(self) -> ast.SelectQuery | ast.SelectSetQuery: return self.outer_select def calculate(self): diff --git a/posthog/models/cohort/util.py b/posthog/models/cohort/util.py index 1d18d632bd030..6d8de53b0e8de 100644 --- a/posthog/models/cohort/util.py +++ b/posthog/models/cohort/util.py @@ -7,6 +7,8 @@ from django.conf import settings from django.utils import timezone from rest_framework.exceptions import ValidationError + +from posthog.hogql.resolver_utils import extract_select_queries from posthog.queries.util import PersonPropertiesMode from posthog.clickhouse.client.connection import Workload from posthog.clickhouse.query_tagging import tag_queries @@ -83,8 +85,7 @@ def print_cohort_hogql_query(cohort: Cohort, hogql_context: HogQLContext) -> str cast(dict, cohort.query), team=cast(Team, cohort.team), limit_context=LimitContext.COHORT_CALCULATION ).to_query() - select_queries: list[ast.SelectQuery] = [query] if isinstance(query, ast.SelectQuery) else query.select_queries - for select_query in select_queries: + for select_query in extract_select_queries(query): columns: dict[str, ast.Expr] = {} for expr in select_query.select: if isinstance(expr, ast.Alias): diff --git a/posthog/session_recordings/queries/session_recording_list_from_filters.py b/posthog/session_recordings/queries/session_recording_list_from_filters.py index 26649ef7165e3..46fb0664c56b7 100644 --- a/posthog/session_recordings/queries/session_recording_list_from_filters.py +++ b/posthog/session_recordings/queries/session_recording_list_from_filters.py @@ -328,7 +328,7 @@ def __init__(self, team: Team, filter: SessionRecordingsFilter, ttl_days: int): self._filter = filter self._ttl_days = ttl_days - def get_query(self) -> ast.SelectQuery | ast.SelectUnionQuery | None: + def get_query(self) -> ast.SelectQuery | ast.SelectSetQuery | None: if self.person_properties and not poe_is_active(self._team): return parse_select( """ @@ -383,7 +383,7 @@ def __init__(self, team: Team, filter: SessionRecordingsFilter, ttl_days: int): self._filter = filter self._ttl_days = ttl_days - def get_query(self) -> ast.SelectQuery | ast.SelectUnionQuery | None: + def get_query(self) -> ast.SelectQuery | ast.SelectSetQuery | None: if self.cohort_properties: return parse_select( self.raw_cohort_to_distinct_id, @@ -433,7 +433,7 @@ def get_operation(self) -> CompareOperation | None: right=q, ) - def get_query(self) -> ast.SelectQuery | ast.SelectUnionQuery | None: + def get_query(self) -> ast.SelectQuery | ast.SelectSetQuery | None: if not self._filter.person_uuid: return None @@ -529,14 +529,14 @@ def _select_from_events(self, select_expr: ast.Expr) -> ast.SelectQuery: group_by=[ast.Field(chain=["$session_id"])], ) - def get_query_for_session_id_matching(self) -> ast.SelectQuery | ast.SelectUnionQuery | None: + def get_query_for_session_id_matching(self) -> ast.SelectQuery | ast.SelectSetQuery | None: use_poe = poe_is_active(self._team) and self.person_properties if self._filter.entities or self.event_properties or self.group_properties or use_poe: return self._select_from_events(ast.Alias(alias="session_id", expr=ast.Field(chain=["$session_id"]))) else: return None - def get_query_for_event_id_matching(self) -> ast.SelectQuery | ast.SelectUnionQuery: + def get_query_for_event_id_matching(self) -> ast.SelectQuery | ast.SelectSetQuery: return self._select_from_events(ast.Call(name="groupUniqArray", args=[ast.Field(chain=["uuid"])])) def get_event_ids_for_session(self) -> SessionRecordingQueryResult: diff --git a/posthog/warehouse/models/modeling.py b/posthog/warehouse/models/modeling.py index 3cc6272c3685f..9e7dcefa4c0a3 100644 --- a/posthog/warehouse/models/modeling.py +++ b/posthog/warehouse/models/modeling.py @@ -10,6 +10,7 @@ from posthog.hogql import ast from posthog.hogql.database.database import Database, create_hogql_database from posthog.hogql.parser import parse_select +from posthog.hogql.resolver_utils import extract_select_queries from posthog.models.team import Team from posthog.models.user import User from posthog.models.utils import ( @@ -99,8 +100,8 @@ def get_parents_from_model_query(model_query: str) -> set[str]: hogql_query = parse_select(model_query) - if isinstance(hogql_query, ast.SelectUnionQuery): - queries = hogql_query.select_queries + if isinstance(hogql_query, ast.SelectSetQuery): + queries = list(extract_select_queries(hogql_query)) else: queries = [hogql_query] @@ -114,8 +115,8 @@ def get_parents_from_model_query(model_query: str) -> set[str]: for name, cte in query.ctes.items(): ctes.add(name) - if isinstance(cte.expr, ast.SelectUnionQuery): - queries.extend(cte.expr.select_queries) + if isinstance(cte.expr, ast.SelectSetQuery): + queries.extend(list(extract_select_queries(cte.expr))) elif isinstance(cte.expr, ast.SelectQuery): queries.append(cte.expr) @@ -130,8 +131,8 @@ def get_parents_from_model_query(model_query: str) -> set[str]: continue queries.append(join.table) - elif isinstance(join.table, ast.SelectUnionQuery): - queries.extend(join.table.select_queries) + elif isinstance(join.table, ast.SelectSetQuery): + queries.extend(list(extract_select_queries(join.table))) while join is not None: parent_name = join.table.chain[0] # type: ignore diff --git a/requirements.in b/requirements.in index 619c6a06cdaaf..b0e87e51b2175 100644 --- a/requirements.in +++ b/requirements.in @@ -105,7 +105,7 @@ phonenumberslite==8.13.6 openai==1.51.2 tiktoken==0.8.0 nh3==0.2.14 -hogql-parser==1.0.45 +hogql-parser==1.0.46 zxcvbn==4.4.28 zstd==1.5.5.1 xmlsec==1.3.13 # Do not change this version - it will break SAML diff --git a/requirements.txt b/requirements.txt index 82798318498ef..ef080dcdeef7c 100644 --- a/requirements.txt +++ b/requirements.txt @@ -282,7 +282,7 @@ h11==0.13.0 # wsproto hexbytes==1.0.0 # via dlt -hogql-parser==1.0.45 +hogql-parser==1.0.46 # via -r requirements.in httpcore==1.0.2 # via httpx From 8d01d5ef546b136be94e9567b06c241af8c59da9 Mon Sep 17 00:00:00 2001 From: Zach Waterfield Date: Tue, 29 Oct 2024 17:17:27 -0400 Subject: [PATCH 06/14] feat: rbac initial set up (#25745) Co-authored-by: github-actions <41898282+github-actions[bot]@users.noreply.github.com> --- ee/api/feature_flag_role_access.py | 6 +- .../organization_resource_access.py | 4 +- ee/api/{ => rbac}/role.py | 4 +- ee/api/test/test_feature_flag.py | 4 +- ee/api/test/test_feature_flag_role_access.py | 4 +- .../test/test_organization_resource_access.py | 2 +- ee/api/test/test_role.py | 4 +- ee/api/test/test_role_membership.py | 2 +- ee/models/__init__.py | 2 +- .../organization_resource_access.py | 2 + ee/models/{ => rbac}/role.py | 2 +- ee/urls.py | 5 +- frontend/src/lib/constants.tsx | 1 + .../settings/user/personalAPIKeysLogic.tsx | 4 +- frontend/src/types.ts | 31 ++++++++++ posthog/api/personal_api_key.py | 3 +- posthog/api/project.py | 2 +- posthog/api/routing.py | 2 +- posthog/api/team.py | 2 +- .../api/test/__snapshots__/test_api_docs.ambr | 6 +- .../test/test_organization_feature_flag.py | 2 +- posthog/models/feature_flag/permissions.py | 2 +- posthog/models/personal_api_key.py | 55 +---------------- posthog/models/scopes.py | 60 +++++++++++++++++++ posthog/permissions.py | 2 +- 25 files changed, 128 insertions(+), 85 deletions(-) rename ee/api/{ => rbac}/organization_resource_access.py (92%) rename ee/api/{ => rbac}/role.py (97%) rename ee/models/{ => rbac}/organization_resource_access.py (95%) rename ee/models/{ => rbac}/role.py (95%) create mode 100644 posthog/models/scopes.py diff --git a/ee/api/feature_flag_role_access.py b/ee/api/feature_flag_role_access.py index 6d03c7a4f361c..01aa98a05b9db 100644 --- a/ee/api/feature_flag_role_access.py +++ b/ee/api/feature_flag_role_access.py @@ -1,10 +1,10 @@ from rest_framework import exceptions, mixins, serializers, viewsets from rest_framework.permissions import SAFE_METHODS, BasePermission -from ee.api.role import RoleSerializer +from ee.api.rbac.role import RoleSerializer from ee.models.feature_flag_role_access import FeatureFlagRoleAccess -from ee.models.organization_resource_access import OrganizationResourceAccess -from ee.models.role import Role +from ee.models.rbac.organization_resource_access import OrganizationResourceAccess +from ee.models.rbac.role import Role from posthog.api.feature_flag import FeatureFlagSerializer from posthog.api.routing import TeamAndOrgViewSetMixin from posthog.models import FeatureFlag diff --git a/ee/api/organization_resource_access.py b/ee/api/rbac/organization_resource_access.py similarity index 92% rename from ee/api/organization_resource_access.py rename to ee/api/rbac/organization_resource_access.py index bf886566605b5..9722fc7b02eac 100644 --- a/ee/api/organization_resource_access.py +++ b/ee/api/rbac/organization_resource_access.py @@ -1,7 +1,7 @@ from rest_framework import mixins, serializers, viewsets -from ee.api.role import RolePermissions -from ee.models.organization_resource_access import OrganizationResourceAccess +from ee.api.rbac.role import RolePermissions +from ee.models.rbac.organization_resource_access import OrganizationResourceAccess from posthog.api.routing import TeamAndOrgViewSetMixin diff --git a/ee/api/role.py b/ee/api/rbac/role.py similarity index 97% rename from ee/api/role.py rename to ee/api/rbac/role.py index 96041cd0109ef..ccf8acef1f1dc 100644 --- a/ee/api/role.py +++ b/ee/api/rbac/role.py @@ -5,8 +5,8 @@ from rest_framework.permissions import SAFE_METHODS, BasePermission from ee.models.feature_flag_role_access import FeatureFlagRoleAccess -from ee.models.organization_resource_access import OrganizationResourceAccess -from ee.models.role import Role, RoleMembership +from ee.models.rbac.organization_resource_access import OrganizationResourceAccess +from ee.models.rbac.role import Role, RoleMembership from posthog.api.organization_member import OrganizationMemberSerializer from posthog.api.routing import TeamAndOrgViewSetMixin from posthog.api.shared import UserBasicSerializer diff --git a/ee/api/test/test_feature_flag.py b/ee/api/test/test_feature_flag.py index e3dd5849d607c..0bc7292f7a875 100644 --- a/ee/api/test/test_feature_flag.py +++ b/ee/api/test/test_feature_flag.py @@ -1,6 +1,6 @@ from ee.api.test.base import APILicensedTest -from ee.models.organization_resource_access import OrganizationResourceAccess -from ee.models.role import Role, RoleMembership +from ee.models.rbac.organization_resource_access import OrganizationResourceAccess +from ee.models.rbac.role import Role, RoleMembership from posthog.models.feature_flag import FeatureFlag from posthog.models.organization import OrganizationMembership diff --git a/ee/api/test/test_feature_flag_role_access.py b/ee/api/test/test_feature_flag_role_access.py index 3cd4e947d90c9..d73c1c7384493 100644 --- a/ee/api/test/test_feature_flag_role_access.py +++ b/ee/api/test/test_feature_flag_role_access.py @@ -2,8 +2,8 @@ from ee.api.test.base import APILicensedTest from ee.models.feature_flag_role_access import FeatureFlagRoleAccess -from ee.models.organization_resource_access import OrganizationResourceAccess -from ee.models.role import Role +from ee.models.rbac.organization_resource_access import OrganizationResourceAccess +from ee.models.rbac.role import Role from posthog.models.feature_flag import FeatureFlag from posthog.models.organization import OrganizationMembership from posthog.models.user import User diff --git a/ee/api/test/test_organization_resource_access.py b/ee/api/test/test_organization_resource_access.py index 9123214a092db..98206fe519f44 100644 --- a/ee/api/test/test_organization_resource_access.py +++ b/ee/api/test/test_organization_resource_access.py @@ -2,7 +2,7 @@ from rest_framework import status from ee.api.test.base import APILicensedTest -from ee.models.organization_resource_access import OrganizationResourceAccess +from ee.models.rbac.organization_resource_access import OrganizationResourceAccess from posthog.models.organization import Organization, OrganizationMembership from posthog.test.base import QueryMatchingTest, snapshot_postgres_queries, FuzzyInt diff --git a/ee/api/test/test_role.py b/ee/api/test/test_role.py index 1a3068ff4cf4f..96503162d5fe9 100644 --- a/ee/api/test/test_role.py +++ b/ee/api/test/test_role.py @@ -2,8 +2,8 @@ from rest_framework import status from ee.api.test.base import APILicensedTest -from ee.models.organization_resource_access import OrganizationResourceAccess -from ee.models.role import Role +from ee.models.rbac.organization_resource_access import OrganizationResourceAccess +from ee.models.rbac.role import Role from posthog.models.organization import Organization, OrganizationMembership diff --git a/ee/api/test/test_role_membership.py b/ee/api/test/test_role_membership.py index f89796d9b7c4f..c3e67cf0514d2 100644 --- a/ee/api/test/test_role_membership.py +++ b/ee/api/test/test_role_membership.py @@ -1,7 +1,7 @@ from rest_framework import status from ee.api.test.base import APILicensedTest -from ee.models.role import Role, RoleMembership +from ee.models.rbac.role import Role, RoleMembership from posthog.models.organization import Organization, OrganizationMembership from posthog.models.user import User diff --git a/ee/models/__init__.py b/ee/models/__init__.py index fd87f76bd54eb..ff5a8fe2dff40 100644 --- a/ee/models/__init__.py +++ b/ee/models/__init__.py @@ -5,7 +5,7 @@ from .hook import Hook from .license import License from .property_definition import EnterprisePropertyDefinition -from .role import Role, RoleMembership +from .rbac.role import Role, RoleMembership __all__ = [ "EnterpriseEventDefinition", diff --git a/ee/models/organization_resource_access.py b/ee/models/rbac/organization_resource_access.py similarity index 95% rename from ee/models/organization_resource_access.py rename to ee/models/rbac/organization_resource_access.py index 924b3e9db2855..de4c86d95a8bc 100644 --- a/ee/models/organization_resource_access.py +++ b/ee/models/rbac/organization_resource_access.py @@ -2,6 +2,8 @@ from posthog.models.organization import Organization +# NOTE: This will be deprecated in favour of the AccessControl model + class OrganizationResourceAccess(models.Model): class AccessLevel(models.IntegerChoices): diff --git a/ee/models/role.py b/ee/models/rbac/role.py similarity index 95% rename from ee/models/role.py rename to ee/models/rbac/role.py index f37170818dbc3..97201835adb1a 100644 --- a/ee/models/role.py +++ b/ee/models/rbac/role.py @@ -1,6 +1,6 @@ from django.db import models -from ee.models.organization_resource_access import OrganizationResourceAccess +from ee.models.rbac.organization_resource_access import OrganizationResourceAccess from posthog.models.utils import UUIDModel diff --git a/ee/urls.py b/ee/urls.py index f0cf168acffb0..7c722bc31852f 100644 --- a/ee/urls.py +++ b/ee/urls.py @@ -6,6 +6,7 @@ from django.urls.conf import path from ee.api import integration +from .api.rbac import organization_resource_access, role from .api import ( authentication, @@ -15,8 +16,6 @@ feature_flag_role_access, hooks, license, - organization_resource_access, - role, sentry_stats, subscription, ) @@ -49,6 +48,7 @@ def extend_api_router() -> None: "organization_role_memberships", ["organization_id", "role_id"], ) + # Start: routes to be deprecated project_feature_flags_router.register( r"role_access", feature_flag_role_access.FeatureFlagRoleAccessViewSet, @@ -61,6 +61,7 @@ def extend_api_router() -> None: "organization_resource_access", ["organization_id"], ) + # End: routes to be deprecated register_grandfathered_environment_nested_viewset(r"hooks", hooks.HookViewSet, "environment_hooks", ["team_id"]) register_grandfathered_environment_nested_viewset( r"explicit_members", diff --git a/frontend/src/lib/constants.tsx b/frontend/src/lib/constants.tsx index 3d563ed32d7da..1ba86ab79c36b 100644 --- a/frontend/src/lib/constants.tsx +++ b/frontend/src/lib/constants.tsx @@ -220,6 +220,7 @@ export const FEATURE_FLAGS = { LEGACY_ACTION_WEBHOOKS: 'legacy-action-webhooks', // owner: @mariusandra #team-cdp SESSION_REPLAY_URL_TRIGGER: 'session-replay-url-trigger', // owner: @richard-better #team-replay REPLAY_TEMPLATES: 'replay-templates', // owner: @raquelmsmith #team-replay + ROLE_BASED_ACCESS_CONTROL: 'role-based-access-control', // owner: @zach EXPERIMENTS_HOLDOUTS: 'experiments-holdouts', // owner: @jurajmajerik #team-experiments MESSAGING: 'messaging', // owner @mariusandra #team-cdp SESSION_REPLAY_URL_BLOCKLIST: 'session-replay-url-blocklist', // owner: @richard-better #team-replay diff --git a/frontend/src/scenes/settings/user/personalAPIKeysLogic.tsx b/frontend/src/scenes/settings/user/personalAPIKeysLogic.tsx index e4f78f929def5..be47278635896 100644 --- a/frontend/src/scenes/settings/user/personalAPIKeysLogic.tsx +++ b/frontend/src/scenes/settings/user/personalAPIKeysLogic.tsx @@ -9,7 +9,7 @@ import { lemonToast } from 'lib/lemon-ui/LemonToast/LemonToast' import { urls } from 'scenes/urls' import { userLogic } from 'scenes/userLogic' -import { OrganizationBasicType, PersonalAPIKeyType, TeamBasicType } from '~/types' +import { APIScopeObject, OrganizationBasicType, PersonalAPIKeyType, TeamBasicType } from '~/types' import type { personalAPIKeysLogicType } from './personalAPIKeysLogicType' @@ -32,7 +32,7 @@ export const API_KEY_SCOPE_PRESETS = [ ] export type APIScope = { - key: string + key: APIScopeObject info?: string | JSX.Element disabledActions?: ('read' | 'write')[] disabledWhenProjectScoped?: boolean diff --git a/frontend/src/types.ts b/frontend/src/types.ts index 6b78307b81774..eb839f5252bcd 100644 --- a/frontend/src/types.ts +++ b/frontend/src/types.ts @@ -3821,6 +3821,37 @@ export interface RoleMemberType { user_uuid: string } +export type APIScopeObject = + | 'action' + | 'activity_log' + | 'annotation' + | 'batch_export' + | 'cohort' + | 'dashboard' + | 'dashboard_template' + | 'early_access_feature' + | 'event_definition' + | 'experiment' + | 'export' + | 'feature_flag' + | 'group' + | 'insight' + | 'query' + | 'notebook' + | 'organization' + | 'organization_member' + | 'person' + | 'plugin' + | 'project' + | 'property_definition' + | 'session_recording' + | 'session_recording_playlist' + | 'sharing_configuration' + | 'subscription' + | 'survey' + | 'user' + | 'webhook' + export interface OrganizationResourcePermissionType { id: string resource: Resource diff --git a/posthog/api/personal_api_key.py b/posthog/api/personal_api_key.py index 23f6d531693a0..355d6cc1c189a 100644 --- a/posthog/api/personal_api_key.py +++ b/posthog/api/personal_api_key.py @@ -5,7 +5,8 @@ from rest_framework.permissions import IsAuthenticated from posthog.models import PersonalAPIKey, User -from posthog.models.personal_api_key import API_SCOPE_ACTIONS, API_SCOPE_OBJECTS, hash_key_value, mask_key_value +from posthog.models.personal_api_key import hash_key_value, mask_key_value +from posthog.models.scopes import API_SCOPE_ACTIONS, API_SCOPE_OBJECTS from posthog.models.team.team import Team from posthog.models.utils import generate_random_token_personal from posthog.permissions import TimeSensitiveActionPermission diff --git a/posthog/api/project.py b/posthog/api/project.py index 8efca11b21968..c740dc330801a 100644 --- a/posthog/api/project.py +++ b/posthog/api/project.py @@ -30,7 +30,7 @@ from posthog.models.async_deletion import AsyncDeletion, DeletionType from posthog.models.group_type_mapping import GroupTypeMapping from posthog.models.organization import OrganizationMembership -from posthog.models.personal_api_key import APIScopeObjectOrNotSupported +from posthog.models.scopes import APIScopeObjectOrNotSupported from posthog.models.product_intent.product_intent import ProductIntent from posthog.models.project import Project from posthog.models.signals import mute_selected_signals diff --git a/posthog/api/routing.py b/posthog/api/routing.py index 9ff2fede76449..084ddcc94c3ae 100644 --- a/posthog/api/routing.py +++ b/posthog/api/routing.py @@ -18,7 +18,7 @@ SharingAccessTokenAuthentication, ) from posthog.models.organization import Organization -from posthog.models.personal_api_key import APIScopeObjectOrNotSupported +from posthog.models.scopes import APIScopeObjectOrNotSupported from posthog.models.project import Project from posthog.models.team import Team from posthog.models.user import User diff --git a/posthog/api/team.py b/posthog/api/team.py index 148471919cbc0..88b7f5e28b5ec 100644 --- a/posthog/api/team.py +++ b/posthog/api/team.py @@ -28,7 +28,7 @@ from posthog.models.async_deletion import AsyncDeletion, DeletionType from posthog.models.group_type_mapping import GroupTypeMapping from posthog.models.organization import OrganizationMembership -from posthog.models.personal_api_key import APIScopeObjectOrNotSupported +from posthog.models.scopes import APIScopeObjectOrNotSupported from posthog.models.project import Project from posthog.models.signals import mute_selected_signals from posthog.models.team.util import delete_batch_exports, delete_bulky_postgres_data diff --git a/posthog/api/test/__snapshots__/test_api_docs.ambr b/posthog/api/test/__snapshots__/test_api_docs.ambr index 6ef31c6530176..2abd070a74e07 100644 --- a/posthog/api/test/__snapshots__/test_api_docs.ambr +++ b/posthog/api/test/__snapshots__/test_api_docs.ambr @@ -70,9 +70,9 @@ '/home/runner/work/posthog/posthog/posthog/api/project.py: Warning [ProjectViewSet > ProjectBackwardCompatSerializer]: unable to resolve type hint for function "get_product_intents". Consider using a type hint or @extend_schema_field. Defaulting to string.', '/home/runner/work/posthog/posthog/posthog/api/proxy_record.py: Warning [ProxyRecordViewset]: could not derive type of path parameter "organization_id" because it is untyped and obtaining queryset from the viewset failed. Consider adding a type to the path (e.g. ) or annotating the parameter type with @extend_schema. Defaulting to "string".', '/home/runner/work/posthog/posthog/posthog/api/proxy_record.py: Warning [ProxyRecordViewset]: could not derive type of path parameter "id" because it is untyped and obtaining queryset from the viewset failed. Consider adding a type to the path (e.g. ) or annotating the parameter type with @extend_schema. Defaulting to "string".', - '/home/runner/work/posthog/posthog/ee/api/role.py: Warning [RoleViewSet > RoleSerializer]: unable to resolve type hint for function "get_members". Consider using a type hint or @extend_schema_field. Defaulting to string.', - '/home/runner/work/posthog/posthog/ee/api/role.py: Warning [RoleViewSet > RoleSerializer]: unable to resolve type hint for function "get_associated_flags". Consider using a type hint or @extend_schema_field. Defaulting to string.', - '/home/runner/work/posthog/posthog/ee/api/role.py: Warning [RoleMembershipViewSet]: could not derive type of path parameter "organization_id" because model "ee.models.role.RoleMembership" contained no such field. Consider annotating parameter with @extend_schema. Defaulting to "string".', + '/home/runner/work/posthog/posthog/ee/api/rbac/role.py: Warning [RoleViewSet > RoleSerializer]: unable to resolve type hint for function "get_members". Consider using a type hint or @extend_schema_field. Defaulting to string.', + '/home/runner/work/posthog/posthog/ee/api/rbac/role.py: Warning [RoleViewSet > RoleSerializer]: unable to resolve type hint for function "get_associated_flags". Consider using a type hint or @extend_schema_field. Defaulting to string.', + '/home/runner/work/posthog/posthog/ee/api/rbac/role.py: Warning [RoleMembershipViewSet]: could not derive type of path parameter "organization_id" because model "ee.models.rbac.role.RoleMembership" contained no such field. Consider annotating parameter with @extend_schema. Defaulting to "string".', '/home/runner/work/posthog/posthog/posthog/api/action.py: Warning [ActionViewSet]: could not derive type of path parameter "project_id" because model "posthog.models.action.action.Action" contained no such field. Consider annotating parameter with @extend_schema. Defaulting to "string".', '/home/runner/work/posthog/posthog/posthog/api/action.py: Warning [ActionViewSet > ActionSerializer]: unable to resolve type hint for function "get_creation_context". Consider using a type hint or @extend_schema_field. Defaulting to string.', '/home/runner/work/posthog/posthog/posthog/api/activity_log.py: Warning [ActivityLogViewSet]: could not derive type of path parameter "project_id" because model "posthog.models.activity_logging.activity_log.ActivityLog" contained no such field. Consider annotating parameter with @extend_schema. Defaulting to "string".', diff --git a/posthog/api/test/test_organization_feature_flag.py b/posthog/api/test/test_organization_feature_flag.py index 83550c689d5ae..65c43575f9b7e 100644 --- a/posthog/api/test/test_organization_feature_flag.py +++ b/posthog/api/test/test_organization_feature_flag.py @@ -3,7 +3,7 @@ from rest_framework import status -from ee.models.organization_resource_access import OrganizationResourceAccess +from ee.models.rbac.organization_resource_access import OrganizationResourceAccess from posthog.api.dashboards.dashboard import Dashboard from posthog.constants import AvailableFeature from posthog.models import FeatureFlag diff --git a/posthog/models/feature_flag/permissions.py b/posthog/models/feature_flag/permissions.py index 8f766b4fccc60..d2b0bb858a403 100644 --- a/posthog/models/feature_flag/permissions.py +++ b/posthog/models/feature_flag/permissions.py @@ -6,7 +6,7 @@ def can_user_edit_feature_flag(request, feature_flag): # self hosted check for enterprise models that may not exist try: from ee.models.feature_flag_role_access import FeatureFlagRoleAccess - from ee.models.organization_resource_access import OrganizationResourceAccess + from ee.models.rbac.organization_resource_access import OrganizationResourceAccess except: return True else: diff --git a/posthog/models/personal_api_key.py b/posthog/models/personal_api_key.py index ea886b55757c6..cac5adefbc65d 100644 --- a/posthog/models/personal_api_key.py +++ b/posthog/models/personal_api_key.py @@ -1,4 +1,4 @@ -from typing import Optional, Literal, get_args +from typing import Optional, Literal import hashlib from django.contrib.auth.hashers import PBKDF2PasswordHasher @@ -66,56 +66,3 @@ class PersonalAPIKey(models.Model): null=True, blank=True, ) - - -## API Scopes -# These are the scopes that are used to define the permissions of the API tokens. -# Not every model needs a scope - it should more be for top-level things -# Typically each object should have `read` and `write` scopes, but some objects may have more specific scopes - -# WARNING: Make sure to keep in sync with the frontend! -APIScopeObject = Literal[ - "action", - "activity_log", - "annotation", - "batch_export", - "cohort", - "dashboard", - "dashboard_template", - "early_access_feature", - "event_definition", - "experiment", - "export", - "feature_flag", - "group", - "insight", - "query", # Covers query and events endpoints - "notebook", - "organization", - "organization_member", - "person", - "plugin", - "project", - "property_definition", - "session_recording", - "session_recording_playlist", - "sharing_configuration", - "subscription", - "survey", - "user", - "webhook", -] - -APIScopeActions = Literal[ - "read", - "write", -] - -APIScopeObjectOrNotSupported = Literal[ - APIScopeObject, - "INTERNAL", -] - - -API_SCOPE_OBJECTS: tuple[APIScopeObject, ...] = get_args(APIScopeObject) -API_SCOPE_ACTIONS: tuple[APIScopeActions, ...] = get_args(APIScopeActions) diff --git a/posthog/models/scopes.py b/posthog/models/scopes.py new file mode 100644 index 0000000000000..2bd0d48b405e5 --- /dev/null +++ b/posthog/models/scopes.py @@ -0,0 +1,60 @@ +## API Scopes +# These are the scopes that are used to define the permissions of the API tokens. +# Not every model needs a scope - it should more be for top-level things +# Typically each object should have `read` and `write` scopes, but some objects may have more specific scopes + +# WARNING: Make sure to keep in sync with the frontend! +from typing import Literal, get_args + + +## API Scopes +# These are the scopes that are used to define the permissions of the API tokens. +# Not every model needs a scope - it should more be for top-level things +# Typically each object should have `read` and `write` scopes, but some objects may have more specific scopes + +# WARNING: Make sure to keep in sync with the frontend! +APIScopeObject = Literal[ + "action", + "activity_log", + "annotation", + "batch_export", + "cohort", + "dashboard", + "dashboard_template", + "early_access_feature", + "event_definition", + "experiment", + "export", + "feature_flag", + "group", + "insight", + "query", # Covers query and events endpoints + "notebook", + "organization", + "organization_member", + "person", + "plugin", + "project", + "property_definition", + "session_recording", + "session_recording_playlist", + "sharing_configuration", + "subscription", + "survey", + "user", + "webhook", +] + +APIScopeActions = Literal[ + "read", + "write", +] + +APIScopeObjectOrNotSupported = Literal[ + APIScopeObject, + "INTERNAL", +] + + +API_SCOPE_OBJECTS: tuple[APIScopeObject, ...] = get_args(APIScopeObject) +API_SCOPE_ACTIONS: tuple[APIScopeActions, ...] = get_args(APIScopeActions) diff --git a/posthog/permissions.py b/posthog/permissions.py index 889832c13baa7..6de160e099567 100644 --- a/posthog/permissions.py +++ b/posthog/permissions.py @@ -19,7 +19,7 @@ from posthog.cloud_utils import is_cloud from posthog.exceptions import EnterpriseFeatureException from posthog.models import Organization, OrganizationMembership, Team, User -from posthog.models.personal_api_key import APIScopeObjectOrNotSupported +from posthog.models.scopes import APIScopeObjectOrNotSupported from posthog.utils import get_can_create_org CREATE_METHODS = ["POST", "PUT"] From 13f48d74d07e8e925f73f7e0c5ae59091372e64f Mon Sep 17 00:00:00 2001 From: Phani Raj Date: Tue, 29 Oct 2024 17:05:25 -0500 Subject: [PATCH 07/14] fix(Surveys): Allow Personal API Keys to read responses_count for surveys (#25879) This PR fixes the api endpoint for responses_count to accept a person API token with the survey:read scope. Reported by a user on zendesk --- posthog/api/survey.py | 2 +- .../api/test/__snapshots__/test_api_docs.ambr | 2 +- posthog/api/test/test_survey.py | 36 ++++ .../test/__snapshots__/test_trends.ambr | 204 +++--------------- 4 files changed, 70 insertions(+), 174 deletions(-) diff --git a/posthog/api/survey.py b/posthog/api/survey.py index ea894a7dd30c0..4864612c2b438 100644 --- a/posthog/api/survey.py +++ b/posthog/api/survey.py @@ -597,7 +597,7 @@ def destroy(self, request: Request, *args: Any, **kwargs: Any) -> Response: return super().destroy(request, *args, **kwargs) - @action(methods=["GET"], detail=False) + @action(methods=["GET"], detail=False, required_scopes=["survey:read"]) def responses_count(self, request: request.Request, **kwargs): earliest_survey_start_date = Survey.objects.filter(team_id=self.team_id).aggregate(Min("start_date"))[ "start_date__min" diff --git a/posthog/api/test/__snapshots__/test_api_docs.ambr b/posthog/api/test/__snapshots__/test_api_docs.ambr index 2abd070a74e07..9221776ff38d1 100644 --- a/posthog/api/test/__snapshots__/test_api_docs.ambr +++ b/posthog/api/test/__snapshots__/test_api_docs.ambr @@ -97,8 +97,8 @@ '/home/runner/work/posthog/posthog/posthog/api/survey.py: Warning [SurveyViewSet > SurveySerializer]: unable to resolve type hint for function "get_conditions". Consider using a type hint or @extend_schema_field. Defaulting to string.', '/home/runner/work/posthog/posthog/posthog/api/web_experiment.py: Warning [WebExperimentViewSet]: could not derive type of path parameter "project_id" because model "posthog.models.web_experiment.WebExperiment" contained no such field. Consider annotating parameter with @extend_schema. Defaulting to "string".', 'Warning: encountered multiple names for the same choice set (HrefMatchingEnum). This may be unwanted even though the generated schema is technically correct. Add an entry to ENUM_NAME_OVERRIDES to fix the naming.', - 'Warning: enum naming encountered a non-optimally resolvable collision for fields named "kind". The same name has been used for multiple choice sets in multiple components. The collision was resolved with "Kind069Enum". add an entry to ENUM_NAME_OVERRIDES to fix the naming.', 'Warning: enum naming encountered a non-optimally resolvable collision for fields named "kind". The same name has been used for multiple choice sets in multiple components. The collision was resolved with "KindCfaEnum". add an entry to ENUM_NAME_OVERRIDES to fix the naming.', + 'Warning: enum naming encountered a non-optimally resolvable collision for fields named "kind". The same name has been used for multiple choice sets in multiple components. The collision was resolved with "Kind069Enum". add an entry to ENUM_NAME_OVERRIDES to fix the naming.', 'Warning: enum naming encountered a non-optimally resolvable collision for fields named "type". The same name has been used for multiple choice sets in multiple components. The collision was resolved with "TypeF73Enum". add an entry to ENUM_NAME_OVERRIDES to fix the naming.', 'Warning: encountered multiple names for the same choice set (EffectivePrivilegeLevelEnum). This may be unwanted even though the generated schema is technically correct. Add an entry to ENUM_NAME_OVERRIDES to fix the naming.', 'Warning: encountered multiple names for the same choice set (MembershipLevelEnum). This may be unwanted even though the generated schema is technically correct. Add an entry to ENUM_NAME_OVERRIDES to fix the naming.', diff --git a/posthog/api/test/test_survey.py b/posthog/api/test/test_survey.py index c6de95a44702e..c79ab601b3369 100644 --- a/posthog/api/test/test_survey.py +++ b/posthog/api/test/test_survey.py @@ -11,6 +11,7 @@ from rest_framework import status from posthog.api.survey import nh3_clean_with_allow_list +from posthog.api.test.test_personal_api_keys import PersonalAPIKeysBaseTest from posthog.constants import AvailableFeature from posthog.models import Action, FeatureFlag, Team from posthog.models.cohort.cohort import Cohort @@ -2783,6 +2784,41 @@ def test_list_surveys_excludes_description(self): assert surveys[1]["name"] == "Survey 2" +class TestSurveyAPITokens(PersonalAPIKeysBaseTest, APIBaseTest): + def setUp(self): + super().setUp() + self.key.scopes = ["survey:read"] + self.key.save() + + @freeze_time("2024-05-01 14:40:09") + def test_responses_count_works_with_survey_read(self): + survey_counts = { + "d63bb580-01af-4819-aae5-edcf7ef2044f": 3, + "fe7c4b62-8fc9-401e-b483-e4ff98fd13d5": 6, + "daed7689-d498-49fe-936f-e85554351b6c": 100, + } + + earliest_survey = Survey.objects.create(team_id=self.team.id) + earliest_survey.start_date = datetime.now() - timedelta(days=101) + earliest_survey.save() + + for survey_id, count in survey_counts.items(): + for _ in range(count): + _create_event( + event="survey sent", + team=self.team, + distinct_id=self.user.id, + properties={"$survey_id": survey_id}, + timestamp=datetime.now() - timedelta(days=count), + ) + + response = self._do_request(f"/api/projects/{self.team.id}/surveys/responses_count") + self.assertEqual(response.status_code, status.HTTP_200_OK) + + data = response.json() + self.assertEqual(data, survey_counts) + + class TestResponsesCount(ClickhouseTestMixin, APIBaseTest): @snapshot_clickhouse_queries @freeze_time("2024-05-01 14:40:09") diff --git a/posthog/hogql_queries/insights/trends/test/__snapshots__/test_trends.ambr b/posthog/hogql_queries/insights/trends/test/__snapshots__/test_trends.ambr index 4ae57feb8cb96..6027f7ca7bb42 100644 --- a/posthog/hogql_queries/insights/trends/test/__snapshots__/test_trends.ambr +++ b/posthog/hogql_queries/insights/trends/test/__snapshots__/test_trends.ambr @@ -851,49 +851,14 @@ # --- # name: TestTrends.test_dau_with_breakdown_filtering_with_sampling.1 ''' - SELECT groupArray(1)(date)[1] AS date, - arrayFold((acc, x) -> arrayMap(i -> plus(acc[i], x[i]), range(1, plus(length(date), 1))), groupArray(ifNull(total, 0)), arrayWithConstant(length(date), reinterpretAsFloat64(0))) AS total, - if(ifNull(ifNull(greaterOrEquals(row_number, 25), 0), 0), '$$_posthog_breakdown_other_$$', breakdown_value) AS breakdown_value - FROM - (SELECT arrayMap(number -> plus(toStartOfDay(assumeNotNull(parseDateTime64BestEffortOrNull('2019-12-28 00:00:00', 6, 'UTC'))), toIntervalDay(number)), range(0, plus(coalesce(dateDiff('day', toStartOfDay(assumeNotNull(parseDateTime64BestEffortOrNull('2019-12-28 00:00:00', 6, 'UTC'))), toStartOfDay(assumeNotNull(parseDateTime64BestEffortOrNull('2020-01-04 23:59:59', 6, 'UTC'))))), 1))) AS date, - arrayMap(_match_date -> arraySum(arraySlice(groupArray(ifNull(count, 0)), indexOf(groupArray(day_start) AS _days_for_count, _match_date) AS _index, plus(minus(arrayLastIndex(x -> ifNull(equals(x, _match_date), isNull(x) - and isNull(_match_date)), _days_for_count), _index), 1))), date) AS total, - breakdown_value AS breakdown_value, - rowNumberInAllBlocks() AS row_number - FROM - (SELECT sum(total) AS count, - day_start AS day_start, - breakdown_value AS breakdown_value - FROM - (SELECT count(DISTINCT if(not(empty(e__override.distinct_id)), e__override.person_id, e.person_id)) AS total, - toStartOfDay(toTimeZone(e.timestamp, 'UTC')) AS day_start, - ifNull(nullIf(toString(replaceRegexpAll(nullIf(nullIf(JSONExtractRaw(e.properties, '$some_property'), ''), 'null'), '^"|"$', '')), ''), '$$_posthog_breakdown_null_$$') AS breakdown_value - FROM events AS e SAMPLE 1.0 - LEFT OUTER JOIN - (SELECT argMax(person_distinct_id_overrides.person_id, person_distinct_id_overrides.version) AS person_id, - person_distinct_id_overrides.distinct_id AS distinct_id - FROM person_distinct_id_overrides - WHERE equals(person_distinct_id_overrides.team_id, 2) - GROUP BY person_distinct_id_overrides.distinct_id - HAVING ifNull(equals(argMax(person_distinct_id_overrides.is_deleted, person_distinct_id_overrides.version), 0), 0) SETTINGS optimize_aggregation_in_order=1) AS e__override ON equals(e.distinct_id, e__override.distinct_id) - WHERE and(equals(e.team_id, 2), greaterOrEquals(toTimeZone(e.timestamp, 'UTC'), toStartOfDay(assumeNotNull(parseDateTime64BestEffortOrNull('2019-12-28 00:00:00', 6, 'UTC')))), lessOrEquals(toTimeZone(e.timestamp, 'UTC'), assumeNotNull(parseDateTime64BestEffortOrNull('2020-01-04 23:59:59', 6, 'UTC'))), equals(e.event, 'sign up')) - GROUP BY day_start, - breakdown_value) - GROUP BY day_start, - breakdown_value - ORDER BY day_start ASC, breakdown_value ASC) - GROUP BY breakdown_value - ORDER BY if(ifNull(equals(breakdown_value, '$$_posthog_breakdown_other_$$'), 0), 2, if(ifNull(equals(breakdown_value, '$$_posthog_breakdown_null_$$'), 0), 1, 0)) ASC, arraySum(total) DESC, breakdown_value ASC) - WHERE isNotNull(breakdown_value) - GROUP BY breakdown_value - ORDER BY if(ifNull(equals(breakdown_value, '$$_posthog_breakdown_other_$$'), 0), 2, if(ifNull(equals(breakdown_value, '$$_posthog_breakdown_null_$$'), 0), 1, 0)) ASC, arraySum(total) DESC, breakdown_value ASC - LIMIT 50000 SETTINGS readonly=2, - max_execution_time=60, - allow_experimental_object_type=1, - format_csv_allow_double_quotes=0, - max_ast_elements=4000000, - max_expanded_ast_elements=4000000, - max_bytes_before_external_group_by=0 + /* celery:posthog.tasks.tasks.sync_insight_caching_state */ + SELECT team_id, + date_diff('second', max(timestamp), now()) AS age + FROM events + WHERE timestamp > date_sub(DAY, 3, now()) + AND timestamp < now() + GROUP BY team_id + ORDER BY age; ''' # --- # name: TestTrends.test_dau_with_breakdown_filtering_with_sampling.10 @@ -1110,143 +1075,38 @@ # --- # name: TestTrends.test_dau_with_breakdown_filtering_with_sampling.2 ''' - SELECT groupArray(1)(date)[1] AS date, - arrayFold((acc, x) -> arrayMap(i -> plus(acc[i], x[i]), range(1, plus(length(date), 1))), groupArray(ifNull(total, 0)), arrayWithConstant(length(date), reinterpretAsFloat64(0))) AS total, - if(ifNull(ifNull(greaterOrEquals(row_number, 25), 0), 0), '$$_posthog_breakdown_other_$$', breakdown_value) AS breakdown_value - FROM - (SELECT arrayMap(number -> plus(toStartOfDay(assumeNotNull(parseDateTime64BestEffortOrNull('2019-12-28 00:00:00', 6, 'UTC'))), toIntervalDay(number)), range(0, plus(coalesce(dateDiff('day', toStartOfDay(assumeNotNull(parseDateTime64BestEffortOrNull('2019-12-28 00:00:00', 6, 'UTC'))), toStartOfDay(assumeNotNull(parseDateTime64BestEffortOrNull('2020-01-04 23:59:59', 6, 'UTC'))))), 1))) AS date, - arrayMap(_match_date -> arraySum(arraySlice(groupArray(ifNull(count, 0)), indexOf(groupArray(day_start) AS _days_for_count, _match_date) AS _index, plus(minus(arrayLastIndex(x -> ifNull(equals(x, _match_date), isNull(x) - and isNull(_match_date)), _days_for_count), _index), 1))), date) AS total, - breakdown_value AS breakdown_value, - rowNumberInAllBlocks() AS row_number - FROM - (SELECT sum(total) AS count, - day_start AS day_start, - breakdown_value AS breakdown_value - FROM - (SELECT count(DISTINCT if(not(empty(e__override.distinct_id)), e__override.person_id, e.person_id)) AS total, - toStartOfDay(toTimeZone(e.timestamp, 'UTC')) AS day_start, - ifNull(nullIf(toString(replaceRegexpAll(nullIf(nullIf(JSONExtractRaw(e.properties, '$some_property'), ''), 'null'), '^"|"$', '')), ''), '$$_posthog_breakdown_null_$$') AS breakdown_value - FROM events AS e SAMPLE 1.0 - LEFT OUTER JOIN - (SELECT argMax(person_distinct_id_overrides.person_id, person_distinct_id_overrides.version) AS person_id, - person_distinct_id_overrides.distinct_id AS distinct_id - FROM person_distinct_id_overrides - WHERE equals(person_distinct_id_overrides.team_id, 2) - GROUP BY person_distinct_id_overrides.distinct_id - HAVING ifNull(equals(argMax(person_distinct_id_overrides.is_deleted, person_distinct_id_overrides.version), 0), 0) SETTINGS optimize_aggregation_in_order=1) AS e__override ON equals(e.distinct_id, e__override.distinct_id) - WHERE and(equals(e.team_id, 2), greaterOrEquals(toTimeZone(e.timestamp, 'UTC'), toStartOfDay(assumeNotNull(parseDateTime64BestEffortOrNull('2019-12-28 00:00:00', 6, 'UTC')))), lessOrEquals(toTimeZone(e.timestamp, 'UTC'), assumeNotNull(parseDateTime64BestEffortOrNull('2020-01-04 23:59:59', 6, 'UTC'))), equals(e.event, 'sign up')) - GROUP BY day_start, - breakdown_value) - GROUP BY day_start, - breakdown_value - ORDER BY day_start ASC, breakdown_value ASC) - GROUP BY breakdown_value - ORDER BY if(ifNull(equals(breakdown_value, '$$_posthog_breakdown_other_$$'), 0), 2, if(ifNull(equals(breakdown_value, '$$_posthog_breakdown_null_$$'), 0), 1, 0)) ASC, arraySum(total) DESC, breakdown_value ASC) - WHERE isNotNull(breakdown_value) - GROUP BY breakdown_value - ORDER BY if(ifNull(equals(breakdown_value, '$$_posthog_breakdown_other_$$'), 0), 2, if(ifNull(equals(breakdown_value, '$$_posthog_breakdown_null_$$'), 0), 1, 0)) ASC, arraySum(total) DESC, breakdown_value ASC - LIMIT 50000 SETTINGS readonly=2, - max_execution_time=60, - allow_experimental_object_type=1, - format_csv_allow_double_quotes=0, - max_ast_elements=4000000, - max_expanded_ast_elements=4000000, - max_bytes_before_external_group_by=0 + /* celery:posthog.tasks.tasks.sync_insight_caching_state */ + SELECT team_id, + date_diff('second', max(timestamp), now()) AS age + FROM events + WHERE timestamp > date_sub(DAY, 3, now()) + AND timestamp < now() + GROUP BY team_id + ORDER BY age; ''' # --- # name: TestTrends.test_dau_with_breakdown_filtering_with_sampling.3 ''' - SELECT groupArray(1)(date)[1] AS date, - arrayFold((acc, x) -> arrayMap(i -> plus(acc[i], x[i]), range(1, plus(length(date), 1))), groupArray(ifNull(total, 0)), arrayWithConstant(length(date), reinterpretAsFloat64(0))) AS total, - arrayMap(i -> if(ifNull(ifNull(greaterOrEquals(row_number, 25), 0), 0), '$$_posthog_breakdown_other_$$', i), breakdown_value) AS breakdown_value - FROM - (SELECT arrayMap(number -> plus(toStartOfDay(assumeNotNull(parseDateTime64BestEffortOrNull('2019-12-28 00:00:00', 6, 'UTC'))), toIntervalDay(number)), range(0, plus(coalesce(dateDiff('day', toStartOfDay(assumeNotNull(parseDateTime64BestEffortOrNull('2019-12-28 00:00:00', 6, 'UTC'))), toStartOfDay(assumeNotNull(parseDateTime64BestEffortOrNull('2020-01-04 23:59:59', 6, 'UTC'))))), 1))) AS date, - arrayMap(_match_date -> arraySum(arraySlice(groupArray(ifNull(count, 0)), indexOf(groupArray(day_start) AS _days_for_count, _match_date) AS _index, plus(minus(arrayLastIndex(x -> ifNull(equals(x, _match_date), isNull(x) - and isNull(_match_date)), _days_for_count), _index), 1))), date) AS total, - breakdown_value AS breakdown_value, - rowNumberInAllBlocks() AS row_number - FROM - (SELECT sum(total) AS count, - day_start AS day_start, - [ifNull(toString(breakdown_value_1), '$$_posthog_breakdown_null_$$')] AS breakdown_value - FROM - (SELECT count(DISTINCT if(not(empty(e__override.distinct_id)), e__override.person_id, e.person_id)) AS total, - toStartOfDay(toTimeZone(e.timestamp, 'UTC')) AS day_start, - ifNull(nullIf(toString(replaceRegexpAll(nullIf(nullIf(JSONExtractRaw(e.properties, '$some_property'), ''), 'null'), '^"|"$', '')), ''), '$$_posthog_breakdown_null_$$') AS breakdown_value_1 - FROM events AS e SAMPLE 1.0 - LEFT OUTER JOIN - (SELECT argMax(person_distinct_id_overrides.person_id, person_distinct_id_overrides.version) AS person_id, - person_distinct_id_overrides.distinct_id AS distinct_id - FROM person_distinct_id_overrides - WHERE equals(person_distinct_id_overrides.team_id, 2) - GROUP BY person_distinct_id_overrides.distinct_id - HAVING ifNull(equals(argMax(person_distinct_id_overrides.is_deleted, person_distinct_id_overrides.version), 0), 0) SETTINGS optimize_aggregation_in_order=1) AS e__override ON equals(e.distinct_id, e__override.distinct_id) - WHERE and(equals(e.team_id, 2), greaterOrEquals(toTimeZone(e.timestamp, 'UTC'), toStartOfDay(assumeNotNull(parseDateTime64BestEffortOrNull('2019-12-28 00:00:00', 6, 'UTC')))), lessOrEquals(toTimeZone(e.timestamp, 'UTC'), assumeNotNull(parseDateTime64BestEffortOrNull('2020-01-04 23:59:59', 6, 'UTC'))), equals(e.event, 'sign up')) - GROUP BY day_start, - breakdown_value_1) - GROUP BY day_start, - breakdown_value_1 - ORDER BY day_start ASC, breakdown_value ASC) - GROUP BY breakdown_value - ORDER BY if(has(breakdown_value, '$$_posthog_breakdown_other_$$'), 2, if(has(breakdown_value, '$$_posthog_breakdown_null_$$'), 1, 0)) ASC, arraySum(total) DESC, breakdown_value ASC) - WHERE arrayExists(x -> isNotNull(x), breakdown_value) - GROUP BY breakdown_value - ORDER BY if(has(breakdown_value, '$$_posthog_breakdown_other_$$'), 2, if(has(breakdown_value, '$$_posthog_breakdown_null_$$'), 1, 0)) ASC, arraySum(total) DESC, breakdown_value ASC - LIMIT 50000 SETTINGS readonly=2, - max_execution_time=60, - allow_experimental_object_type=1, - format_csv_allow_double_quotes=0, - max_ast_elements=4000000, - max_expanded_ast_elements=4000000, - max_bytes_before_external_group_by=0 + /* celery:posthog.tasks.tasks.sync_insight_caching_state */ + SELECT team_id, + date_diff('second', max(timestamp), now()) AS age + FROM events + WHERE timestamp > date_sub(DAY, 3, now()) + AND timestamp < now() + GROUP BY team_id + ORDER BY age; ''' # --- # name: TestTrends.test_dau_with_breakdown_filtering_with_sampling.4 ''' - SELECT groupArray(1)(date)[1] AS date, - arrayFold((acc, x) -> arrayMap(i -> plus(acc[i], x[i]), range(1, plus(length(date), 1))), groupArray(ifNull(total, 0)), arrayWithConstant(length(date), reinterpretAsFloat64(0))) AS total, - arrayMap(i -> if(ifNull(ifNull(greaterOrEquals(row_number, 25), 0), 0), '$$_posthog_breakdown_other_$$', i), breakdown_value) AS breakdown_value - FROM - (SELECT arrayMap(number -> plus(toStartOfDay(assumeNotNull(parseDateTime64BestEffortOrNull('2019-12-28 00:00:00', 6, 'UTC'))), toIntervalDay(number)), range(0, plus(coalesce(dateDiff('day', toStartOfDay(assumeNotNull(parseDateTime64BestEffortOrNull('2019-12-28 00:00:00', 6, 'UTC'))), toStartOfDay(assumeNotNull(parseDateTime64BestEffortOrNull('2020-01-04 23:59:59', 6, 'UTC'))))), 1))) AS date, - arrayMap(_match_date -> arraySum(arraySlice(groupArray(ifNull(count, 0)), indexOf(groupArray(day_start) AS _days_for_count, _match_date) AS _index, plus(minus(arrayLastIndex(x -> ifNull(equals(x, _match_date), isNull(x) - and isNull(_match_date)), _days_for_count), _index), 1))), date) AS total, - breakdown_value AS breakdown_value, - rowNumberInAllBlocks() AS row_number - FROM - (SELECT sum(total) AS count, - day_start AS day_start, - [ifNull(toString(breakdown_value_1), '$$_posthog_breakdown_null_$$')] AS breakdown_value - FROM - (SELECT count(DISTINCT if(not(empty(e__override.distinct_id)), e__override.person_id, e.person_id)) AS total, - toStartOfDay(toTimeZone(e.timestamp, 'UTC')) AS day_start, - ifNull(nullIf(toString(replaceRegexpAll(nullIf(nullIf(JSONExtractRaw(e.properties, '$some_property'), ''), 'null'), '^"|"$', '')), ''), '$$_posthog_breakdown_null_$$') AS breakdown_value_1 - FROM events AS e SAMPLE 1.0 - LEFT OUTER JOIN - (SELECT argMax(person_distinct_id_overrides.person_id, person_distinct_id_overrides.version) AS person_id, - person_distinct_id_overrides.distinct_id AS distinct_id - FROM person_distinct_id_overrides - WHERE equals(person_distinct_id_overrides.team_id, 2) - GROUP BY person_distinct_id_overrides.distinct_id - HAVING ifNull(equals(argMax(person_distinct_id_overrides.is_deleted, person_distinct_id_overrides.version), 0), 0) SETTINGS optimize_aggregation_in_order=1) AS e__override ON equals(e.distinct_id, e__override.distinct_id) - WHERE and(equals(e.team_id, 2), greaterOrEquals(toTimeZone(e.timestamp, 'UTC'), toStartOfDay(assumeNotNull(parseDateTime64BestEffortOrNull('2019-12-28 00:00:00', 6, 'UTC')))), lessOrEquals(toTimeZone(e.timestamp, 'UTC'), assumeNotNull(parseDateTime64BestEffortOrNull('2020-01-04 23:59:59', 6, 'UTC'))), equals(e.event, 'sign up')) - GROUP BY day_start, - breakdown_value_1) - GROUP BY day_start, - breakdown_value_1 - ORDER BY day_start ASC, breakdown_value ASC) - GROUP BY breakdown_value - ORDER BY if(has(breakdown_value, '$$_posthog_breakdown_other_$$'), 2, if(has(breakdown_value, '$$_posthog_breakdown_null_$$'), 1, 0)) ASC, arraySum(total) DESC, breakdown_value ASC) - WHERE arrayExists(x -> isNotNull(x), breakdown_value) - GROUP BY breakdown_value - ORDER BY if(has(breakdown_value, '$$_posthog_breakdown_other_$$'), 2, if(has(breakdown_value, '$$_posthog_breakdown_null_$$'), 1, 0)) ASC, arraySum(total) DESC, breakdown_value ASC - LIMIT 50000 SETTINGS readonly=2, - max_execution_time=60, - allow_experimental_object_type=1, - format_csv_allow_double_quotes=0, - max_ast_elements=4000000, - max_expanded_ast_elements=4000000, - max_bytes_before_external_group_by=0 + /* celery:posthog.tasks.tasks.sync_insight_caching_state */ + SELECT team_id, + date_diff('second', max(timestamp), now()) AS age + FROM events + WHERE timestamp > date_sub(DAY, 3, now()) + AND timestamp < now() + GROUP BY team_id + ORDER BY age; ''' # --- # name: TestTrends.test_dau_with_breakdown_filtering_with_sampling.5 From bfa9c7bc7142f9ee5afb20ef97c97e683dd69f11 Mon Sep 17 00:00:00 2001 From: Robbie Date: Wed, 30 Oct 2024 10:14:30 +0000 Subject: [PATCH 08/14] fix(sessions): Limit the teams for which we ingest sessions v1 events (#25766) Co-authored-by: github-actions <41898282+github-actions[bot]@users.noreply.github.com> --- ...create_sessions_v1_after_limiting_teams.py | 8 ++ .../test/__snapshots__/test_schema.ambr | 2 +- .../clickhouse/test/test_sessions_model.py | 53 +++++---- .../database/schema/test/test_sessions_v1.py | 78 ++++-------- ...ssion_attribution_explorer_query_runner.py | 29 ++--- .../web_analytics/test/test_web_overview.py | 38 ++---- .../test/test_web_stats_table.py | 112 +++++------------- posthog/models/sessions/sql.py | 30 ++++- 8 files changed, 143 insertions(+), 207 deletions(-) create mode 100644 posthog/clickhouse/migrations/0083_recreate_sessions_v1_after_limiting_teams.py diff --git a/posthog/clickhouse/migrations/0083_recreate_sessions_v1_after_limiting_teams.py b/posthog/clickhouse/migrations/0083_recreate_sessions_v1_after_limiting_teams.py new file mode 100644 index 0000000000000..d0da2eb158b6d --- /dev/null +++ b/posthog/clickhouse/migrations/0083_recreate_sessions_v1_after_limiting_teams.py @@ -0,0 +1,8 @@ +from posthog.clickhouse.client.migration_tools import run_sql_with_exceptions +from posthog.models.sessions.sql import DROP_SESSION_MATERIALIZED_VIEW_SQL, SESSIONS_TABLE_MV_SQL + +operations = [ + # drop the mv, and recreate it with the new part of the WHERE clause + run_sql_with_exceptions(DROP_SESSION_MATERIALIZED_VIEW_SQL()), + run_sql_with_exceptions(SESSIONS_TABLE_MV_SQL()), +] diff --git a/posthog/clickhouse/test/__snapshots__/test_schema.ambr b/posthog/clickhouse/test/__snapshots__/test_schema.ambr index bc5a623ed0cdc..1fc54f30fdc78 100644 --- a/posthog/clickhouse/test/__snapshots__/test_schema.ambr +++ b/posthog/clickhouse/test/__snapshots__/test_schema.ambr @@ -2160,7 +2160,7 @@ sumIf(1, event='$autocapture') as autocapture_count FROM posthog_test.sharded_events - WHERE `$session_id` IS NOT NULL AND `$session_id` != '' + WHERE `$session_id` IS NOT NULL AND `$session_id` != '' AND team_id IN (1, 2, 13610, 19279, 21173, 29929, 32050, 9910, 11775, 21129, 31490) GROUP BY `$session_id`, team_id diff --git a/posthog/clickhouse/test/test_sessions_model.py b/posthog/clickhouse/test/test_sessions_model.py index 0e3631e0ab3cd..0042456a03d95 100644 --- a/posthog/clickhouse/test/test_sessions_model.py +++ b/posthog/clickhouse/test/test_sessions_model.py @@ -1,8 +1,10 @@ from posthog.clickhouse.client import sync_execute, query_with_columns +from posthog.models import Team from posthog.test.base import ( _create_event, ClickhouseTestMixin, BaseTest, + ClickhouseDestroyTablesMixin, ) distinct_id_counter = 0 @@ -21,7 +23,12 @@ def create_session_id(): return f"s{session_id_counter}" -class TestSessionsModel(ClickhouseTestMixin, BaseTest): +# only certain team ids can insert events into this legacy sessions table, see sessions/sql.py for more info +TEAM_ID = 2 +TEAM = Team(id=TEAM_ID) + + +class TestSessionsModel(ClickhouseDestroyTablesMixin, ClickhouseTestMixin, BaseTest): def select_by_session_id(self, session_id): return query_with_columns( """ @@ -34,7 +41,7 @@ def select_by_session_id(self, session_id): """, { "session_id": session_id, - "team_id": self.team.id, + "team_id": TEAM_ID, }, ) @@ -42,7 +49,7 @@ def test_it_creates_session_when_creating_event(self): distinct_id = create_distinct_id() session_id = create_session_id() _create_event( - team=self.team, + team=TEAM, event="$pageview", distinct_id=distinct_id, properties={"$current_url": "/", "$session_id": session_id}, @@ -60,7 +67,7 @@ def test_it_creates_session_when_creating_event(self): """, { "distinct_id": distinct_id, - "team_id": self.team.id, + "team_id": TEAM_ID, }, ) @@ -72,14 +79,14 @@ def test_handles_different_distinct_id_across_same_session(self): session_id = create_session_id() _create_event( - team=self.team, + team=TEAM, event="$pageview", distinct_id=distinct_id1, properties={"$session_id": session_id}, timestamp="2024-03-08", ) _create_event( - team=self.team, + team=TEAM, event="$pageview", distinct_id=distinct_id2, properties={"$session_id": session_id}, @@ -96,28 +103,28 @@ def test_handles_entry_and_exit_urls(self): session_id = create_session_id() _create_event( - team=self.team, + team=TEAM, event="$pageview", distinct_id=distinct_id, properties={"$current_url": "/entry", "$session_id": session_id}, timestamp="2024-03-08:01", ) _create_event( - team=self.team, + team=TEAM, event="$pageview", distinct_id=distinct_id, properties={"$current_url": "/middle", "$session_id": session_id}, timestamp="2024-03-08:02", ) _create_event( - team=self.team, + team=TEAM, event="$pageview", distinct_id=distinct_id, properties={"$current_url": "/middle", "$session_id": session_id}, timestamp="2024-03-08:03", ) _create_event( - team=self.team, + team=TEAM, event="$pageview", distinct_id=distinct_id, properties={"$current_url": "/exit", "$session_id": session_id}, @@ -136,14 +143,14 @@ def test_handles_initial_utm_properties(self): session_id = create_session_id() _create_event( - team=self.team, + team=TEAM, event="$pageview", distinct_id=distinct_id, properties={"$session_id": session_id, "utm_source": "source"}, timestamp="2024-03-08", ) _create_event( - team=self.team, + team=TEAM, event="$pageview", distinct_id=distinct_id, properties={"$session_id": session_id, "utm_source": "other_source"}, @@ -159,35 +166,35 @@ def test_counts_pageviews_autocaptures_and_events(self): session_id = create_session_id() _create_event( - team=self.team, + team=TEAM, event="$pageview", distinct_id=distinct_id, properties={"$session_id": session_id}, timestamp="2024-03-08", ) _create_event( - team=self.team, + team=TEAM, event="$autocapture", distinct_id=distinct_id, properties={"$session_id": session_id}, timestamp="2024-03-08", ) _create_event( - team=self.team, + team=TEAM, event="$autocapture", distinct_id=distinct_id, properties={"$session_id": session_id}, timestamp="2024-03-08", ) _create_event( - team=self.team, + team=TEAM, event="other event", distinct_id=distinct_id, properties={"$session_id": session_id}, timestamp="2024-03-08", ) _create_event( - team=self.team, + team=TEAM, event="$pageleave", distinct_id=distinct_id, properties={"$session_id": session_id}, @@ -209,14 +216,14 @@ def test_separates_sessions_across_same_user(self): session_id3 = create_session_id() _create_event( - team=self.team, + team=TEAM, event="$pageview", distinct_id=distinct_id, properties={"$session_id": session_id1}, timestamp="2024-03-08", ) _create_event( - team=self.team, + team=TEAM, event="$pageview", distinct_id=distinct_id, properties={"$session_id": session_id2}, @@ -235,7 +242,7 @@ def test_select_from_sessions(self): distinct_id = create_distinct_id() session_id = create_session_id() _create_event( - team=self.team, + team=TEAM, event="$pageview", distinct_id=distinct_id, properties={"$session_id": session_id}, @@ -260,7 +267,7 @@ def test_select_from_sessions(self): """, { "session_id": session_id, - "team_id": self.team.id, + "team_id": TEAM_ID, }, ) self.assertEqual(len(responses), 1) @@ -270,7 +277,7 @@ def test_select_from_sessions_mv(self): distinct_id = create_distinct_id() session_id = create_session_id() _create_event( - team=self.team, + team=TEAM, event="$pageview", distinct_id=distinct_id, properties={"$session_id": session_id}, @@ -295,7 +302,7 @@ def test_select_from_sessions_mv(self): """, { "session_id": session_id, - "team_id": self.team.id, + "team_id": TEAM_ID, }, ) self.assertEqual(len(responses), 1) diff --git a/posthog/hogql/database/schema/test/test_sessions_v1.py b/posthog/hogql/database/schema/test/test_sessions_v1.py index eefd04197deab..77f41fd2f6bbc 100644 --- a/posthog/hogql/database/schema/test/test_sessions_v1.py +++ b/posthog/hogql/database/schema/test/test_sessions_v1.py @@ -8,6 +8,7 @@ ) from posthog.hogql.parser import parse_select from posthog.hogql.query import execute_hogql_query +from posthog.models import Team from posthog.models.property_definition import PropertyType from posthog.models.utils import uuid7 from posthog.schema import HogQLQueryModifiers, BounceRatePageViewMode, SessionTableVersion @@ -15,16 +16,20 @@ APIBaseTest, ClickhouseTestMixin, _create_event, - _create_person, + ClickhouseDestroyTablesMixin, ) +# only certain team ids can insert events into this legacy sessions table, see sessions/sql.py for more info +TEAM_ID = 2 +TEAM = Team(id=TEAM_ID, pk=TEAM_ID) -class TestSessionsV1(ClickhouseTestMixin, APIBaseTest): + +class TestSessionsV1(ClickhouseDestroyTablesMixin, ClickhouseTestMixin, APIBaseTest): def __execute(self, query): modifiers = HogQLQueryModifiers(sessionTableVersion=SessionTableVersion.V1) return execute_hogql_query( query=query, - team=self.team, + team=TEAM, modifiers=modifiers, ) @@ -33,7 +38,7 @@ def test_select_star(self): _create_event( event="$pageview", - team=self.team, + team=TEAM, distinct_id="d1", properties={"$current_url": "https://example.com", "$session_id": session_id}, ) @@ -56,7 +61,7 @@ def test_select_event_sessions_star(self): _create_event( event="$pageview", - team=self.team, + team=TEAM, distinct_id="d1", properties={"$current_url": "https://example.com", "$session_id": session_id}, ) @@ -93,7 +98,7 @@ def test_channel_type(self): _create_event( event="$pageview", - team=self.team, + team=TEAM, distinct_id="d1", properties={"gad_source": "1", "$session_id": session_id}, ) @@ -116,7 +121,7 @@ def test_event_dot_session_dot_channel_type(self): _create_event( event="$pageview", - team=self.team, + team=TEAM, distinct_id="d1", properties={"gad_source": "1", "$session_id": session_id}, ) @@ -139,7 +144,7 @@ def test_events_session_dot_channel_type(self): _create_event( event="$pageview", - team=self.team, + team=TEAM, distinct_id="d1", properties={"gad_source": "1", "$session_id": session_id}, ) @@ -157,57 +162,26 @@ def test_events_session_dot_channel_type(self): "Paid Search", ) - def test_persons_and_sessions_on_events(self): - p1 = _create_person(distinct_ids=["d1"], team=self.team) - p2 = _create_person(distinct_ids=["d2"], team=self.team) - - s1 = "session_test_persons_and_sessions_on_events_1" - s2 = "session_test_persons_and_sessions_on_events_2" - - _create_event( - event="$pageview", - team=self.team, - distinct_id="d1", - properties={"$session_id": s1, "utm_source": "source1"}, - ) - _create_event( - event="$pageview", - team=self.team, - distinct_id="d2", - properties={"$session_id": s2, "utm_source": "source2"}, - ) - - response = self.__execute( - parse_select( - "select events.person_id, session.$entry_utm_source from events where $session_id = {session_id} or $session_id = {session_id2} order by 2 asc", - placeholders={"session_id": ast.Constant(value=s1), "session_id2": ast.Constant(value=s2)}, - ), - ) - - [row1, row2] = response.results or [] - self.assertEqual(row1, (p1.uuid, "source1")) - self.assertEqual(row2, (p2.uuid, "source2")) - @parameterized.expand([(BounceRatePageViewMode.UNIQ_URLS,), (BounceRatePageViewMode.COUNT_PAGEVIEWS,)]) def test_bounce_rate(self, bounceRatePageViewMode): # person with 2 different sessions _create_event( event="$pageview", - team=self.team, + team=TEAM, distinct_id="d1", properties={"$session_id": "s1a", "$current_url": "https://example.com/1"}, timestamp="2023-12-02", ) _create_event( event="$pageview", - team=self.team, + team=TEAM, distinct_id="d1", properties={"$session_id": "s1a", "$current_url": "https://example.com/2"}, timestamp="2023-12-03", ) _create_event( event="$pageview", - team=self.team, + team=TEAM, distinct_id="d1", properties={"$session_id": "s1b", "$current_url": "https://example.com/3"}, timestamp="2023-12-12", @@ -215,7 +189,7 @@ def test_bounce_rate(self, bounceRatePageViewMode): # session with 1 pageview _create_event( event="$pageview", - team=self.team, + team=TEAM, distinct_id="d2", properties={"$session_id": "s2", "$current_url": "https://example.com/4"}, timestamp="2023-12-11", @@ -223,14 +197,14 @@ def test_bounce_rate(self, bounceRatePageViewMode): # session with 1 pageview and 1 autocapture _create_event( event="$pageview", - team=self.team, + team=TEAM, distinct_id="d3", properties={"$session_id": "s3", "$current_url": "https://example.com/5"}, timestamp="2023-12-11", ) _create_event( event="$autocapture", - team=self.team, + team=TEAM, distinct_id="d3", properties={"$session_id": "s3", "$current_url": "https://example.com/5"}, timestamp="2023-12-11", @@ -238,14 +212,14 @@ def test_bounce_rate(self, bounceRatePageViewMode): # short session with a pageleave _create_event( event="$pageview", - team=self.team, + team=TEAM, distinct_id="d4", properties={"$session_id": "s4", "$current_url": "https://example.com/6"}, timestamp="2023-12-11T12:00:00", ) _create_event( event="$pageleave", - team=self.team, + team=TEAM, distinct_id="d4", properties={"$session_id": "s4", "$current_url": "https://example.com/6"}, timestamp="2023-12-11T12:00:01", @@ -253,14 +227,14 @@ def test_bounce_rate(self, bounceRatePageViewMode): # long session with a pageleave _create_event( event="$pageview", - team=self.team, + team=TEAM, distinct_id="d5", properties={"$session_id": "s5", "$current_url": "https://example.com/7"}, timestamp="2023-12-11T12:00:00", ) _create_event( event="$pageleave", - team=self.team, + team=TEAM, distinct_id="d5", properties={"$session_id": "s5", "$current_url": "https://example.com/7"}, timestamp="2023-12-11T12:00:11", @@ -269,7 +243,7 @@ def test_bounce_rate(self, bounceRatePageViewMode): parse_select( "select $is_bounce, session_id from sessions ORDER BY session_id", ), - self.team, + TEAM, modifiers=HogQLQueryModifiers( bounceRatePageViewMode=bounceRatePageViewMode, sessionTableVersion=SessionTableVersion.V1 ), @@ -291,7 +265,7 @@ def test_can_use_v1_and_v2_fields(self): _create_event( event="$pageview", - team=self.team, + team=TEAM, distinct_id="d1", properties={ "$current_url": "https://example.com/pathname", @@ -372,4 +346,4 @@ def test_entry_utm(self): def test_can_get_values_for_all(self): results = get_lazy_session_table_properties_v1(None) for prop in results: - get_lazy_session_table_values_v1(key=prop["id"], team=self.team, search_term=None) + get_lazy_session_table_values_v1(key=prop["id"], team=TEAM, search_term=None) diff --git a/posthog/hogql_queries/web_analytics/test/test_session_attribution_explorer_query_runner.py b/posthog/hogql_queries/web_analytics/test/test_session_attribution_explorer_query_runner.py index d285ff2aa25f3..06ba1ddfeabbe 100644 --- a/posthog/hogql_queries/web_analytics/test/test_session_attribution_explorer_query_runner.py +++ b/posthog/hogql_queries/web_analytics/test/test_session_attribution_explorer_query_runner.py @@ -1,6 +1,5 @@ from typing import Optional -from parameterized import parameterized from posthog.hogql.constants import LimitContext from posthog.hogql_queries.web_analytics.session_attribution_explorer_query_runner import ( @@ -80,7 +79,7 @@ def _run_session_attribution_query( self, date_from: Optional[str] = None, date_to: Optional[str] = None, - session_table_version: SessionTableVersion = SessionTableVersion.V1, + session_table_version: SessionTableVersion = SessionTableVersion.V2, group_by: Optional[list[SessionAttributionGroupBy]] = None, limit_context: Optional[LimitContext] = None, properties: Optional[list[SessionPropertyFilter]] = None, @@ -94,20 +93,14 @@ def _run_session_attribution_query( runner = SessionAttributionExplorerQueryRunner(team=self.team, query=query, limit_context=limit_context) return runner.calculate() - @parameterized.expand([[SessionTableVersion.V1], [SessionTableVersion.V2]]) - def test_no_crash_when_no_data(self, session_table_version: SessionTableVersion): - results = self._run_session_attribution_query( - session_table_version=session_table_version, - ).results + def test_no_crash_when_no_data(self): + results = self._run_session_attribution_query().results assert results == [(0, [], [], [], [], [], [], [])] - @parameterized.expand([[SessionTableVersion.V1], [SessionTableVersion.V2]]) - def test_group_by_nothing(self, session_table_version: SessionTableVersion): + def test_group_by_nothing(self): self._create_data() - results = self._run_session_attribution_query( - session_table_version=session_table_version, - ).results + results = self._run_session_attribution_query().results assert results == [ ( @@ -122,12 +115,10 @@ def test_group_by_nothing(self, session_table_version: SessionTableVersion): ) ] - @parameterized.expand([[SessionTableVersion.V1], [SessionTableVersion.V2]]) - def test_group_by_initial_url(self, session_table_version: SessionTableVersion): + def test_group_by_initial_url(self): self._create_data() results = self._run_session_attribution_query( - session_table_version=session_table_version, group_by=[SessionAttributionGroupBy.INITIAL_URL], ).results @@ -164,12 +155,10 @@ def test_group_by_initial_url(self, session_table_version: SessionTableVersion): ), ] - @parameterized.expand([[SessionTableVersion.V1], [SessionTableVersion.V2]]) - def test_group_channel_medium_source(self, session_table_version: SessionTableVersion): + def test_group_channel_medium_source(self): self._create_data() results = self._run_session_attribution_query( - session_table_version=session_table_version, group_by=[ SessionAttributionGroupBy.CHANNEL_TYPE, SessionAttributionGroupBy.MEDIUM, @@ -191,12 +180,10 @@ def test_group_channel_medium_source(self, session_table_version: SessionTableVe (1, "Referral", ["referring_domain2"], "source2", "medium2", ["campaign2"], [], ["http://example.com/2"]), ] - @parameterized.expand([[SessionTableVersion.V1], [SessionTableVersion.V2]]) - def test_filters(self, session_table_version: SessionTableVersion): + def test_filters(self): self._create_data() results = self._run_session_attribution_query( - session_table_version=session_table_version, group_by=[ SessionAttributionGroupBy.CHANNEL_TYPE, SessionAttributionGroupBy.MEDIUM, diff --git a/posthog/hogql_queries/web_analytics/test/test_web_overview.py b/posthog/hogql_queries/web_analytics/test/test_web_overview.py index bc41d4d0a6785..3e9b570f57b9e 100644 --- a/posthog/hogql_queries/web_analytics/test/test_web_overview.py +++ b/posthog/hogql_queries/web_analytics/test/test_web_overview.py @@ -2,7 +2,6 @@ from unittest.mock import MagicMock, patch from freezegun import freeze_time -from parameterized import parameterized from posthog.clickhouse.client.execute import sync_execute from posthog.hogql.constants import LimitContext @@ -72,7 +71,7 @@ def _run_web_overview_query( self, date_from: str, date_to: str, - session_table_version: SessionTableVersion = SessionTableVersion.V1, + session_table_version: SessionTableVersion = SessionTableVersion.V2, compare: bool = True, limit_context: Optional[LimitContext] = None, filter_test_accounts: Optional[bool] = False, @@ -97,19 +96,16 @@ def _run_web_overview_query( runner = WebOverviewQueryRunner(team=self.team, query=query, limit_context=limit_context) return runner.calculate() - @parameterized.expand([[SessionTableVersion.V1], [SessionTableVersion.V2]]) - def test_no_crash_when_no_data(self, session_table_version: SessionTableVersion): + def test_no_crash_when_no_data(self): results = self._run_web_overview_query( "2023-12-08", "2023-12-15", - session_table_version=session_table_version, ).results assert [item.key for item in results] == ["visitors", "views", "sessions", "session duration", "bounce rate"] results = self._run_web_overview_query( "2023-12-08", "2023-12-15", - session_table_version=session_table_version, includeLCPScore=True, ).results assert [item.key for item in results] == [ @@ -132,9 +128,7 @@ def test_no_crash_when_no_data(self, session_table_version: SessionTableVersion) } ], ) - results = self._run_web_overview_query( - "2023-12-08", "2023-12-15", session_table_version=session_table_version, action=action - ).results + results = self._run_web_overview_query("2023-12-08", "2023-12-15", action=action).results assert [item.key for item in results] == [ "visitors", @@ -143,8 +137,7 @@ def test_no_crash_when_no_data(self, session_table_version: SessionTableVersion) "conversion rate", ] - @parameterized.expand([[SessionTableVersion.V1], [SessionTableVersion.V2]]) - def test_increase_in_users(self, session_table_version: SessionTableVersion): + def test_increase_in_users(self): s1a = str(uuid7("2023-12-02")) s1b = str(uuid7("2023-12-12")) s2 = str(uuid7("2023-12-11")) @@ -159,7 +152,6 @@ def test_increase_in_users(self, session_table_version: SessionTableVersion): results = self._run_web_overview_query( "2023-12-08", "2023-12-15", - session_table_version=session_table_version, ).results visitors = results[0] @@ -192,8 +184,7 @@ def test_increase_in_users(self, session_table_version: SessionTableVersion): self.assertEqual(0, bounce.previous) self.assertEqual(None, bounce.changeFromPreviousPct) - @parameterized.expand([[SessionTableVersion.V1], [SessionTableVersion.V2]]) - def test_all_time(self, session_table_version: SessionTableVersion): + def test_all_time(self): s1a = str(uuid7("2023-12-02")) s1b = str(uuid7("2023-12-12")) s2 = str(uuid7("2023-12-11")) @@ -208,7 +199,6 @@ def test_all_time(self, session_table_version: SessionTableVersion): "all", "2023-12-15", compare=False, - session_table_version=session_table_version, ).results visitors = results[0] @@ -241,15 +231,12 @@ def test_all_time(self, session_table_version: SessionTableVersion): self.assertEqual(None, bounce.previous) self.assertEqual(None, bounce.changeFromPreviousPct) - @parameterized.expand([[SessionTableVersion.V1], [SessionTableVersion.V2]]) - def test_filter_test_accounts(self, session_table_version: SessionTableVersion): + def test_filter_test_accounts(self): s1 = str(uuid7("2023-12-02")) # Create 1 test account self._create_events([("test", [("2023-12-02", s1), ("2023-12-03", s1)])]) - results = self._run_web_overview_query( - "2023-12-01", "2023-12-03", session_table_version=session_table_version, filter_test_accounts=True - ).results + results = self._run_web_overview_query("2023-12-01", "2023-12-03", filter_test_accounts=True).results visitors = results[0] self.assertEqual(0, visitors.value) @@ -267,21 +254,17 @@ def test_filter_test_accounts(self, session_table_version: SessionTableVersion): self.assertEqual("bounce rate", bounce.key) self.assertEqual(None, bounce.value) - @parameterized.expand([[SessionTableVersion.V1], [SessionTableVersion.V2]]) - def test_dont_filter_test_accounts(self, session_table_version: SessionTableVersion): + def test_dont_filter_test_accounts(self): s1 = str(uuid7("2023-12-02")) # Create 1 test account self._create_events([("test", [("2023-12-02", s1), ("2023-12-03", s1)])]) - results = self._run_web_overview_query( - "2023-12-01", "2023-12-03", session_table_version=session_table_version, filter_test_accounts=False - ).results + results = self._run_web_overview_query("2023-12-01", "2023-12-03", filter_test_accounts=False).results visitors = results[0] self.assertEqual(1, visitors.value) - @parameterized.expand([[SessionTableVersion.V1], [SessionTableVersion.V2]]) - def test_correctly_counts_pageviews_in_long_running_session(self, session_table_version: SessionTableVersion): + def test_correctly_counts_pageviews_in_long_running_session(self): # this test is important when using the v1 sessions table as the raw sessions table will have 3 entries, one per day s1 = str(uuid7("2023-12-01")) self._create_events( @@ -293,7 +276,6 @@ def test_correctly_counts_pageviews_in_long_running_session(self, session_table_ results = self._run_web_overview_query( "2023-12-01", "2023-12-03", - session_table_version=session_table_version, ).results visitors = results[0] diff --git a/posthog/hogql_queries/web_analytics/test/test_web_stats_table.py b/posthog/hogql_queries/web_analytics/test/test_web_stats_table.py index 10ce9ab1ebcb4..865424f5bc862 100644 --- a/posthog/hogql_queries/web_analytics/test/test_web_stats_table.py +++ b/posthog/hogql_queries/web_analytics/test/test_web_stats_table.py @@ -1,7 +1,6 @@ from typing import Optional from freezegun import freeze_time -from parameterized import parameterized from posthog.hogql_queries.web_analytics.stats_table import WebStatsTableQueryRunner from posthog.models import Cohort @@ -108,7 +107,7 @@ def _run_web_stats_table_query( include_bounce_rate=False, include_scroll_depth=False, properties=None, - session_table_version: SessionTableVersion = SessionTableVersion.V1, + session_table_version: SessionTableVersion = SessionTableVersion.V2, filter_test_accounts: Optional[bool] = False, ): modifiers = HogQLQueryModifiers(sessionTableVersion=session_table_version) @@ -126,15 +125,14 @@ def _run_web_stats_table_query( runner = WebStatsTableQueryRunner(team=self.team, query=query, modifiers=modifiers) return runner.calculate() - @parameterized.expand([[SessionTableVersion.V1], [SessionTableVersion.V2]]) - def test_no_crash_when_no_data(self, session_table_version: SessionTableVersion): + def test_no_crash_when_no_data(self): results = self._run_web_stats_table_query( - "2023-12-08", "2023-12-15", session_table_version=session_table_version + "2023-12-08", + "2023-12-15", ).results self.assertEqual([], results) - @parameterized.expand([[SessionTableVersion.V1], [SessionTableVersion.V2]]) - def test_increase_in_users(self, session_table_version: SessionTableVersion): + def test_increase_in_users(self): s1a = str(uuid7("2023-12-02")) s1b = str(uuid7("2023-12-13")) s2 = str(uuid7("2023-12-10")) @@ -145,9 +143,7 @@ def test_increase_in_users(self, session_table_version: SessionTableVersion): ] ) - results = self._run_web_stats_table_query( - "2023-12-01", "2023-12-11", session_table_version=session_table_version - ).results + results = self._run_web_stats_table_query("2023-12-01", "2023-12-11").results self.assertEqual( [ @@ -157,8 +153,7 @@ def test_increase_in_users(self, session_table_version: SessionTableVersion): results, ) - @parameterized.expand([[SessionTableVersion.V1], [SessionTableVersion.V2]]) - def test_all_time(self, session_table_version: SessionTableVersion): + def test_all_time(self): s1a = str(uuid7("2023-12-02")) s1b = str(uuid7("2023-12-13")) s2 = str(uuid7("2023-12-10")) @@ -169,9 +164,7 @@ def test_all_time(self, session_table_version: SessionTableVersion): ] ) - results = self._run_web_stats_table_query( - "all", "2023-12-15", session_table_version=session_table_version - ).results + results = self._run_web_stats_table_query("all", "2023-12-15").results self.assertEqual( [ @@ -182,38 +175,31 @@ def test_all_time(self, session_table_version: SessionTableVersion): results, ) - @parameterized.expand([[SessionTableVersion.V1], [SessionTableVersion.V2]]) - def test_filter_test_accounts(self, session_table_version: SessionTableVersion): + def test_filter_test_accounts(self): s1 = str(uuid7("2023-12-02")) # Create 1 test account self._create_events([("test", [("2023-12-02", s1, "/"), ("2023-12-03", s1, "/login")])]) - results = self._run_web_stats_table_query( - "2023-12-01", "2023-12-03", session_table_version=session_table_version, filter_test_accounts=True - ).results + results = self._run_web_stats_table_query("2023-12-01", "2023-12-03", filter_test_accounts=True).results self.assertEqual( [], results, ) - @parameterized.expand([[SessionTableVersion.V1], [SessionTableVersion.V2]]) - def test_dont_filter_test_accounts(self, session_table_version: SessionTableVersion): + def test_dont_filter_test_accounts(self): s1 = str(uuid7("2023-12-02")) # Create 1 test account self._create_events([("test", [("2023-12-02", s1, "/"), ("2023-12-03", s1, "/login")])]) - results = self._run_web_stats_table_query( - "2023-12-01", "2023-12-03", session_table_version=session_table_version, filter_test_accounts=False - ).results + results = self._run_web_stats_table_query("2023-12-01", "2023-12-03", filter_test_accounts=False).results self.assertEqual( [["/", 1, 1], ["/login", 1, 1]], results, ) - @parameterized.expand([[SessionTableVersion.V1], [SessionTableVersion.V2]]) - def test_breakdown_channel_type_doesnt_throw(self, session_table_version: SessionTableVersion): + def test_breakdown_channel_type_doesnt_throw(self): s1a = str(uuid7("2023-12-02")) s1b = str(uuid7("2023-12-13")) s2 = str(uuid7("2023-12-10")) @@ -229,7 +215,6 @@ def test_breakdown_channel_type_doesnt_throw(self, session_table_version: Sessio "2023-12-01", "2023-12-03", breakdown_by=WebStatsBreakdown.INITIAL_CHANNEL_TYPE, - session_table_version=session_table_version, ).results self.assertEqual( @@ -237,8 +222,7 @@ def test_breakdown_channel_type_doesnt_throw(self, session_table_version: Sessio len(results), ) - @parameterized.expand([[SessionTableVersion.V1], [SessionTableVersion.V2]]) - def test_limit(self, session_table_version: SessionTableVersion): + def test_limit(self): s1 = str(uuid7("2023-12-02")) s2 = str(uuid7("2023-12-10")) self._create_events( @@ -248,9 +232,7 @@ def test_limit(self, session_table_version: SessionTableVersion): ] ) - response_1 = self._run_web_stats_table_query( - "all", "2023-12-15", limit=1, session_table_version=session_table_version - ) + response_1 = self._run_web_stats_table_query("all", "2023-12-15", limit=1) self.assertEqual( [ ["/", 2, 2], @@ -269,8 +251,7 @@ def test_limit(self, session_table_version: SessionTableVersion): ) self.assertEqual(False, response_2.hasMore) - @parameterized.expand([[SessionTableVersion.V1], [SessionTableVersion.V2]]) - def test_path_filters(self, session_table_version: SessionTableVersion): + def test_path_filters(self): s1 = str(uuid7("2023-12-02")) s2 = str(uuid7("2023-12-10")) s3 = str(uuid7("2023-12-10")) @@ -295,7 +276,6 @@ def test_path_filters(self, session_table_version: SessionTableVersion): {"regex": "thing_a", "alias": "thing_b"}, {"regex": "thing_b", "alias": "thing_c"}, ], - session_table_version=session_table_version, ).results self.assertEqual( @@ -308,8 +288,7 @@ def test_path_filters(self, session_table_version: SessionTableVersion): results, ) - @parameterized.expand([[SessionTableVersion.V1], [SessionTableVersion.V2]]) - def test_scroll_depth_bounce_rate_one_user(self, session_table_version: SessionTableVersion): + def test_scroll_depth_bounce_rate_one_user(self): self._create_pageviews( "p1", [ @@ -325,7 +304,6 @@ def test_scroll_depth_bounce_rate_one_user(self, session_table_version: SessionT breakdown_by=WebStatsBreakdown.PAGE, include_scroll_depth=True, include_bounce_rate=True, - session_table_version=session_table_version, ).results self.assertEqual( @@ -337,8 +315,7 @@ def test_scroll_depth_bounce_rate_one_user(self, session_table_version: SessionT results, ) - @parameterized.expand([[SessionTableVersion.V1], [SessionTableVersion.V2]]) - def test_scroll_depth_bounce_rate(self, session_table_version: SessionTableVersion): + def test_scroll_depth_bounce_rate(self): self._create_pageviews( "p1", [ @@ -369,7 +346,6 @@ def test_scroll_depth_bounce_rate(self, session_table_version: SessionTableVersi breakdown_by=WebStatsBreakdown.PAGE, include_scroll_depth=True, include_bounce_rate=True, - session_table_version=session_table_version, ).results self.assertEqual( @@ -381,8 +357,7 @@ def test_scroll_depth_bounce_rate(self, session_table_version: SessionTableVersi results, ) - @parameterized.expand([[SessionTableVersion.V1], [SessionTableVersion.V2]]) - def test_scroll_depth_bounce_rate_with_filter(self, session_table_version: SessionTableVersion): + def test_scroll_depth_bounce_rate_with_filter(self): self._create_pageviews( "p1", [ @@ -414,7 +389,6 @@ def test_scroll_depth_bounce_rate_with_filter(self, session_table_version: Sessi include_scroll_depth=True, include_bounce_rate=True, properties=[EventPropertyFilter(key="$pathname", operator=PropertyOperator.EXACT, value="/a")], - session_table_version=session_table_version, ).results self.assertEqual( @@ -424,8 +398,7 @@ def test_scroll_depth_bounce_rate_with_filter(self, session_table_version: Sessi results, ) - @parameterized.expand([[SessionTableVersion.V1], [SessionTableVersion.V2]]) - def test_scroll_depth_bounce_rate_path_cleaning(self, session_table_version: SessionTableVersion): + def test_scroll_depth_bounce_rate_path_cleaning(self): self._create_pageviews( "p1", [ @@ -446,7 +419,6 @@ def test_scroll_depth_bounce_rate_path_cleaning(self, session_table_version: Ses {"regex": "\\/b\\/\\d+", "alias": "/b/:id"}, {"regex": "\\/c\\/\\d+", "alias": "/c/:id"}, ], - session_table_version=session_table_version, ).results self.assertEqual( @@ -458,8 +430,7 @@ def test_scroll_depth_bounce_rate_path_cleaning(self, session_table_version: Ses results, ) - @parameterized.expand([[SessionTableVersion.V1], [SessionTableVersion.V2]]) - def test_bounce_rate_one_user(self, session_table_version: SessionTableVersion): + def test_bounce_rate_one_user(self): self._create_pageviews( "p1", [ @@ -474,7 +445,6 @@ def test_bounce_rate_one_user(self, session_table_version: SessionTableVersion): "2023-12-15", breakdown_by=WebStatsBreakdown.PAGE, include_bounce_rate=True, - session_table_version=session_table_version, ).results self.assertEqual( @@ -486,8 +456,7 @@ def test_bounce_rate_one_user(self, session_table_version: SessionTableVersion): results, ) - @parameterized.expand([[SessionTableVersion.V1], [SessionTableVersion.V2]]) - def test_bounce_rate(self, session_table_version: SessionTableVersion): + def test_bounce_rate(self): self._create_pageviews( "p1", [ @@ -517,7 +486,6 @@ def test_bounce_rate(self, session_table_version: SessionTableVersion): "2023-12-15", breakdown_by=WebStatsBreakdown.PAGE, include_bounce_rate=True, - session_table_version=session_table_version, ).results self.assertEqual( @@ -529,8 +497,7 @@ def test_bounce_rate(self, session_table_version: SessionTableVersion): results, ) - @parameterized.expand([[SessionTableVersion.V1], [SessionTableVersion.V2]]) - def test_bounce_rate_with_property(self, session_table_version: SessionTableVersion): + def test_bounce_rate_with_property(self): self._create_pageviews( "p1", [ @@ -561,7 +528,6 @@ def test_bounce_rate_with_property(self, session_table_version: SessionTableVers breakdown_by=WebStatsBreakdown.PAGE, include_bounce_rate=True, properties=[EventPropertyFilter(key="$pathname", operator=PropertyOperator.EXACT, value="/a")], - session_table_version=session_table_version, ).results self.assertEqual( @@ -571,8 +537,7 @@ def test_bounce_rate_with_property(self, session_table_version: SessionTableVers results, ) - @parameterized.expand([[SessionTableVersion.V1], [SessionTableVersion.V2]]) - def test_bounce_rate_path_cleaning(self, session_table_version: SessionTableVersion): + def test_bounce_rate_path_cleaning(self): self._create_pageviews( "p1", [ @@ -592,7 +557,6 @@ def test_bounce_rate_path_cleaning(self, session_table_version: SessionTableVers {"regex": "\\/b\\/\\d+", "alias": "/b/:id"}, {"regex": "\\/c\\/\\d+", "alias": "/c/:id"}, ], - session_table_version=session_table_version, ).results self.assertEqual( @@ -604,8 +568,7 @@ def test_bounce_rate_path_cleaning(self, session_table_version: SessionTableVers results, ) - @parameterized.expand([[SessionTableVersion.V1], [SessionTableVersion.V2]]) - def test_entry_bounce_rate_one_user(self, session_table_version: SessionTableVersion): + def test_entry_bounce_rate_one_user(self): self._create_pageviews( "p1", [ @@ -620,7 +583,6 @@ def test_entry_bounce_rate_one_user(self, session_table_version: SessionTableVer "2023-12-15", breakdown_by=WebStatsBreakdown.INITIAL_PAGE, include_bounce_rate=True, - session_table_version=session_table_version, ).results self.assertEqual( @@ -630,8 +592,7 @@ def test_entry_bounce_rate_one_user(self, session_table_version: SessionTableVer results, ) - @parameterized.expand([[SessionTableVersion.V1], [SessionTableVersion.V2]]) - def test_entry_bounce_rate(self, session_table_version: SessionTableVersion): + def test_entry_bounce_rate(self): self._create_pageviews( "p1", [ @@ -661,7 +622,6 @@ def test_entry_bounce_rate(self, session_table_version: SessionTableVersion): "2023-12-15", breakdown_by=WebStatsBreakdown.INITIAL_PAGE, include_bounce_rate=True, - session_table_version=session_table_version, ).results self.assertEqual( @@ -671,8 +631,7 @@ def test_entry_bounce_rate(self, session_table_version: SessionTableVersion): results, ) - @parameterized.expand([[SessionTableVersion.V1], [SessionTableVersion.V2]]) - def test_entry_bounce_rate_with_property(self, session_table_version: SessionTableVersion): + def test_entry_bounce_rate_with_property(self): self._create_pageviews( "p1", [ @@ -703,7 +662,6 @@ def test_entry_bounce_rate_with_property(self, session_table_version: SessionTab breakdown_by=WebStatsBreakdown.INITIAL_PAGE, include_bounce_rate=True, properties=[EventPropertyFilter(key="$pathname", operator=PropertyOperator.EXACT, value="/a")], - session_table_version=session_table_version, ).results self.assertEqual( @@ -713,8 +671,7 @@ def test_entry_bounce_rate_with_property(self, session_table_version: SessionTab results, ) - @parameterized.expand([[SessionTableVersion.V1], [SessionTableVersion.V2]]) - def test_entry_bounce_rate_path_cleaning(self, session_table_version: SessionTableVersion): + def test_entry_bounce_rate_path_cleaning(self): self._create_pageviews( "p1", [ @@ -734,7 +691,6 @@ def test_entry_bounce_rate_path_cleaning(self, session_table_version: SessionTab {"regex": "\\/b\\/\\d+", "alias": "/b/:id"}, {"regex": "\\/c\\/\\d+", "alias": "/c/:id"}, ], - session_table_version=session_table_version, ).results self.assertEqual( @@ -744,8 +700,7 @@ def test_entry_bounce_rate_path_cleaning(self, session_table_version: SessionTab results, ) - @parameterized.expand([[SessionTableVersion.V1], [SessionTableVersion.V2]]) - def test_source_medium_campaign(self, session_table_version: SessionTableVersion): + def test_source_medium_campaign(self): d1 = "d1" s1 = str(uuid7("2024-06-26")) @@ -785,7 +740,6 @@ def test_source_medium_campaign(self, session_table_version: SessionTableVersion "all", "2024-06-27", breakdown_by=WebStatsBreakdown.INITIAL_UTM_SOURCE_MEDIUM_CAMPAIGN, - session_table_version=session_table_version, ).results self.assertEqual( @@ -793,8 +747,7 @@ def test_source_medium_campaign(self, session_table_version: SessionTableVersion results, ) - @parameterized.expand([[SessionTableVersion.V1], [SessionTableVersion.V2]]) - def test_null_in_utm_tags(self, session_table_version: SessionTableVersion): + def test_null_in_utm_tags(self): d1 = "d1" s1 = str(uuid7("2024-06-26")) @@ -836,7 +789,6 @@ def test_null_in_utm_tags(self, session_table_version: SessionTableVersion): "all", "2024-06-27", breakdown_by=WebStatsBreakdown.INITIAL_UTM_SOURCE, - session_table_version=session_table_version, ).results self.assertEqual( @@ -844,8 +796,7 @@ def test_null_in_utm_tags(self, session_table_version: SessionTableVersion): results, ) - @parameterized.expand([[SessionTableVersion.V1], [SessionTableVersion.V2]]) - def test_is_not_set_filter(self, session_table_version: SessionTableVersion): + def test_is_not_set_filter(self): d1 = "d1" s1 = str(uuid7("2024-06-26")) @@ -888,7 +839,6 @@ def test_is_not_set_filter(self, session_table_version: SessionTableVersion): "2024-06-27", breakdown_by=WebStatsBreakdown.INITIAL_UTM_SOURCE, properties=[EventPropertyFilter(key="utm_source", operator=PropertyOperator.IS_NOT_SET)], - session_table_version=session_table_version, ).results self.assertEqual( diff --git a/posthog/models/sessions/sql.py b/posthog/models/sessions/sql.py index 680e1f7ff6f7b..93d3083a37763 100644 --- a/posthog/models/sessions/sql.py +++ b/posthog/models/sessions/sql.py @@ -7,6 +7,7 @@ AggregatingMergeTree, ) +# V1 Sessions table TABLE_BASE_NAME = "sessions" SESSIONS_DATA_TABLE = lambda: f"sharded_{TABLE_BASE_NAME}" @@ -21,6 +22,32 @@ ) DROP_SESSION_VIEW_SQL = lambda: f"DROP VIEW IF EXISTS {TABLE_BASE_NAME}_v ON CLUSTER '{settings.CLICKHOUSE_CLUSTER}'" +# Only teams that were grandfathered into the V1 sessions table are allowed to use it. Everyone else should use V2, +# i.e. raw_sessions. These teams were those who were seen to have changed their session table version in these metabase +# queries: +# US: https://metabase.prod-us.posthog.dev/question#eyJkYXRhc2V0X3F1ZXJ5Ijp7InR5cGUiOiJuYXRpdmUiLCJuYXRpdmUiOnsicXVlcnkiOiJTRUxFQ1QgdGVhbV9pZCwgc1xuRlJPTSAoXG4gICAgU0VMRUNUIG1vZGlmaWVycy0-PidzZXNzaW9uVGFibGVWZXJzaW9uJyBBUyBzLCBpZCBhcyB0ZWFtX2lkXG4gICAgRlJPTSBwb3N0aG9nX3RlYW1cbikgc3ViXG5XSEVSRSBzICE9ICcnIiwidGVtcGxhdGUtdGFncyI6e319LCJkYXRhYmFzZSI6MzR9LCJkaXNwbGF5IjoidGFibGUiLCJwYXJhbWV0ZXJzIjpbXSwidmlzdWFsaXphdGlvbl9zZXR0aW5ncyI6e319 +# EU: https://metabase.prod-eu.posthog.dev/question#eyJkYXRhc2V0X3F1ZXJ5Ijp7InR5cGUiOiJuYXRpdmUiLCJuYXRpdmUiOnsicXVlcnkiOiJTRUxFQ1QgdGVhbV9pZCwgc1xuRlJPTSAoXG4gICAgU0VMRUNUIG1vZGlmaWVycy0-PidzZXNzaW9uVGFibGVWZXJzaW9uJyBBUyBzLCBpZCBhcyB0ZWFtX2lkXG4gICAgRlJPTSBwb3N0aG9nX3RlYW1cbikgc3ViXG5XSEVSRSBzICE9ICcnIiwidGVtcGxhdGUtdGFncyI6e319LCJkYXRhYmFzZSI6MzR9LCJkaXNwbGF5IjoidGFibGUiLCJwYXJhbWV0ZXJzIjpbXSwidmlzdWFsaXphdGlvbl9zZXR0aW5ncyI6e319 +# or had contacted support about an issue. +# This list exists because we want to reduce the number of writes happening to this table, and so we don't write to it +# for any team not in this list. Adding a team to this is possible if needed, but would require changing this MV in +# production and backfilling this table with the management command backfill_sessions_table. +ALLOWED_TEAM_IDS = [ + # posthog + 1, + 2, + # US query + 13610, # zendesk: https://posthoghelp.zendesk.com/agent/tickets/18001 + 19279, + 21173, + 29929, + 32050, + # EU query + 9910, + 11775, + 21129, + 31490, +] +ALLOWED_TEAM_IDS_SQL = ", ".join(str(team_id) for team_id in ALLOWED_TEAM_IDS) # if updating these column definitions # you'll need to update the explicit column definitions in the materialized view creation statement below @@ -144,7 +171,7 @@ def source_column(column_name: str) -> str: sumIf(1, event='$autocapture') as autocapture_count FROM {database}.sharded_events -WHERE `$session_id` IS NOT NULL AND `$session_id` != '' +WHERE `$session_id` IS NOT NULL AND `$session_id` != '' AND team_id IN ({allowed_team_ids}) GROUP BY `$session_id`, team_id """.format( database=settings.CLICKHOUSE_DATABASE, @@ -168,6 +195,7 @@ def source_column(column_name: str) -> str: mc_cid_property=source_column("mc_cid"), igshid_property=source_column("igshid"), ttclid_property=source_column("ttclid"), + allowed_team_ids=ALLOWED_TEAM_IDS_SQL, ) ) From a0843f475b20166ea1ccb0ec626683178962496c Mon Sep 17 00:00:00 2001 From: Paul D'Ambra Date: Wed, 30 Oct 2024 11:30:50 +0100 Subject: [PATCH 09/14] fix: flappity snapshots begone (#25893) Co-authored-by: github-actions <41898282+github-actions[bot]@users.noreply.github.com> --- .../api/test/__snapshots__/test_api_docs.ambr | 180 +++++++++--------- posthog/api/test/test_api_docs.py | 2 +- 2 files changed, 91 insertions(+), 91 deletions(-) diff --git a/posthog/api/test/__snapshots__/test_api_docs.ambr b/posthog/api/test/__snapshots__/test_api_docs.ambr index 9221776ff38d1..9b7667ec6484b 100644 --- a/posthog/api/test/__snapshots__/test_api_docs.ambr +++ b/posthog/api/test/__snapshots__/test_api_docs.ambr @@ -1,137 +1,137 @@ # serializer version: 1 # name: TestAPIDocsSchema.test_api_docs_generation_warnings_snapshot list([ - '/home/runner/work/posthog/posthog/posthog/api/plugin_log_entry.py: Warning [PluginLogEntryViewSet]: could not derive type of path parameter "plugin_config_id" because it is untyped and obtaining queryset from the viewset failed. Consider adding a type to the path (e.g. ) or annotating the parameter type with @extend_schema. Defaulting to "string".', + '', + '/home/runner/work/posthog/posthog/ee/api/dashboard_collaborator.py: Warning [DashboardCollaboratorViewSet]: could not derive type of path parameter "project_id" because model "ee.models.dashboard_privilege.DashboardPrivilege" contained no such field. Consider annotating parameter with @extend_schema. Defaulting to "string".', + '/home/runner/work/posthog/posthog/ee/api/explicit_team_member.py: Warning [ExplicitTeamMemberViewSet]: could not derive type of path parameter "project_id" because model "ee.models.explicit_team_membership.ExplicitTeamMembership" contained no such field. Consider annotating parameter with @extend_schema. Defaulting to "string".', + '/home/runner/work/posthog/posthog/ee/api/feature_flag_role_access.py: Warning [FeatureFlagRoleAccessViewSet]: could not derive type of path parameter "project_id" because model "ee.models.feature_flag_role_access.FeatureFlagRoleAccess" contained no such field. Consider annotating parameter with @extend_schema. Defaulting to "string".', + '/home/runner/work/posthog/posthog/ee/api/rbac/role.py: Warning [RoleMembershipViewSet]: could not derive type of path parameter "organization_id" because model "ee.models.rbac.role.RoleMembership" contained no such field. Consider annotating parameter with @extend_schema. Defaulting to "string".', + '/home/runner/work/posthog/posthog/ee/api/rbac/role.py: Warning [RoleViewSet > RoleSerializer]: unable to resolve type hint for function "get_associated_flags". Consider using a type hint or @extend_schema_field. Defaulting to string.', + '/home/runner/work/posthog/posthog/ee/api/rbac/role.py: Warning [RoleViewSet > RoleSerializer]: unable to resolve type hint for function "get_members". Consider using a type hint or @extend_schema_field. Defaulting to string.', + '/home/runner/work/posthog/posthog/ee/api/subscription.py: Warning [SubscriptionViewSet > SubscriptionSerializer]: unable to resolve type hint for function "summary". Consider using a type hint or @extend_schema_field. Defaulting to string.', + '/home/runner/work/posthog/posthog/ee/api/subscription.py: Warning [SubscriptionViewSet]: could not derive type of path parameter "project_id" because model "posthog.models.subscription.Subscription" contained no such field. Consider annotating parameter with @extend_schema. Defaulting to "string".', + '/home/runner/work/posthog/posthog/ee/clickhouse/views/experiment_holdouts.py: Warning [ExperimentHoldoutViewSet]: could not derive type of path parameter "project_id" because model "posthog.models.experiment.ExperimentHoldout" contained no such field. Consider annotating parameter with @extend_schema. Defaulting to "string".', + '/home/runner/work/posthog/posthog/ee/clickhouse/views/experiments.py: Warning [EnterpriseExperimentsViewSet]: could not derive type of path parameter "project_id" because model "posthog.models.experiment.Experiment" contained no such field. Consider annotating parameter with @extend_schema. Defaulting to "string".', + '/home/runner/work/posthog/posthog/ee/clickhouse/views/groups.py: Warning [GroupsTypesViewSet]: could not derive type of path parameter "project_id" because model "posthog.models.group_type_mapping.GroupTypeMapping" contained no such field. Consider annotating parameter with @extend_schema. Defaulting to "string".', + '/home/runner/work/posthog/posthog/ee/clickhouse/views/groups.py: Warning [GroupsViewSet]: could not derive type of path parameter "project_id" because model "posthog.models.group.group.Group" contained no such field. Consider annotating parameter with @extend_schema. Defaulting to "string".', + '/home/runner/work/posthog/posthog/ee/clickhouse/views/insights.py: Warning [EnterpriseInsightsViewSet]: could not derive type of path parameter "project_id" because model "posthog.models.insight.Insight" contained no such field. Consider annotating parameter with @extend_schema. Defaulting to "string".', + '/home/runner/work/posthog/posthog/ee/clickhouse/views/person.py: Warning [EnterprisePersonViewSet]: could not derive type of path parameter "project_id" because model "posthog.models.person.person.Person" contained no such field. Consider annotating parameter with @extend_schema. Defaulting to "string".', + '/home/runner/work/posthog/posthog/ee/session_recordings/session_recording_playlist.py: Warning [SessionRecordingPlaylistViewSet]: could not derive type of path parameter "project_id" because model "posthog.session_recordings.models.session_recording_playlist.SessionRecordingPlaylist" contained no such field. Consider annotating parameter with @extend_schema. Defaulting to "string".', + '/home/runner/work/posthog/posthog/ee/session_recordings/session_recording_playlist.py: Warning [SessionRecordingPlaylistViewSet]: could not derive type of path parameter "session_recording_id" because model "posthog.session_recordings.models.session_recording_playlist.SessionRecordingPlaylist" contained no such field. Consider annotating parameter with @extend_schema. Defaulting to "string".', + '/home/runner/work/posthog/posthog/posthog/api/action.py: Warning [ActionViewSet > ActionSerializer]: unable to resolve type hint for function "get_creation_context". Consider using a type hint or @extend_schema_field. Defaulting to string.', + '/home/runner/work/posthog/posthog/posthog/api/action.py: Warning [ActionViewSet]: could not derive type of path parameter "project_id" because model "posthog.models.action.action.Action" contained no such field. Consider annotating parameter with @extend_schema. Defaulting to "string".', + '/home/runner/work/posthog/posthog/posthog/api/activity_log.py: Warning [ActivityLogViewSet]: could not derive type of path parameter "project_id" because model "posthog.models.activity_logging.activity_log.ActivityLog" contained no such field. Consider annotating parameter with @extend_schema. Defaulting to "string".', + '/home/runner/work/posthog/posthog/posthog/api/annotation.py: Warning [AnnotationsViewSet]: could not derive type of path parameter "project_id" because model "posthog.models.annotation.Annotation" contained no such field. Consider annotating parameter with @extend_schema. Defaulting to "string".', "/home/runner/work/posthog/posthog/posthog/api/app_metrics.py: Error [AppMetricsViewSet]: exception raised while getting serializer. Hint: Is get_serializer_class() returning None or is get_queryset() not working without a request? Ignoring the view for now. (Exception: 'AppMetricsViewSet' should either include a `serializer_class` attribute, or override the `get_serializer_class()` method.)", - '/home/runner/work/posthog/posthog/posthog/api/app_metrics.py: Warning [AppMetricsViewSet]: could not derive type of path parameter "project_id" because model "posthog.models.plugin.PluginConfig" contained no such field. Consider annotating parameter with @extend_schema. Defaulting to "string".', '/home/runner/work/posthog/posthog/posthog/api/app_metrics.py: Error [HistoricalExportsAppMetricsViewSet]: unable to guess serializer. This is graceful fallback handling for APIViews. Consider using GenericAPIView as view base class, if view is under your control. Either way you may want to add a serializer_class (or method). Ignoring view for now.', - '/home/runner/work/posthog/posthog/posthog/api/app_metrics.py: Warning [HistoricalExportsAppMetricsViewSet]: could not derive type of path parameter "project_id" because it is untyped and obtaining queryset from the viewset failed. Consider adding a type to the path (e.g. ) or annotating the parameter type with @extend_schema. Defaulting to "string".', - '/home/runner/work/posthog/posthog/posthog/api/app_metrics.py: Warning [HistoricalExportsAppMetricsViewSet]: could not derive type of path parameter "plugin_config_id" because it is untyped and obtaining queryset from the viewset failed. Consider adding a type to the path (e.g. ) or annotating the parameter type with @extend_schema. Defaulting to "string".', + '/home/runner/work/posthog/posthog/posthog/api/app_metrics.py: Warning [AppMetricsViewSet]: could not derive type of path parameter "project_id" because model "posthog.models.plugin.PluginConfig" contained no such field. Consider annotating parameter with @extend_schema. Defaulting to "string".', '/home/runner/work/posthog/posthog/posthog/api/app_metrics.py: Warning [HistoricalExportsAppMetricsViewSet]: could not derive type of path parameter "id" because it is untyped and obtaining queryset from the viewset failed. Consider adding a type to the path (e.g. ) or annotating the parameter type with @extend_schema. Defaulting to "string".', - '/home/runner/work/posthog/posthog/posthog/batch_exports/http.py: Warning [BatchExportViewSet]: could not derive type of path parameter "project_id" because model "posthog.batch_exports.models.BatchExport" contained no such field. Consider annotating parameter with @extend_schema. Defaulting to "string".', - '/home/runner/work/posthog/posthog/posthog/batch_exports/http.py: Warning [BatchExportViewSet > BatchExportSerializer]: could not resolve serializer field "HogQLSelectQueryField(required=False)". Defaulting to "string"', - '/home/runner/work/posthog/posthog/posthog/batch_exports/http.py: Warning [BatchExportRunViewSet]: could not derive type of path parameter "project_id" because model "posthog.batch_exports.models.BatchExportRun" contained no such field. Consider annotating parameter with @extend_schema. Defaulting to "string".', + '/home/runner/work/posthog/posthog/posthog/api/app_metrics.py: Warning [HistoricalExportsAppMetricsViewSet]: could not derive type of path parameter "plugin_config_id" because it is untyped and obtaining queryset from the viewset failed. Consider adding a type to the path (e.g. ) or annotating the parameter type with @extend_schema. Defaulting to "string".', + '/home/runner/work/posthog/posthog/posthog/api/app_metrics.py: Warning [HistoricalExportsAppMetricsViewSet]: could not derive type of path parameter "project_id" because it is untyped and obtaining queryset from the viewset failed. Consider adding a type to the path (e.g. ) or annotating the parameter type with @extend_schema. Defaulting to "string".', + '/home/runner/work/posthog/posthog/posthog/api/cohort.py: Warning [CohortViewSet]: could not derive type of path parameter "project_id" because model "posthog.models.cohort.cohort.Cohort" contained no such field. Consider annotating parameter with @extend_schema. Defaulting to "string".', '/home/runner/work/posthog/posthog/posthog/api/dashboards/dashboard.py: Warning [DashboardsViewSet]: could not derive type of path parameter "project_id" because model "posthog.models.dashboard.Dashboard" contained no such field. Consider annotating parameter with @extend_schema. Defaulting to "string".', - '/home/runner/work/posthog/posthog/ee/api/dashboard_collaborator.py: Warning [DashboardCollaboratorViewSet]: could not derive type of path parameter "project_id" because model "ee.models.dashboard_privilege.DashboardPrivilege" contained no such field. Consider annotating parameter with @extend_schema. Defaulting to "string".', - '/home/runner/work/posthog/posthog/posthog/api/sharing.py: Warning [SharingConfigurationViewSet]: could not derive type of path parameter "project_id" because model "posthog.models.sharing_configuration.SharingConfiguration" contained no such field. Consider annotating parameter with @extend_schema. Defaulting to "string".', - '/home/runner/work/posthog/posthog/posthog/api/event.py: Warning [EventViewSet]: could not derive type of path parameter "project_id" because it is untyped and obtaining queryset from the viewset failed. Consider adding a type to the path (e.g. ) or annotating the parameter type with @extend_schema. Defaulting to "string".', - '/home/runner/work/posthog/posthog/posthog/models/event/util.py: Warning [EventViewSet > ClickhouseEventSerializer]: unable to resolve type hint for function "get_id". Consider using a type hint or @extend_schema_field. Defaulting to string.', - '/home/runner/work/posthog/posthog/posthog/models/event/util.py: Warning [EventViewSet > ClickhouseEventSerializer]: unable to resolve type hint for function "get_distinct_id". Consider using a type hint or @extend_schema_field. Defaulting to string.', - '/home/runner/work/posthog/posthog/posthog/models/event/util.py: Warning [EventViewSet > ClickhouseEventSerializer]: unable to resolve type hint for function "get_properties". Consider using a type hint or @extend_schema_field. Defaulting to string.', - '/home/runner/work/posthog/posthog/posthog/models/event/util.py: Warning [EventViewSet > ClickhouseEventSerializer]: unable to resolve type hint for function "get_event". Consider using a type hint or @extend_schema_field. Defaulting to string.', - '/home/runner/work/posthog/posthog/posthog/models/event/util.py: Warning [EventViewSet > ClickhouseEventSerializer]: unable to resolve type hint for function "get_timestamp". Consider using a type hint or @extend_schema_field. Defaulting to string.', - '/home/runner/work/posthog/posthog/posthog/models/event/util.py: Warning [EventViewSet > ClickhouseEventSerializer]: unable to resolve type hint for function "get_person". Consider using a type hint or @extend_schema_field. Defaulting to string.', - '/home/runner/work/posthog/posthog/posthog/models/event/util.py: Warning [EventViewSet > ClickhouseEventSerializer]: unable to resolve type hint for function "get_elements". Consider using a type hint or @extend_schema_field. Defaulting to string.', - '/home/runner/work/posthog/posthog/posthog/models/event/util.py: Warning [EventViewSet > ClickhouseEventSerializer]: unable to resolve type hint for function "get_elements_chain". Consider using a type hint or @extend_schema_field. Defaulting to string.', + '/home/runner/work/posthog/posthog/posthog/api/dashboards/dashboard_templates.py: Warning [DashboardTemplateViewSet]: could not derive type of path parameter "project_id" because model "posthog.models.dashboard_templates.DashboardTemplate" contained no such field. Consider annotating parameter with @extend_schema. Defaulting to "string".', + '/home/runner/work/posthog/posthog/posthog/api/early_access_feature.py: Warning [EarlyAccessFeatureViewSet]: could not derive type of path parameter "project_id" because model "posthog.models.early_access_feature.EarlyAccessFeature" contained no such field. Consider annotating parameter with @extend_schema. Defaulting to "string".', '/home/runner/work/posthog/posthog/posthog/api/event.py: Warning [EventViewSet]: could not derive type of path parameter "id" because it is untyped and obtaining queryset from the viewset failed. Consider adding a type to the path (e.g. ) or annotating the parameter type with @extend_schema. Defaulting to "string".', - '/home/runner/work/posthog/posthog/ee/api/explicit_team_member.py: Warning [ExplicitTeamMemberViewSet]: could not derive type of path parameter "project_id" because model "ee.models.explicit_team_membership.ExplicitTeamMembership" contained no such field. Consider annotating parameter with @extend_schema. Defaulting to "string".', - '/home/runner/work/posthog/posthog/posthog/api/exports.py: Warning [ExportedAssetViewSet]: could not derive type of path parameter "project_id" because model "posthog.models.exported_asset.ExportedAsset" contained no such field. Consider annotating parameter with @extend_schema. Defaulting to "string".', - '/home/runner/work/posthog/posthog/posthog/api/exports.py: Warning [ExportedAssetViewSet > ExportedAssetSerializer]: unable to resolve type hint for function "has_content". Consider using a type hint or @extend_schema_field. Defaulting to string.', + '/home/runner/work/posthog/posthog/posthog/api/event.py: Warning [EventViewSet]: could not derive type of path parameter "project_id" because it is untyped and obtaining queryset from the viewset failed. Consider adding a type to the path (e.g. ) or annotating the parameter type with @extend_schema. Defaulting to "string".', + "/home/runner/work/posthog/posthog/posthog/api/event_definition.py: Error [EventDefinitionViewSet]: exception raised while getting serializer. Hint: Is get_serializer_class() returning None or is get_queryset() not working without a request? Ignoring the view for now. (Exception: 'AnonymousUser' object has no attribute 'organization')", + '/home/runner/work/posthog/posthog/posthog/api/event_definition.py: Warning [EventDefinitionViewSet]: could not derive type of path parameter "project_id" because model "posthog.models.event_definition.EventDefinition" contained no such field. Consider annotating parameter with @extend_schema. Defaulting to "string".', '/home/runner/work/posthog/posthog/posthog/api/exports.py: Warning [ExportedAssetViewSet > ExportedAssetSerializer]: unable to resolve type hint for function "filename". Consider using a type hint or @extend_schema_field. Defaulting to string.', - '/home/runner/work/posthog/posthog/ee/clickhouse/views/groups.py: Warning [GroupsViewSet]: could not derive type of path parameter "project_id" because model "posthog.models.group.group.Group" contained no such field. Consider annotating parameter with @extend_schema. Defaulting to "string".', - '/home/runner/work/posthog/posthog/ee/clickhouse/views/insights.py: Warning [EnterpriseInsightsViewSet]: could not derive type of path parameter "project_id" because model "posthog.models.insight.Insight" contained no such field. Consider annotating parameter with @extend_schema. Defaulting to "string".', - '/home/runner/work/posthog/posthog/posthog/api/insight.py: Warning [EnterpriseInsightsViewSet > InsightSerializer]: unable to resolve type hint for function "get_last_refresh". Consider using a type hint or @extend_schema_field. Defaulting to string.', + '/home/runner/work/posthog/posthog/posthog/api/exports.py: Warning [ExportedAssetViewSet > ExportedAssetSerializer]: unable to resolve type hint for function "has_content". Consider using a type hint or @extend_schema_field. Defaulting to string.', + '/home/runner/work/posthog/posthog/posthog/api/exports.py: Warning [ExportedAssetViewSet]: could not derive type of path parameter "project_id" because model "posthog.models.exported_asset.ExportedAsset" contained no such field. Consider annotating parameter with @extend_schema. Defaulting to "string".', + '/home/runner/work/posthog/posthog/posthog/api/feature_flag.py: Warning [FeatureFlagViewSet]: could not derive type of path parameter "project_id" because model "posthog.models.feature_flag.feature_flag.FeatureFlag" contained no such field. Consider annotating parameter with @extend_schema. Defaulting to "string".', '/home/runner/work/posthog/posthog/posthog/api/insight.py: Warning [EnterpriseInsightsViewSet > InsightSerializer]: unable to resolve type hint for function "get_cache_target_age". Consider using a type hint or @extend_schema_field. Defaulting to string.', - '/home/runner/work/posthog/posthog/posthog/api/insight.py: Warning [EnterpriseInsightsViewSet > InsightSerializer]: unable to resolve type hint for function "get_next_allowed_client_refresh". Consider using a type hint or @extend_schema_field. Defaulting to string.', - '/home/runner/work/posthog/posthog/posthog/api/insight.py: Warning [EnterpriseInsightsViewSet > InsightSerializer]: unable to resolve type hint for function "get_result". Consider using a type hint or @extend_schema_field. Defaulting to string.', - '/home/runner/work/posthog/posthog/posthog/api/insight.py: Warning [EnterpriseInsightsViewSet > InsightSerializer]: unable to resolve type hint for function "get_hasMore". Consider using a type hint or @extend_schema_field. Defaulting to string.', '/home/runner/work/posthog/posthog/posthog/api/insight.py: Warning [EnterpriseInsightsViewSet > InsightSerializer]: unable to resolve type hint for function "get_columns". Consider using a type hint or @extend_schema_field. Defaulting to string.', - '/home/runner/work/posthog/posthog/posthog/api/insight.py: Warning [EnterpriseInsightsViewSet > InsightSerializer]: unable to resolve type hint for function "get_timezone". Consider using a type hint or @extend_schema_field. Defaulting to string.', + '/home/runner/work/posthog/posthog/posthog/api/insight.py: Warning [EnterpriseInsightsViewSet > InsightSerializer]: unable to resolve type hint for function "get_hasMore". Consider using a type hint or @extend_schema_field. Defaulting to string.', + '/home/runner/work/posthog/posthog/posthog/api/insight.py: Warning [EnterpriseInsightsViewSet > InsightSerializer]: unable to resolve type hint for function "get_hogql". Consider using a type hint or @extend_schema_field. Defaulting to string.', '/home/runner/work/posthog/posthog/posthog/api/insight.py: Warning [EnterpriseInsightsViewSet > InsightSerializer]: unable to resolve type hint for function "get_is_cached". Consider using a type hint or @extend_schema_field. Defaulting to string.', + '/home/runner/work/posthog/posthog/posthog/api/insight.py: Warning [EnterpriseInsightsViewSet > InsightSerializer]: unable to resolve type hint for function "get_last_refresh". Consider using a type hint or @extend_schema_field. Defaulting to string.', + '/home/runner/work/posthog/posthog/posthog/api/insight.py: Warning [EnterpriseInsightsViewSet > InsightSerializer]: unable to resolve type hint for function "get_next_allowed_client_refresh". Consider using a type hint or @extend_schema_field. Defaulting to string.', '/home/runner/work/posthog/posthog/posthog/api/insight.py: Warning [EnterpriseInsightsViewSet > InsightSerializer]: unable to resolve type hint for function "get_query_status". Consider using a type hint or @extend_schema_field. Defaulting to string.', - '/home/runner/work/posthog/posthog/posthog/api/insight.py: Warning [EnterpriseInsightsViewSet > InsightSerializer]: unable to resolve type hint for function "get_hogql". Consider using a type hint or @extend_schema_field. Defaulting to string.', + '/home/runner/work/posthog/posthog/posthog/api/insight.py: Warning [EnterpriseInsightsViewSet > InsightSerializer]: unable to resolve type hint for function "get_result". Consider using a type hint or @extend_schema_field. Defaulting to string.', + '/home/runner/work/posthog/posthog/posthog/api/insight.py: Warning [EnterpriseInsightsViewSet > InsightSerializer]: unable to resolve type hint for function "get_timezone". Consider using a type hint or @extend_schema_field. Defaulting to string.', '/home/runner/work/posthog/posthog/posthog/api/insight.py: Warning [EnterpriseInsightsViewSet > InsightSerializer]: unable to resolve type hint for function "get_types". Consider using a type hint or @extend_schema_field. Defaulting to string.', - '/home/runner/work/posthog/posthog/ee/clickhouse/views/person.py: Warning [EnterprisePersonViewSet]: could not derive type of path parameter "project_id" because model "posthog.models.person.person.Person" contained no such field. Consider annotating parameter with @extend_schema. Defaulting to "string".', - '/home/runner/work/posthog/posthog/posthog/api/plugin.py: Warning [PipelineDestinationsConfigsViewSet]: could not derive type of path parameter "project_id" because model "posthog.models.plugin.PluginConfig" contained no such field. Consider annotating parameter with @extend_schema. Defaulting to "string".', + '/home/runner/work/posthog/posthog/posthog/api/notebook.py: Warning [NotebookViewSet]: could not derive type of path parameter "project_id" because model "posthog.models.notebook.notebook.Notebook" contained no such field. Consider annotating parameter with @extend_schema. Defaulting to "string".', + '/home/runner/work/posthog/posthog/posthog/api/organization.py: Warning [OrganizationViewSet > OrganizationSerializer]: unable to resolve type hint for function "get_member_count". Consider using a type hint or @extend_schema_field. Defaulting to string.', + '/home/runner/work/posthog/posthog/posthog/api/organization.py: Warning [OrganizationViewSet > OrganizationSerializer]: unable to resolve type hint for function "get_metadata". Consider using a type hint or @extend_schema_field. Defaulting to string.', + '/home/runner/work/posthog/posthog/posthog/api/person.py: Warning [SessionRecordingViewSet > SessionRecordingSerializer > MinimalPersonSerializer]: unable to resolve type hint for function "get_distinct_ids". Consider using a type hint or @extend_schema_field. Defaulting to string.', '/home/runner/work/posthog/posthog/posthog/api/plugin.py: Warning [PipelineDestinationsConfigsViewSet > PluginConfigSerializer]: unable to resolve type hint for function "get_config". Consider using a type hint or @extend_schema_field. Defaulting to string.', + '/home/runner/work/posthog/posthog/posthog/api/plugin.py: Warning [PipelineDestinationsConfigsViewSet > PluginConfigSerializer]: unable to resolve type hint for function "get_delivery_rate_24h". Consider using a type hint or @extend_schema_field. Defaulting to string.', '/home/runner/work/posthog/posthog/posthog/api/plugin.py: Warning [PipelineDestinationsConfigsViewSet > PluginConfigSerializer]: unable to resolve type hint for function "get_error". Consider using a type hint or @extend_schema_field. Defaulting to string.', '/home/runner/work/posthog/posthog/posthog/api/plugin.py: Warning [PipelineDestinationsConfigsViewSet > PluginConfigSerializer]: unable to resolve type hint for function "get_plugin_info". Consider using a type hint or @extend_schema_field. Defaulting to string.', - '/home/runner/work/posthog/posthog/posthog/api/plugin.py: Warning [PipelineDestinationsConfigsViewSet > PluginConfigSerializer]: unable to resolve type hint for function "get_delivery_rate_24h". Consider using a type hint or @extend_schema_field. Defaulting to string.', + '/home/runner/work/posthog/posthog/posthog/api/plugin.py: Warning [PipelineDestinationsConfigsViewSet]: could not derive type of path parameter "project_id" because model "posthog.models.plugin.PluginConfig" contained no such field. Consider annotating parameter with @extend_schema. Defaulting to "string".', + '/home/runner/work/posthog/posthog/posthog/api/plugin.py: Warning [PipelineDestinationsViewSet > PluginSerializer]: unable to resolve type hint for function "get_hog_function_migration_available". Consider using a type hint or @extend_schema_field. Defaulting to string.', '/home/runner/work/posthog/posthog/posthog/api/plugin.py: Warning [PipelineFrontendAppsConfigsViewSet]: could not derive type of path parameter "project_id" because model "posthog.models.plugin.PluginConfig" contained no such field. Consider annotating parameter with @extend_schema. Defaulting to "string".', '/home/runner/work/posthog/posthog/posthog/api/plugin.py: Warning [PipelineImportAppsConfigsViewSet]: could not derive type of path parameter "project_id" because model "posthog.models.plugin.PluginConfig" contained no such field. Consider annotating parameter with @extend_schema. Defaulting to "string".', '/home/runner/work/posthog/posthog/posthog/api/plugin.py: Warning [PipelineTransformationsConfigsViewSet]: could not derive type of path parameter "project_id" because model "posthog.models.plugin.PluginConfig" contained no such field. Consider annotating parameter with @extend_schema. Defaulting to "string".', '/home/runner/work/posthog/posthog/posthog/api/plugin.py: Warning [PluginConfigViewSet]: could not derive type of path parameter "project_id" because model "posthog.models.plugin.PluginConfig" contained no such field. Consider annotating parameter with @extend_schema. Defaulting to "string".', - '/home/runner/work/posthog/posthog/posthog/api/query.py: Warning [QueryViewSet]: could not derive type of path parameter "project_id" because it is untyped and obtaining queryset from the viewset failed. Consider adding a type to the path (e.g. ) or annotating the parameter type with @extend_schema. Defaulting to "string".', - '/opt/hostedtoolcache/Python/3.11.9/x64/lib/python3.11/site-packages/pydantic/_internal/_model_construction.py: Warning [QueryViewSet > ModelMetaclass]: Encountered 2 components with identical names "Person" and different classes and . This will very likely result in an incorrect schema. Try renaming one.', - '/home/runner/work/posthog/posthog/posthog/api/query.py: Warning [QueryViewSet]: could not derive type of path parameter "id" because it is untyped and obtaining queryset from the viewset failed. Consider adding a type to the path (e.g. ) or annotating the parameter type with @extend_schema. Defaulting to "string".', - '/home/runner/work/posthog/posthog/posthog/api/query.py: Error [QueryViewSet]: unable to guess serializer. This is graceful fallback handling for APIViews. Consider using GenericAPIView as view base class, if view is under your control. Either way you may want to add a serializer_class (or method). Ignoring view for now.', - '/home/runner/work/posthog/posthog/posthog/session_recordings/session_recording_api.py: Warning [SessionRecordingViewSet]: could not derive type of path parameter "project_id" because model "posthog.session_recordings.models.session_recording.SessionRecording" contained no such field. Consider annotating parameter with @extend_schema. Defaulting to "string".', - '/home/runner/work/posthog/posthog/posthog/api/person.py: Warning [SessionRecordingViewSet > SessionRecordingSerializer > MinimalPersonSerializer]: unable to resolve type hint for function "get_distinct_ids". Consider using a type hint or @extend_schema_field. Defaulting to string.', - '/home/runner/work/posthog/posthog/posthog/session_recordings/session_recording_api.py: Warning [SessionRecordingViewSet > SessionRecordingSerializer]: unable to resolve type hint for function "storage". Consider using a type hint or @extend_schema_field. Defaulting to string.', - '/home/runner/work/posthog/posthog/posthog/api/session.py: Warning [SessionViewSet]: could not derive type of path parameter "project_id" because it is untyped and obtaining queryset from the viewset failed. Consider adding a type to the path (e.g. ) or annotating the parameter type with @extend_schema. Defaulting to "string".', - '/home/runner/work/posthog/posthog/ee/api/subscription.py: Warning [SubscriptionViewSet]: could not derive type of path parameter "project_id" because model "posthog.models.subscription.Subscription" contained no such field. Consider annotating parameter with @extend_schema. Defaulting to "string".', - '/home/runner/work/posthog/posthog/ee/api/subscription.py: Warning [SubscriptionViewSet > SubscriptionSerializer]: unable to resolve type hint for function "summary". Consider using a type hint or @extend_schema_field. Defaulting to string.', - '/home/runner/work/posthog/posthog/posthog/api/organization.py: Warning [OrganizationViewSet > OrganizationSerializer]: unable to resolve type hint for function "get_metadata". Consider using a type hint or @extend_schema_field. Defaulting to string.', - '/home/runner/work/posthog/posthog/posthog/api/organization.py: Warning [OrganizationViewSet > OrganizationSerializer]: unable to resolve type hint for function "get_member_count". Consider using a type hint or @extend_schema_field. Defaulting to string.', - '/home/runner/work/posthog/posthog/posthog/batch_exports/http.py: Warning [BatchExportOrganizationViewSet]: could not derive type of path parameter "organization_id" because model "posthog.batch_exports.models.BatchExport" contained no such field. Consider annotating parameter with @extend_schema. Defaulting to "string".', - '/home/runner/work/posthog/posthog/posthog/api/plugin.py: Warning [PipelineDestinationsViewSet > PluginSerializer]: unable to resolve type hint for function "get_hog_function_migration_available". Consider using a type hint or @extend_schema_field. Defaulting to string.', - '/home/runner/work/posthog/posthog/posthog/api/project.py: Warning [ProjectViewSet > ProjectBackwardCompatSerializer]: could not resolve field on model with path "person_on_events_querying_enabled". This is likely a custom field that does some unknown magic. Maybe consider annotating the field/property? Defaulting to "string". (Exception: Project has no field named \'person_on_events_querying_enabled\')', + '/home/runner/work/posthog/posthog/posthog/api/plugin_log_entry.py: Warning [PluginLogEntryViewSet]: could not derive type of path parameter "plugin_config_id" because it is untyped and obtaining queryset from the viewset failed. Consider adding a type to the path (e.g. ) or annotating the parameter type with @extend_schema. Defaulting to "string".', '/home/runner/work/posthog/posthog/posthog/api/project.py: Warning [ProjectViewSet > ProjectBackwardCompatSerializer]: could not resolve field on model with path "default_modifiers". This is likely a custom field that does some unknown magic. Maybe consider annotating the field/property? Defaulting to "string". (Exception: Project has no field named \'default_modifiers\')', + '/home/runner/work/posthog/posthog/posthog/api/project.py: Warning [ProjectViewSet > ProjectBackwardCompatSerializer]: could not resolve field on model with path "person_on_events_querying_enabled". This is likely a custom field that does some unknown magic. Maybe consider annotating the field/property? Defaulting to "string". (Exception: Project has no field named \'person_on_events_querying_enabled\')', '/home/runner/work/posthog/posthog/posthog/api/project.py: Warning [ProjectViewSet > ProjectBackwardCompatSerializer]: unable to resolve type hint for function "get_product_intents". Consider using a type hint or @extend_schema_field. Defaulting to string.', - '/home/runner/work/posthog/posthog/posthog/api/proxy_record.py: Warning [ProxyRecordViewset]: could not derive type of path parameter "organization_id" because it is untyped and obtaining queryset from the viewset failed. Consider adding a type to the path (e.g. ) or annotating the parameter type with @extend_schema. Defaulting to "string".', - '/home/runner/work/posthog/posthog/posthog/api/proxy_record.py: Warning [ProxyRecordViewset]: could not derive type of path parameter "id" because it is untyped and obtaining queryset from the viewset failed. Consider adding a type to the path (e.g. ) or annotating the parameter type with @extend_schema. Defaulting to "string".', - '/home/runner/work/posthog/posthog/ee/api/rbac/role.py: Warning [RoleViewSet > RoleSerializer]: unable to resolve type hint for function "get_members". Consider using a type hint or @extend_schema_field. Defaulting to string.', - '/home/runner/work/posthog/posthog/ee/api/rbac/role.py: Warning [RoleViewSet > RoleSerializer]: unable to resolve type hint for function "get_associated_flags". Consider using a type hint or @extend_schema_field. Defaulting to string.', - '/home/runner/work/posthog/posthog/ee/api/rbac/role.py: Warning [RoleMembershipViewSet]: could not derive type of path parameter "organization_id" because model "ee.models.rbac.role.RoleMembership" contained no such field. Consider annotating parameter with @extend_schema. Defaulting to "string".', - '/home/runner/work/posthog/posthog/posthog/api/action.py: Warning [ActionViewSet]: could not derive type of path parameter "project_id" because model "posthog.models.action.action.Action" contained no such field. Consider annotating parameter with @extend_schema. Defaulting to "string".', - '/home/runner/work/posthog/posthog/posthog/api/action.py: Warning [ActionViewSet > ActionSerializer]: unable to resolve type hint for function "get_creation_context". Consider using a type hint or @extend_schema_field. Defaulting to string.', - '/home/runner/work/posthog/posthog/posthog/api/activity_log.py: Warning [ActivityLogViewSet]: could not derive type of path parameter "project_id" because model "posthog.models.activity_logging.activity_log.ActivityLog" contained no such field. Consider annotating parameter with @extend_schema. Defaulting to "string".', - '/home/runner/work/posthog/posthog/posthog/api/annotation.py: Warning [AnnotationsViewSet]: could not derive type of path parameter "project_id" because model "posthog.models.annotation.Annotation" contained no such field. Consider annotating parameter with @extend_schema. Defaulting to "string".', - '/home/runner/work/posthog/posthog/posthog/api/cohort.py: Warning [CohortViewSet]: could not derive type of path parameter "project_id" because model "posthog.models.cohort.cohort.Cohort" contained no such field. Consider annotating parameter with @extend_schema. Defaulting to "string".', - '/home/runner/work/posthog/posthog/posthog/api/dashboards/dashboard_templates.py: Warning [DashboardTemplateViewSet]: could not derive type of path parameter "project_id" because model "posthog.models.dashboard_templates.DashboardTemplate" contained no such field. Consider annotating parameter with @extend_schema. Defaulting to "string".', - '/home/runner/work/posthog/posthog/posthog/api/early_access_feature.py: Warning [EarlyAccessFeatureViewSet]: could not derive type of path parameter "project_id" because model "posthog.models.early_access_feature.EarlyAccessFeature" contained no such field. Consider annotating parameter with @extend_schema. Defaulting to "string".', - '/home/runner/work/posthog/posthog/posthog/api/team.py: Warning [TeamViewSet > TeamSerializer]: unable to resolve type hint for function "get_product_intents". Consider using a type hint or @extend_schema_field. Defaulting to string.', - "/home/runner/work/posthog/posthog/posthog/api/event_definition.py: Error [EventDefinitionViewSet]: exception raised while getting serializer. Hint: Is get_serializer_class() returning None or is get_queryset() not working without a request? Ignoring the view for now. (Exception: 'AnonymousUser' object has no attribute 'organization')", - '/home/runner/work/posthog/posthog/posthog/api/event_definition.py: Warning [EventDefinitionViewSet]: could not derive type of path parameter "project_id" because model "posthog.models.event_definition.EventDefinition" contained no such field. Consider annotating parameter with @extend_schema. Defaulting to "string".', - '/home/runner/work/posthog/posthog/ee/clickhouse/views/experiment_holdouts.py: Warning [ExperimentHoldoutViewSet]: could not derive type of path parameter "project_id" because model "posthog.models.experiment.ExperimentHoldout" contained no such field. Consider annotating parameter with @extend_schema. Defaulting to "string".', - '/home/runner/work/posthog/posthog/ee/clickhouse/views/experiments.py: Warning [EnterpriseExperimentsViewSet]: could not derive type of path parameter "project_id" because model "posthog.models.experiment.Experiment" contained no such field. Consider annotating parameter with @extend_schema. Defaulting to "string".', - '/home/runner/work/posthog/posthog/posthog/api/feature_flag.py: Warning [FeatureFlagViewSet]: could not derive type of path parameter "project_id" because model "posthog.models.feature_flag.feature_flag.FeatureFlag" contained no such field. Consider annotating parameter with @extend_schema. Defaulting to "string".', - '/home/runner/work/posthog/posthog/ee/api/feature_flag_role_access.py: Warning [FeatureFlagRoleAccessViewSet]: could not derive type of path parameter "project_id" because model "ee.models.feature_flag_role_access.FeatureFlagRoleAccess" contained no such field. Consider annotating parameter with @extend_schema. Defaulting to "string".', - '/home/runner/work/posthog/posthog/ee/clickhouse/views/groups.py: Warning [GroupsTypesViewSet]: could not derive type of path parameter "project_id" because model "posthog.models.group_type_mapping.GroupTypeMapping" contained no such field. Consider annotating parameter with @extend_schema. Defaulting to "string".', - '/home/runner/work/posthog/posthog/posthog/api/notebook.py: Warning [NotebookViewSet]: could not derive type of path parameter "project_id" because model "posthog.models.notebook.notebook.Notebook" contained no such field. Consider annotating parameter with @extend_schema. Defaulting to "string".', "/home/runner/work/posthog/posthog/posthog/api/property_definition.py: Error [PropertyDefinitionViewSet]: exception raised while getting serializer. Hint: Is get_serializer_class() returning None or is get_queryset() not working without a request? Ignoring the view for now. (Exception: 'AnonymousUser' object has no attribute 'organization')", '/home/runner/work/posthog/posthog/posthog/api/property_definition.py: Warning [PropertyDefinitionViewSet]: could not derive type of path parameter "project_id" because model "posthog.models.property_definition.PropertyDefinition" contained no such field. Consider annotating parameter with @extend_schema. Defaulting to "string".', - '/home/runner/work/posthog/posthog/ee/session_recordings/session_recording_playlist.py: Warning [SessionRecordingPlaylistViewSet]: could not derive type of path parameter "project_id" because model "posthog.session_recordings.models.session_recording_playlist.SessionRecordingPlaylist" contained no such field. Consider annotating parameter with @extend_schema. Defaulting to "string".', - '/home/runner/work/posthog/posthog/ee/session_recordings/session_recording_playlist.py: Warning [SessionRecordingPlaylistViewSet]: could not derive type of path parameter "session_recording_id" because model "posthog.session_recordings.models.session_recording_playlist.SessionRecordingPlaylist" contained no such field. Consider annotating parameter with @extend_schema. Defaulting to "string".', - '/home/runner/work/posthog/posthog/posthog/api/survey.py: Warning [SurveyViewSet]: could not derive type of path parameter "project_id" because model "posthog.models.feedback.survey.Survey" contained no such field. Consider annotating parameter with @extend_schema. Defaulting to "string".', + '/home/runner/work/posthog/posthog/posthog/api/proxy_record.py: Warning [ProxyRecordViewset]: could not derive type of path parameter "id" because it is untyped and obtaining queryset from the viewset failed. Consider adding a type to the path (e.g. ) or annotating the parameter type with @extend_schema. Defaulting to "string".', + '/home/runner/work/posthog/posthog/posthog/api/proxy_record.py: Warning [ProxyRecordViewset]: could not derive type of path parameter "organization_id" because it is untyped and obtaining queryset from the viewset failed. Consider adding a type to the path (e.g. ) or annotating the parameter type with @extend_schema. Defaulting to "string".', + '/home/runner/work/posthog/posthog/posthog/api/query.py: Error [QueryViewSet]: unable to guess serializer. This is graceful fallback handling for APIViews. Consider using GenericAPIView as view base class, if view is under your control. Either way you may want to add a serializer_class (or method). Ignoring view for now.', + '/home/runner/work/posthog/posthog/posthog/api/query.py: Warning [QueryViewSet]: could not derive type of path parameter "id" because it is untyped and obtaining queryset from the viewset failed. Consider adding a type to the path (e.g. ) or annotating the parameter type with @extend_schema. Defaulting to "string".', + '/home/runner/work/posthog/posthog/posthog/api/query.py: Warning [QueryViewSet]: could not derive type of path parameter "project_id" because it is untyped and obtaining queryset from the viewset failed. Consider adding a type to the path (e.g. ) or annotating the parameter type with @extend_schema. Defaulting to "string".', + '/home/runner/work/posthog/posthog/posthog/api/session.py: Warning [SessionViewSet]: could not derive type of path parameter "project_id" because it is untyped and obtaining queryset from the viewset failed. Consider adding a type to the path (e.g. ) or annotating the parameter type with @extend_schema. Defaulting to "string".', + '/home/runner/work/posthog/posthog/posthog/api/sharing.py: Warning [SharingConfigurationViewSet]: could not derive type of path parameter "project_id" because model "posthog.models.sharing_configuration.SharingConfiguration" contained no such field. Consider annotating parameter with @extend_schema. Defaulting to "string".', '/home/runner/work/posthog/posthog/posthog/api/survey.py: Warning [SurveyViewSet > SurveySerializer]: unable to resolve type hint for function "get_conditions". Consider using a type hint or @extend_schema_field. Defaulting to string.', + '/home/runner/work/posthog/posthog/posthog/api/survey.py: Warning [SurveyViewSet]: could not derive type of path parameter "project_id" because model "posthog.models.feedback.survey.Survey" contained no such field. Consider annotating parameter with @extend_schema. Defaulting to "string".', + '/home/runner/work/posthog/posthog/posthog/api/team.py: Warning [TeamViewSet > TeamSerializer]: unable to resolve type hint for function "get_product_intents". Consider using a type hint or @extend_schema_field. Defaulting to string.', '/home/runner/work/posthog/posthog/posthog/api/web_experiment.py: Warning [WebExperimentViewSet]: could not derive type of path parameter "project_id" because model "posthog.models.web_experiment.WebExperiment" contained no such field. Consider annotating parameter with @extend_schema. Defaulting to "string".', + '/home/runner/work/posthog/posthog/posthog/batch_exports/http.py: Warning [BatchExportOrganizationViewSet]: could not derive type of path parameter "organization_id" because model "posthog.batch_exports.models.BatchExport" contained no such field. Consider annotating parameter with @extend_schema. Defaulting to "string".', + '/home/runner/work/posthog/posthog/posthog/batch_exports/http.py: Warning [BatchExportRunViewSet]: could not derive type of path parameter "project_id" because model "posthog.batch_exports.models.BatchExportRun" contained no such field. Consider annotating parameter with @extend_schema. Defaulting to "string".', + '/home/runner/work/posthog/posthog/posthog/batch_exports/http.py: Warning [BatchExportViewSet > BatchExportSerializer]: could not resolve serializer field "HogQLSelectQueryField(required=False)". Defaulting to "string"', + '/home/runner/work/posthog/posthog/posthog/batch_exports/http.py: Warning [BatchExportViewSet]: could not derive type of path parameter "project_id" because model "posthog.batch_exports.models.BatchExport" contained no such field. Consider annotating parameter with @extend_schema. Defaulting to "string".', + '/home/runner/work/posthog/posthog/posthog/models/event/util.py: Warning [EventViewSet > ClickhouseEventSerializer]: unable to resolve type hint for function "get_distinct_id". Consider using a type hint or @extend_schema_field. Defaulting to string.', + '/home/runner/work/posthog/posthog/posthog/models/event/util.py: Warning [EventViewSet > ClickhouseEventSerializer]: unable to resolve type hint for function "get_elements". Consider using a type hint or @extend_schema_field. Defaulting to string.', + '/home/runner/work/posthog/posthog/posthog/models/event/util.py: Warning [EventViewSet > ClickhouseEventSerializer]: unable to resolve type hint for function "get_elements_chain". Consider using a type hint or @extend_schema_field. Defaulting to string.', + '/home/runner/work/posthog/posthog/posthog/models/event/util.py: Warning [EventViewSet > ClickhouseEventSerializer]: unable to resolve type hint for function "get_event". Consider using a type hint or @extend_schema_field. Defaulting to string.', + '/home/runner/work/posthog/posthog/posthog/models/event/util.py: Warning [EventViewSet > ClickhouseEventSerializer]: unable to resolve type hint for function "get_id". Consider using a type hint or @extend_schema_field. Defaulting to string.', + '/home/runner/work/posthog/posthog/posthog/models/event/util.py: Warning [EventViewSet > ClickhouseEventSerializer]: unable to resolve type hint for function "get_person". Consider using a type hint or @extend_schema_field. Defaulting to string.', + '/home/runner/work/posthog/posthog/posthog/models/event/util.py: Warning [EventViewSet > ClickhouseEventSerializer]: unable to resolve type hint for function "get_properties". Consider using a type hint or @extend_schema_field. Defaulting to string.', + '/home/runner/work/posthog/posthog/posthog/models/event/util.py: Warning [EventViewSet > ClickhouseEventSerializer]: unable to resolve type hint for function "get_timestamp". Consider using a type hint or @extend_schema_field. Defaulting to string.', + '/home/runner/work/posthog/posthog/posthog/session_recordings/session_recording_api.py: Warning [SessionRecordingViewSet > SessionRecordingSerializer]: unable to resolve type hint for function "storage". Consider using a type hint or @extend_schema_field. Defaulting to string.', + '/home/runner/work/posthog/posthog/posthog/session_recordings/session_recording_api.py: Warning [SessionRecordingViewSet]: could not derive type of path parameter "project_id" because model "posthog.session_recordings.models.session_recording.SessionRecording" contained no such field. Consider annotating parameter with @extend_schema. Defaulting to "string".', + '/opt/hostedtoolcache/Python/3.11.9/x64/lib/python3.11/site-packages/pydantic/_internal/_model_construction.py: Warning [QueryViewSet > ModelMetaclass]: Encountered 2 components with identical names "Person" and different classes and . This will very likely result in an incorrect schema. Try renaming one.', + 'Warning: encountered multiple names for the same choice set (EffectivePrivilegeLevelEnum). This may be unwanted even though the generated schema is technically correct. Add an entry to ENUM_NAME_OVERRIDES to fix the naming.', 'Warning: encountered multiple names for the same choice set (HrefMatchingEnum). This may be unwanted even though the generated schema is technically correct. Add an entry to ENUM_NAME_OVERRIDES to fix the naming.', - 'Warning: enum naming encountered a non-optimally resolvable collision for fields named "kind". The same name has been used for multiple choice sets in multiple components. The collision was resolved with "KindCfaEnum". add an entry to ENUM_NAME_OVERRIDES to fix the naming.', + 'Warning: encountered multiple names for the same choice set (MembershipLevelEnum). This may be unwanted even though the generated schema is technically correct. Add an entry to ENUM_NAME_OVERRIDES to fix the naming.', 'Warning: enum naming encountered a non-optimally resolvable collision for fields named "kind". The same name has been used for multiple choice sets in multiple components. The collision was resolved with "Kind069Enum". add an entry to ENUM_NAME_OVERRIDES to fix the naming.', + 'Warning: enum naming encountered a non-optimally resolvable collision for fields named "kind". The same name has been used for multiple choice sets in multiple components. The collision was resolved with "KindCfaEnum". add an entry to ENUM_NAME_OVERRIDES to fix the naming.', 'Warning: enum naming encountered a non-optimally resolvable collision for fields named "type". The same name has been used for multiple choice sets in multiple components. The collision was resolved with "TypeF73Enum". add an entry to ENUM_NAME_OVERRIDES to fix the naming.', - 'Warning: encountered multiple names for the same choice set (EffectivePrivilegeLevelEnum). This may be unwanted even though the generated schema is technically correct. Add an entry to ENUM_NAME_OVERRIDES to fix the naming.', - 'Warning: encountered multiple names for the same choice set (MembershipLevelEnum). This may be unwanted even though the generated schema is technically correct. Add an entry to ENUM_NAME_OVERRIDES to fix the naming.', - 'Warning: operationId "environments_app_metrics_historical_exports_retrieve" has collisions [(\'/api/environments/{project_id}/app_metrics/{plugin_config_id}/historical_exports/\', \'get\'), (\'/api/environments/{project_id}/app_metrics/{plugin_config_id}/historical_exports/{id}/\', \'get\')]. resolving with numeral suffixes.', - 'Warning: operationId "environments_insights_activity_retrieve" has collisions [(\'/api/environments/{project_id}/insights/{id}/activity/\', \'get\'), (\'/api/environments/{project_id}/insights/activity/\', \'get\')]. resolving with numeral suffixes.', 'Warning: operationId "Funnels" has collisions [(\'/api/environments/{project_id}/insights/funnel/\', \'post\'), (\'/api/projects/{project_id}/insights/funnel/\', \'post\')]. resolving with numeral suffixes.', 'Warning: operationId "Trends" has collisions [(\'/api/environments/{project_id}/insights/trend/\', \'post\'), (\'/api/projects/{project_id}/insights/trend/\', \'post\')]. resolving with numeral suffixes.', - 'Warning: operationId "environments_persons_activity_retrieve" has collisions [(\'/api/environments/{project_id}/persons/{id}/activity/\', \'get\'), (\'/api/environments/{project_id}/persons/activity/\', \'get\')]. resolving with numeral suffixes.', - 'Warning: operationId "list" has collisions [(\'/api/organizations/\', \'get\'), (\'/api/organizations/{organization_id}/projects/\', \'get\')]. resolving with numeral suffixes.', - 'Warning: operationId "create" has collisions [(\'/api/organizations/\', \'post\'), (\'/api/organizations/{organization_id}/projects/\', \'post\')]. resolving with numeral suffixes.', - 'Warning: operationId "retrieve" has collisions [(\'/api/organizations/{id}/\', \'get\'), (\'/api/organizations/{organization_id}/projects/{id}/\', \'get\')]. resolving with numeral suffixes.', - 'Warning: operationId "update" has collisions [(\'/api/organizations/{id}/\', \'put\'), (\'/api/organizations/{organization_id}/projects/{id}/\', \'put\')]. resolving with numeral suffixes.', - 'Warning: operationId "partial_update" has collisions [(\'/api/organizations/{id}/\', \'patch\'), (\'/api/organizations/{organization_id}/projects/{id}/\', \'patch\')]. resolving with numeral suffixes.', - 'Warning: operationId "destroy" has collisions [(\'/api/organizations/{id}/\', \'delete\'), (\'/api/organizations/{organization_id}/projects/{id}/\', \'delete\')]. resolving with numeral suffixes.', - 'Warning: operationId "batch_exports_list" has collisions [(\'/api/organizations/{organization_id}/batch_exports/\', \'get\'), (\'/api/projects/{project_id}/batch_exports/\', \'get\')]. resolving with numeral suffixes.', + 'Warning: operationId "app_metrics_historical_exports_retrieve" has collisions [(\'/api/projects/{project_id}/app_metrics/{plugin_config_id}/historical_exports/\', \'get\'), (\'/api/projects/{project_id}/app_metrics/{plugin_config_id}/historical_exports/{id}/\', \'get\')]. resolving with numeral suffixes.', + 'Warning: operationId "batch_exports_backfill_create" has collisions [(\'/api/organizations/{organization_id}/batch_exports/{id}/backfill/\', \'post\'), (\'/api/projects/{project_id}/batch_exports/{id}/backfill/\', \'post\')]. resolving with numeral suffixes.', 'Warning: operationId "batch_exports_create" has collisions [(\'/api/organizations/{organization_id}/batch_exports/\', \'post\'), (\'/api/projects/{project_id}/batch_exports/\', \'post\')]. resolving with numeral suffixes.', - 'Warning: operationId "batch_exports_retrieve" has collisions [(\'/api/organizations/{organization_id}/batch_exports/{id}/\', \'get\'), (\'/api/projects/{project_id}/batch_exports/{id}/\', \'get\')]. resolving with numeral suffixes.', - 'Warning: operationId "batch_exports_update" has collisions [(\'/api/organizations/{organization_id}/batch_exports/{id}/\', \'put\'), (\'/api/projects/{project_id}/batch_exports/{id}/\', \'put\')]. resolving with numeral suffixes.', - 'Warning: operationId "batch_exports_partial_update" has collisions [(\'/api/organizations/{organization_id}/batch_exports/{id}/\', \'patch\'), (\'/api/projects/{project_id}/batch_exports/{id}/\', \'patch\')]. resolving with numeral suffixes.', 'Warning: operationId "batch_exports_destroy" has collisions [(\'/api/organizations/{organization_id}/batch_exports/{id}/\', \'delete\'), (\'/api/projects/{project_id}/batch_exports/{id}/\', \'delete\')]. resolving with numeral suffixes.', - 'Warning: operationId "batch_exports_backfill_create" has collisions [(\'/api/organizations/{organization_id}/batch_exports/{id}/backfill/\', \'post\'), (\'/api/projects/{project_id}/batch_exports/{id}/backfill/\', \'post\')]. resolving with numeral suffixes.', + 'Warning: operationId "batch_exports_list" has collisions [(\'/api/organizations/{organization_id}/batch_exports/\', \'get\'), (\'/api/projects/{project_id}/batch_exports/\', \'get\')]. resolving with numeral suffixes.', 'Warning: operationId "batch_exports_logs_retrieve" has collisions [(\'/api/organizations/{organization_id}/batch_exports/{id}/logs/\', \'get\'), (\'/api/projects/{project_id}/batch_exports/{id}/logs/\', \'get\')]. resolving with numeral suffixes.', + 'Warning: operationId "batch_exports_partial_update" has collisions [(\'/api/organizations/{organization_id}/batch_exports/{id}/\', \'patch\'), (\'/api/projects/{project_id}/batch_exports/{id}/\', \'patch\')]. resolving with numeral suffixes.', 'Warning: operationId "batch_exports_pause_create" has collisions [(\'/api/organizations/{organization_id}/batch_exports/{id}/pause/\', \'post\'), (\'/api/projects/{project_id}/batch_exports/{id}/pause/\', \'post\')]. resolving with numeral suffixes.', + 'Warning: operationId "batch_exports_retrieve" has collisions [(\'/api/organizations/{organization_id}/batch_exports/{id}/\', \'get\'), (\'/api/projects/{project_id}/batch_exports/{id}/\', \'get\')]. resolving with numeral suffixes.', 'Warning: operationId "batch_exports_unpause_create" has collisions [(\'/api/organizations/{organization_id}/batch_exports/{id}/unpause/\', \'post\'), (\'/api/projects/{project_id}/batch_exports/{id}/unpause/\', \'post\')]. resolving with numeral suffixes.', - 'Warning: operationId "app_metrics_historical_exports_retrieve" has collisions [(\'/api/projects/{project_id}/app_metrics/{plugin_config_id}/historical_exports/\', \'get\'), (\'/api/projects/{project_id}/app_metrics/{plugin_config_id}/historical_exports/{id}/\', \'get\')]. resolving with numeral suffixes.', + 'Warning: operationId "batch_exports_update" has collisions [(\'/api/organizations/{organization_id}/batch_exports/{id}/\', \'put\'), (\'/api/projects/{project_id}/batch_exports/{id}/\', \'put\')]. resolving with numeral suffixes.', 'Warning: operationId "cohorts_activity_retrieve" has collisions [(\'/api/projects/{project_id}/cohorts/{id}/activity/\', \'get\'), (\'/api/projects/{project_id}/cohorts/activity/\', \'get\')]. resolving with numeral suffixes.', + 'Warning: operationId "create" has collisions [(\'/api/organizations/\', \'post\'), (\'/api/organizations/{organization_id}/projects/\', \'post\')]. resolving with numeral suffixes.', + 'Warning: operationId "destroy" has collisions [(\'/api/organizations/{id}/\', \'delete\'), (\'/api/organizations/{organization_id}/projects/{id}/\', \'delete\')]. resolving with numeral suffixes.', + 'Warning: operationId "environments_app_metrics_historical_exports_retrieve" has collisions [(\'/api/environments/{project_id}/app_metrics/{plugin_config_id}/historical_exports/\', \'get\'), (\'/api/environments/{project_id}/app_metrics/{plugin_config_id}/historical_exports/{id}/\', \'get\')]. resolving with numeral suffixes.', + 'Warning: operationId "environments_insights_activity_retrieve" has collisions [(\'/api/environments/{project_id}/insights/{id}/activity/\', \'get\'), (\'/api/environments/{project_id}/insights/activity/\', \'get\')]. resolving with numeral suffixes.', + 'Warning: operationId "environments_persons_activity_retrieve" has collisions [(\'/api/environments/{project_id}/persons/{id}/activity/\', \'get\'), (\'/api/environments/{project_id}/persons/activity/\', \'get\')]. resolving with numeral suffixes.', 'Warning: operationId "event_definitions_retrieve" has collisions [(\'/api/projects/{project_id}/event_definitions/\', \'get\'), (\'/api/projects/{project_id}/event_definitions/{id}/\', \'get\')]. resolving with numeral suffixes.', 'Warning: operationId "feature_flags_activity_retrieve" has collisions [(\'/api/projects/{project_id}/feature_flags/{id}/activity/\', \'get\'), (\'/api/projects/{project_id}/feature_flags/activity/\', \'get\')]. resolving with numeral suffixes.', 'Warning: operationId "insights_activity_retrieve" has collisions [(\'/api/projects/{project_id}/insights/{id}/activity/\', \'get\'), (\'/api/projects/{project_id}/insights/activity/\', \'get\')]. resolving with numeral suffixes.', + 'Warning: operationId "list" has collisions [(\'/api/organizations/\', \'get\'), (\'/api/organizations/{organization_id}/projects/\', \'get\')]. resolving with numeral suffixes.', 'Warning: operationId "notebooks_activity_retrieve" has collisions [(\'/api/projects/{project_id}/notebooks/{short_id}/activity/\', \'get\'), (\'/api/projects/{project_id}/notebooks/activity/\', \'get\')]. resolving with numeral suffixes.', + 'Warning: operationId "partial_update" has collisions [(\'/api/organizations/{id}/\', \'patch\'), (\'/api/organizations/{organization_id}/projects/{id}/\', \'patch\')]. resolving with numeral suffixes.', 'Warning: operationId "persons_activity_retrieve" has collisions [(\'/api/projects/{project_id}/persons/{id}/activity/\', \'get\'), (\'/api/projects/{project_id}/persons/activity/\', \'get\')]. resolving with numeral suffixes.', 'Warning: operationId "property_definitions_retrieve" has collisions [(\'/api/projects/{project_id}/property_definitions/\', \'get\'), (\'/api/projects/{project_id}/property_definitions/{id}/\', \'get\')]. resolving with numeral suffixes.', + 'Warning: operationId "retrieve" has collisions [(\'/api/organizations/{id}/\', \'get\'), (\'/api/organizations/{organization_id}/projects/{id}/\', \'get\')]. resolving with numeral suffixes.', 'Warning: operationId "surveys_activity_retrieve" has collisions [(\'/api/projects/{project_id}/surveys/{id}/activity/\', \'get\'), (\'/api/projects/{project_id}/surveys/activity/\', \'get\')]. resolving with numeral suffixes.', - '', + 'Warning: operationId "update" has collisions [(\'/api/organizations/{id}/\', \'put\'), (\'/api/organizations/{organization_id}/projects/{id}/\', \'put\')]. resolving with numeral suffixes.', ]) # --- diff --git a/posthog/api/test/test_api_docs.py b/posthog/api/test/test_api_docs.py index f7f7ab1d418b0..d5e1fc9b3bbf6 100644 --- a/posthog/api/test/test_api_docs.py +++ b/posthog/api/test/test_api_docs.py @@ -30,4 +30,4 @@ def test_api_docs_generation_warnings_snapshot(self) -> None: # we log lots of warnings when generating the schema warnings = self._capsys.readouterr().err.split("\n") - assert warnings == self._snapshot + assert sorted(warnings) == self._snapshot From 78ea7fb6274cb150241e5f3dd6ab6d90b07b1985 Mon Sep 17 00:00:00 2001 From: Marcus Hof <13001502+MarconLP@users.noreply.github.com> Date: Wed, 30 Oct 2024 11:37:04 +0100 Subject: [PATCH 10/14] feat(cdp): add option to run a hog function per person per event (#25874) --- .../filters/HogFunctionFilters.tsx | 4 ++ plugin-server/tests/cdp/examples.ts | 12 +++++- plugin-server/tests/cdp/hog-masker.test.ts | 37 +++++++++++++++---- 3 files changed, 43 insertions(+), 10 deletions(-) diff --git a/frontend/src/scenes/pipeline/hogfunctions/filters/HogFunctionFilters.tsx b/frontend/src/scenes/pipeline/hogfunctions/filters/HogFunctionFilters.tsx index 9dee4c767cc5e..ed98f0f3de14b 100644 --- a/frontend/src/scenes/pipeline/hogfunctions/filters/HogFunctionFilters.tsx +++ b/frontend/src/scenes/pipeline/hogfunctions/filters/HogFunctionFilters.tsx @@ -161,6 +161,10 @@ export function HogFunctionFilters(): JSX.Element { value: '{person.id}', label: 'Run once per person per interval', }, + { + value: '{concat(person.id, event.event)}', + label: 'Run once per person per event per interval', + }, ]} value={value?.hash ?? null} onChange={(val) => diff --git a/plugin-server/tests/cdp/examples.ts b/plugin-server/tests/cdp/examples.ts index fafafce472e3d..f92dd9ed4f97a 100644 --- a/plugin-server/tests/cdp/examples.ts +++ b/plugin-server/tests/cdp/examples.ts @@ -708,8 +708,16 @@ export const HOG_MASK_EXAMPLES: Record> person: { masking: { ttl: 30, - hash: '{person.uuid}', - bytecode: ['_h', 32, 'uuid', 32, 'person', 1, 2], + hash: '{person.id}', + bytecode: ['_h', 32, 'id', 32, 'person', 1, 2], + threshold: null, + }, + }, + personAndEvent: { + masking: { + ttl: 30, + hash: '{concat(person.id, event.event)}', + bytecode: ['_H', 1, 32, 'id', 32, 'person', 1, 2, 32, 'event', 32, 'event', 1, 2, 2, 'concat', 2], threshold: null, }, }, diff --git a/plugin-server/tests/cdp/hog-masker.test.ts b/plugin-server/tests/cdp/hog-masker.test.ts index df05043290e63..a3c7a955574db 100644 --- a/plugin-server/tests/cdp/hog-masker.test.ts +++ b/plugin-server/tests/cdp/hog-masker.test.ts @@ -118,6 +118,7 @@ describe('HogMasker', () => { describe('ttl', () => { let hogFunctionPerson: HogFunctionType let hogFunctionAll: HogFunctionType + let hogFunctionPersonAndEvent: HogFunctionType beforeEach(() => { hogFunctionPerson = createHogFunction({ @@ -127,6 +128,13 @@ describe('HogMasker', () => { }, }) + hogFunctionPersonAndEvent = createHogFunction({ + masking: { + ...HOG_MASK_EXAMPLES.personAndEvent.masking!, + ttl: 1, + }, + }) + hogFunctionAll = createHogFunction({ masking: { ...HOG_MASK_EXAMPLES.all.masking!, @@ -145,20 +153,33 @@ describe('HogMasker', () => { }) it('should mask with custom hog hash', async () => { - const globalsPerson1 = createHogExecutionGlobals({ person: { uuid: '1' } as any }) - const globalsPerson2 = createHogExecutionGlobals({ person: { uuid: '2' } as any }) + const globals1 = createHogExecutionGlobals({ + person: { id: '1' } as any, + event: { event: '$pageview' } as any, + }) + const globals2 = createHogExecutionGlobals({ + person: { id: '2' } as any, + event: { event: '$autocapture' } as any, + }) + const globals3 = createHogExecutionGlobals({ + person: { id: '2' } as any, + event: { event: '$pageview' } as any, + }) const invocations = [ - createInvocation(hogFunctionPerson, globalsPerson1), - createInvocation(hogFunctionAll, globalsPerson1), - createInvocation(hogFunctionPerson, globalsPerson2), - createInvocation(hogFunctionAll, globalsPerson2), + createInvocation(hogFunctionPerson, globals1), + createInvocation(hogFunctionAll, globals1), + createInvocation(hogFunctionPersonAndEvent, globals1), + createInvocation(hogFunctionPerson, globals2), + createInvocation(hogFunctionAll, globals2), + createInvocation(hogFunctionPersonAndEvent, globals2), + createInvocation(hogFunctionPersonAndEvent, globals3), ] const res = await masker.filterByMasking(invocations) expect(res.masked.length).toEqual(1) - expect(res.notMasked.length).toEqual(3) + expect(res.notMasked.length).toEqual(6) const res2 = await masker.filterByMasking(invocations) - expect(res2.masked.length).toEqual(4) + expect(res2.masked.length).toEqual(7) expect(res2.notMasked.length).toEqual(0) }) From 3946758c98b82f01435186a523bcd593771f636b Mon Sep 17 00:00:00 2001 From: Marcus Hof <13001502+MarconLP@users.noreply.github.com> Date: Wed, 30 Oct 2024 12:14:32 +0100 Subject: [PATCH 11/14] rename per event trigger option label (#25896) --- .../scenes/pipeline/hogfunctions/filters/HogFunctionFilters.tsx | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/frontend/src/scenes/pipeline/hogfunctions/filters/HogFunctionFilters.tsx b/frontend/src/scenes/pipeline/hogfunctions/filters/HogFunctionFilters.tsx index ed98f0f3de14b..681e63a6239b2 100644 --- a/frontend/src/scenes/pipeline/hogfunctions/filters/HogFunctionFilters.tsx +++ b/frontend/src/scenes/pipeline/hogfunctions/filters/HogFunctionFilters.tsx @@ -163,7 +163,7 @@ export function HogFunctionFilters(): JSX.Element { }, { value: '{concat(person.id, event.event)}', - label: 'Run once per person per event per interval', + label: 'Run once per person per event name per interval', }, ]} value={value?.hash ?? null} From a9a77ace552df5492c1adc7b0f00728325d8d097 Mon Sep 17 00:00:00 2001 From: Paul D'Ambra Date: Wed, 30 Oct 2024 12:39:10 +0100 Subject: [PATCH 12/14] fix: session when impersonated (#25897) --- frontend/src/loadPostHogJS.tsx | 52 ++++++++++++++++++---------------- 1 file changed, 27 insertions(+), 25 deletions(-) diff --git a/frontend/src/loadPostHogJS.tsx b/frontend/src/loadPostHogJS.tsx index 2c5a3285ef509..badabf1105246 100644 --- a/frontend/src/loadPostHogJS.tsx +++ b/frontend/src/loadPostHogJS.tsx @@ -29,16 +29,38 @@ export function loadPostHogJS(): void { bootstrap: window.POSTHOG_USER_IDENTITY_WITH_FLAGS ? window.POSTHOG_USER_IDENTITY_WITH_FLAGS : {}, opt_in_site_apps: true, api_transport: 'fetch', - loaded: (posthog) => { - if (posthog.sessionRecording) { - posthog.sessionRecording._forceAllowLocalhostNetworkCapture = true + loaded: (loadedInstance) => { + if (loadedInstance.sessionRecording) { + loadedInstance.sessionRecording._forceAllowLocalhostNetworkCapture = true } if (window.IMPERSONATED_SESSION) { - posthog.opt_out_capturing() + loadedInstance.sessionManager?.resetSessionId() + loadedInstance.opt_out_capturing() } else { - posthog.opt_in_capturing() + loadedInstance.opt_in_capturing() } + + const Cypress = (window as any).Cypress + + if (Cypress) { + Object.entries(Cypress.env()).forEach(([key, value]) => { + if (key.startsWith('POSTHOG_PROPERTY_')) { + loadedInstance.register_for_session({ + [key.replace('POSTHOG_PROPERTY_', 'E2E_TESTING_').toLowerCase()]: value, + }) + } + }) + } + + // This is a helpful flag to set to automatically reset the recording session on load for testing multiple recordings + const shouldResetSessionOnLoad = loadedInstance.getFeatureFlag(FEATURE_FLAGS.SESSION_RESET_ON_LOAD) + if (shouldResetSessionOnLoad) { + loadedInstance.sessionManager?.resetSessionId() + } + + // Make sure we have access to the object in window for debugging + window.posthog = loadedInstance }, scroll_root_selector: ['main', 'html'], autocapture: { @@ -52,26 +74,6 @@ export function loadPostHogJS(): void { : undefined, }) ) - - const Cypress = (window as any).Cypress - - if (Cypress) { - Object.entries(Cypress.env()).forEach(([key, value]) => { - if (key.startsWith('POSTHOG_PROPERTY_')) { - posthog.register_for_session({ - [key.replace('POSTHOG_PROPERTY_', 'E2E_TESTING_').toLowerCase()]: value, - }) - } - }) - } - - // This is a helpful flag to set to automatically reset the recording session on load for testing multiple recordings - const shouldResetSessionOnLoad = posthog.getFeatureFlag(FEATURE_FLAGS.SESSION_RESET_ON_LOAD) - if (shouldResetSessionOnLoad) { - posthog.sessionManager?.resetSessionId() - } - // Make sure we have access to the object in window for debugging - window.posthog = posthog } else { posthog.init('fake token', { autocapture: false, From 019d4dc71a29b8151e2c35e23c17ab8491cda5a1 Mon Sep 17 00:00:00 2001 From: Juraj Majerik Date: Wed, 30 Oct 2024 12:55:15 +0100 Subject: [PATCH 13/14] chore(experiments HogQL): render main goal from HogQL (#25852) --- ee/clickhouse/views/experiments.py | 1 + ...r-onboarding--onboarding-billing--dark.png | Bin 173264 -> 173185 bytes frontend/src/lib/constants.tsx | 1 + frontend/src/queries/schema.json | 160 +++++++- frontend/src/queries/schema.ts | 9 +- .../scenes/experiments/Experiment.stories.tsx | 3 + .../experiments/ExperimentView/Goal.tsx | 19 +- .../ExperimentView/SecondaryMetricsTable.tsx | 3 +- .../ExperimentView/SummaryTable.tsx | 4 +- .../experiments/ExperimentView/components.tsx | 122 ++++-- .../scenes/experiments/experimentLogic.tsx | 203 +++++++--- frontend/src/types.ts | 12 +- .../api/test/__snapshots__/test_api_docs.ambr | 2 + .../test/__snapshots__/test_in_cohort.ambr | 8 +- .../experiment_funnels_query_runner.py | 16 +- .../experiment_trends_query_runner.py | 9 +- .../test/__snapshots__/test_trends.ambr | 204 ++++++++-- posthog/schema.py | 355 ++++++++++-------- 18 files changed, 810 insertions(+), 321 deletions(-) diff --git a/ee/clickhouse/views/experiments.py b/ee/clickhouse/views/experiments.py index 6df24dc012cea..44fe8b72b5045 100644 --- a/ee/clickhouse/views/experiments.py +++ b/ee/clickhouse/views/experiments.py @@ -184,6 +184,7 @@ class Meta: "created_by", "created_at", "updated_at", + "metrics", ] read_only_fields = [ "id", diff --git a/frontend/__snapshots__/scenes-other-onboarding--onboarding-billing--dark.png b/frontend/__snapshots__/scenes-other-onboarding--onboarding-billing--dark.png index a11674466fae07c459640c0e6051b397481dd887..032e85e82d703a6f323726b67351abba84d04bcc 100644 GIT binary patch delta 155395 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 *BkX(X&bWuoD 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 z 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

$JPP;p#>RSlD5C} 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 X+VY%6h5iz}Nq1LS^LDY)Ur+xJexC+l diff --git a/frontend/src/lib/constants.tsx b/frontend/src/lib/constants.tsx index 1ba86ab79c36b..a13f3277ec41f 100644 --- a/frontend/src/lib/constants.tsx +++ b/frontend/src/lib/constants.tsx @@ -220,6 +220,7 @@ export const FEATURE_FLAGS = { LEGACY_ACTION_WEBHOOKS: 'legacy-action-webhooks', // owner: @mariusandra #team-cdp SESSION_REPLAY_URL_TRIGGER: 'session-replay-url-trigger', // owner: @richard-better #team-replay REPLAY_TEMPLATES: 'replay-templates', // owner: @raquelmsmith #team-replay + EXPERIMENTS_HOGQL: 'experiments-hogql', // owner: @jurajmajerik #team-experiments ROLE_BASED_ACCESS_CONTROL: 'role-based-access-control', // owner: @zach EXPERIMENTS_HOLDOUTS: 'experiments-holdouts', // owner: @jurajmajerik #team-experiments MESSAGING: 'messaging', // owner @mariusandra #team-cdp diff --git a/frontend/src/queries/schema.json b/frontend/src/queries/schema.json index 75b26c88bc4de..757097fa12025 100644 --- a/frontend/src/queries/schema.json +++ b/frontend/src/queries/schema.json @@ -1315,12 +1315,25 @@ "expected_loss": { "type": "number" }, + "funnels_query": { + "$ref": "#/definitions/FunnelsQuery" + }, "insight": { - "$ref": "#/definitions/FunnelsQueryResponse" + "items": { + "items": { + "type": "object" + }, + "type": "array" + }, + "type": "array" }, "is_cached": { "type": "boolean" }, + "kind": { + "const": "ExperimentFunnelsQuery", + "type": "string" + }, "last_refresh": { "format": "date-time", "type": "string" @@ -1361,6 +1374,7 @@ "expected_loss", "insight", "is_cached", + "kind", "last_refresh", "next_allowed_client_refresh", "probability", @@ -1385,6 +1399,9 @@ "description": "What triggered the calculation of the query, leave empty if user/immediate", "type": "string" }, + "count_query": { + "$ref": "#/definitions/TrendsQuery" + }, "credible_intervals": { "additionalProperties": { "items": { @@ -1396,12 +1413,22 @@ }, "type": "object" }, + "exposure_query": { + "$ref": "#/definitions/TrendsQuery" + }, "insight": { - "$ref": "#/definitions/TrendsQueryResponse" + "items": { + "type": "object" + }, + "type": "array" }, "is_cached": { "type": "boolean" }, + "kind": { + "const": "ExperimentTrendsQuery", + "type": "string" + }, "last_refresh": { "format": "date-time", "type": "string" @@ -1444,6 +1471,7 @@ "credible_intervals", "insight", "is_cached", + "kind", "last_refresh", "next_allowed_client_refresh", "p_value", @@ -3732,8 +3760,21 @@ "expected_loss": { "type": "number" }, + "funnels_query": { + "$ref": "#/definitions/FunnelsQuery" + }, "insight": { - "$ref": "#/definitions/FunnelsQueryResponse" + "items": { + "items": { + "type": "object" + }, + "type": "array" + }, + "type": "array" + }, + "kind": { + "const": "ExperimentFunnelsQuery", + "type": "string" }, "probability": { "additionalProperties": { @@ -3758,6 +3799,7 @@ "credible_intervals", "expected_loss", "insight", + "kind", "probability", "significance_code", "significant", @@ -3768,6 +3810,9 @@ { "additionalProperties": false, "properties": { + "count_query": { + "$ref": "#/definitions/TrendsQuery" + }, "credible_intervals": { "additionalProperties": { "items": { @@ -3779,8 +3824,18 @@ }, "type": "object" }, + "exposure_query": { + "$ref": "#/definitions/TrendsQuery" + }, "insight": { - "$ref": "#/definitions/TrendsQueryResponse" + "items": { + "type": "object" + }, + "type": "array" + }, + "kind": { + "const": "ExperimentTrendsQuery", + "type": "string" }, "p_value": { "type": "number" @@ -3807,6 +3862,7 @@ "required": [ "credible_intervals", "insight", + "kind", "p_value", "probability", "significance_code", @@ -5215,8 +5271,21 @@ "expected_loss": { "type": "number" }, + "funnels_query": { + "$ref": "#/definitions/FunnelsQuery" + }, "insight": { - "$ref": "#/definitions/FunnelsQueryResponse" + "items": { + "items": { + "type": "object" + }, + "type": "array" + }, + "type": "array" + }, + "kind": { + "const": "ExperimentFunnelsQuery", + "type": "string" }, "probability": { "additionalProperties": { @@ -5238,6 +5307,7 @@ } }, "required": [ + "kind", "insight", "variants", "probability", @@ -5282,6 +5352,9 @@ "ExperimentTrendsQueryResponse": { "additionalProperties": false, "properties": { + "count_query": { + "$ref": "#/definitions/TrendsQuery" + }, "credible_intervals": { "additionalProperties": { "items": { @@ -5293,8 +5366,18 @@ }, "type": "object" }, + "exposure_query": { + "$ref": "#/definitions/TrendsQuery" + }, "insight": { - "$ref": "#/definitions/TrendsQueryResponse" + "items": { + "type": "object" + }, + "type": "array" + }, + "kind": { + "const": "ExperimentTrendsQuery", + "type": "string" }, "p_value": { "type": "number" @@ -5319,6 +5402,7 @@ } }, "required": [ + "kind", "insight", "variants", "probability", @@ -8962,8 +9046,21 @@ "expected_loss": { "type": "number" }, + "funnels_query": { + "$ref": "#/definitions/FunnelsQuery" + }, "insight": { - "$ref": "#/definitions/FunnelsQueryResponse" + "items": { + "items": { + "type": "object" + }, + "type": "array" + }, + "type": "array" + }, + "kind": { + "const": "ExperimentFunnelsQuery", + "type": "string" }, "probability": { "additionalProperties": { @@ -8985,6 +9082,7 @@ } }, "required": [ + "kind", "insight", "variants", "probability", @@ -8998,6 +9096,9 @@ { "additionalProperties": false, "properties": { + "count_query": { + "$ref": "#/definitions/TrendsQuery" + }, "credible_intervals": { "additionalProperties": { "items": { @@ -9009,8 +9110,18 @@ }, "type": "object" }, + "exposure_query": { + "$ref": "#/definitions/TrendsQuery" + }, "insight": { - "$ref": "#/definitions/TrendsQueryResponse" + "items": { + "type": "object" + }, + "type": "array" + }, + "kind": { + "const": "ExperimentTrendsQuery", + "type": "string" }, "p_value": { "type": "number" @@ -9035,6 +9146,7 @@ } }, "required": [ + "kind", "insight", "variants", "probability", @@ -9607,8 +9719,21 @@ "expected_loss": { "type": "number" }, + "funnels_query": { + "$ref": "#/definitions/FunnelsQuery" + }, "insight": { - "$ref": "#/definitions/FunnelsQueryResponse" + "items": { + "items": { + "type": "object" + }, + "type": "array" + }, + "type": "array" + }, + "kind": { + "const": "ExperimentFunnelsQuery", + "type": "string" }, "probability": { "additionalProperties": { @@ -9633,6 +9758,7 @@ "credible_intervals", "expected_loss", "insight", + "kind", "probability", "significance_code", "significant", @@ -9643,6 +9769,9 @@ { "additionalProperties": false, "properties": { + "count_query": { + "$ref": "#/definitions/TrendsQuery" + }, "credible_intervals": { "additionalProperties": { "items": { @@ -9654,8 +9783,18 @@ }, "type": "object" }, + "exposure_query": { + "$ref": "#/definitions/TrendsQuery" + }, "insight": { - "$ref": "#/definitions/TrendsQueryResponse" + "items": { + "type": "object" + }, + "type": "array" + }, + "kind": { + "const": "ExperimentTrendsQuery", + "type": "string" }, "p_value": { "type": "number" @@ -9682,6 +9821,7 @@ "required": [ "credible_intervals", "insight", + "kind", "p_value", "probability", "significance_code", diff --git a/frontend/src/queries/schema.ts b/frontend/src/queries/schema.ts index 273605a42f6d7..8fb58464d3ce4 100644 --- a/frontend/src/queries/schema.ts +++ b/frontend/src/queries/schema.ts @@ -1621,7 +1621,10 @@ export enum ExperimentSignificanceCode { } export interface ExperimentTrendsQueryResponse { - insight: TrendsQueryResponse + kind: NodeKind.ExperimentTrendsQuery + insight: Record[] + count_query?: TrendsQuery + exposure_query?: TrendsQuery variants: ExperimentVariantTrendsBaseStats[] probability: Record significant: boolean @@ -1633,7 +1636,9 @@ export interface ExperimentTrendsQueryResponse { export type CachedExperimentTrendsQueryResponse = CachedQueryResponse export interface ExperimentFunnelsQueryResponse { - insight: FunnelsQueryResponse + kind: NodeKind.ExperimentFunnelsQuery + insight: Record[][] + funnels_query?: FunnelsQuery variants: ExperimentVariantFunnelsBaseStats[] probability: Record significant: boolean diff --git a/frontend/src/scenes/experiments/Experiment.stories.tsx b/frontend/src/scenes/experiments/Experiment.stories.tsx index daab995ff3aa1..8d2aecd75ab1e 100644 --- a/frontend/src/scenes/experiments/Experiment.stories.tsx +++ b/frontend/src/scenes/experiments/Experiment.stories.tsx @@ -116,6 +116,7 @@ const MOCK_FUNNEL_EXPERIMENT: Experiment = { interval: 'day', filter_test_accounts: true, }, + metrics: [], archived: false, created_by: { id: 1, @@ -172,6 +173,7 @@ const MOCK_TREND_EXPERIMENT: Experiment = { }, }, }, + metrics: [], parameters: { feature_flag_variants: [ { @@ -277,6 +279,7 @@ const MOCK_TREND_EXPERIMENT_MANY_VARIANTS: Experiment = { }, }, }, + metrics: [], parameters: { feature_flag_variants: [ { diff --git a/frontend/src/scenes/experiments/ExperimentView/Goal.tsx b/frontend/src/scenes/experiments/ExperimentView/Goal.tsx index b0ef5701ec5c7..c68acb47f9df4 100644 --- a/frontend/src/scenes/experiments/ExperimentView/Goal.tsx +++ b/frontend/src/scenes/experiments/ExperimentView/Goal.tsx @@ -238,17 +238,16 @@ export function Goal(): JSX.Element { Change goal - {experimentInsightType === InsightType.TRENDS && - !experimentMathAggregationForTrends(experiment.filters) && ( - <> - -

-
- -
+ {experimentInsightType === InsightType.TRENDS && !experimentMathAggregationForTrends() && ( + <> + +
+
+
- - )} +
+ + )}
) diff --git a/frontend/src/scenes/experiments/ExperimentView/SecondaryMetricsTable.tsx b/frontend/src/scenes/experiments/ExperimentView/SecondaryMetricsTable.tsx index aadaebee40729..e9c19a72eb589 100644 --- a/frontend/src/scenes/experiments/ExperimentView/SecondaryMetricsTable.tsx +++ b/frontend/src/scenes/experiments/ExperimentView/SecondaryMetricsTable.tsx @@ -157,7 +157,6 @@ export function SecondaryMetricsTable({ experiment.secondary_metrics?.forEach((metric, idx) => { const targetResults = secondaryMetricResults?.[idx] - const targetResultFilters = targetResults?.filters const winningVariant = getHighestProbabilityVariant(targetResults || null) const Header = (): JSX.Element => ( @@ -206,7 +205,7 @@ export function SecondaryMetricsTable({ )} ] - {experimentMathAggregationForTrends(targetResultFilters) ? 'metric' : 'count'} + {experimentMathAggregationForTrends() ? 'metric' : 'count'} ), diff --git a/frontend/src/scenes/experiments/ExperimentView/SummaryTable.tsx b/frontend/src/scenes/experiments/ExperimentView/SummaryTable.tsx index e046d0f3a52fe..1814cb8717795 100644 --- a/frontend/src/scenes/experiments/ExperimentView/SummaryTable.tsx +++ b/frontend/src/scenes/experiments/ExperimentView/SummaryTable.tsx @@ -59,9 +59,7 @@ export function SummaryTable(): JSX.Element { {experimentResults.insight?.[0] && 'action' in experimentResults.insight[0] && ( )} - - {experimentMathAggregationForTrends(experimentResults?.filters) ? 'metric' : 'count'} - + {experimentMathAggregationForTrends() ? 'metric' : 'count'} ), render: function Key(_, variant): JSX.Element { diff --git a/frontend/src/scenes/experiments/ExperimentView/components.tsx b/frontend/src/scenes/experiments/ExperimentView/components.tsx index e61c32505c857..43a7b46e58f74 100644 --- a/frontend/src/scenes/experiments/ExperimentView/components.tsx +++ b/frontend/src/scenes/experiments/ExperimentView/components.tsx @@ -22,6 +22,7 @@ import { FEATURE_FLAGS } from 'lib/constants' import { dayjs } from 'lib/dayjs' import { IconAreaChart } from 'lib/lemon-ui/icons' import { More } from 'lib/lemon-ui/LemonButton/More' +import { featureFlagLogic } from 'lib/logic/featureFlagLogic' import { useEffect, useState } from 'react' import { urls } from 'scenes/urls' @@ -29,7 +30,15 @@ import { groupsModel } from '~/models/groupsModel' import { filtersToQueryNode } from '~/queries/nodes/InsightQuery/utils/filtersToQueryNode' import { queryFromFilters } from '~/queries/nodes/InsightViz/utils' import { Query } from '~/queries/Query/Query' -import { InsightVizNode, NodeKind } from '~/queries/schema' +import { + CachedExperimentFunnelsQueryResponse, + CachedExperimentTrendsQueryResponse, + ExperimentFunnelsQueryResponse, + ExperimentTrendsQueryResponse, + InsightQueryNode, + InsightVizNode, + NodeKind, +} from '~/queries/schema' import { Experiment, Experiment as ExperimentType, @@ -108,10 +117,54 @@ export function ResultsQuery({ targetResults, showTable, }: { - targetResults: ExperimentResults['result'] | null + targetResults: ExperimentResults['result'] | ExperimentTrendsQueryResponse | ExperimentFunnelsQueryResponse | null showTable: boolean }): JSX.Element { - if (!targetResults?.filters) { + const { featureFlags } = useValues(featureFlagLogic) + if (featureFlags[FEATURE_FLAGS.EXPERIMENTS_HOGQL]) { + const newQueryResults = targetResults as unknown as + | CachedExperimentTrendsQueryResponse + | CachedExperimentFunnelsQueryResponse + + const query = + newQueryResults.kind === NodeKind.ExperimentTrendsQuery + ? newQueryResults.count_query + : newQueryResults.funnels_query + const fakeInsightId = Math.random().toString(36).substring(2, 15) + + return ( + + ) + } + + const oldQueryResults = targetResults as ExperimentResults['result'] + + if (!oldQueryResults?.filters) { return <> } @@ -119,22 +172,22 @@ export function ResultsQuery({ }: { icon?: JSX.Element }): JSX.Element { - const { experimentResults, experiment } = useValues(experimentLogic) + const { experimentResults, experiment, featureFlags } = useValues(experimentLogic) // keep in sync with https://github.com/PostHog/posthog/blob/master/ee/clickhouse/queries/experiments/funnel_experiment_result.py#L71 // :TRICKY: In the case of no results, we still want users to explore the query, so they can debug further. @@ -160,18 +213,41 @@ export function ExploreButton({ icon = }: { icon?: JSX.Element properties: [], } - const query: InsightVizNode = { - kind: NodeKind.InsightVizNode, - source: filtersToQueryNode( - transformResultFilters( - experimentResults?.filters - ? { ...experimentResults.filters, explicit_date: true } - : filtersFromExperiment - ) - ), - showTable: true, - showLastComputation: true, - showLastComputationRefresh: false, + let query: InsightVizNode + if (featureFlags[FEATURE_FLAGS.EXPERIMENTS_HOGQL]) { + const newQueryResults = experimentResults as unknown as + | CachedExperimentTrendsQueryResponse + | CachedExperimentFunnelsQueryResponse + + const source = + newQueryResults.kind === NodeKind.ExperimentTrendsQuery + ? newQueryResults.count_query + : newQueryResults.funnels_query + + query = { + kind: NodeKind.InsightVizNode, + source: source as InsightQueryNode, + } + } else { + const oldQueryResults = experimentResults as ExperimentResults['result'] + + if (!oldQueryResults?.filters) { + return <> + } + + query = { + kind: NodeKind.InsightVizNode, + source: filtersToQueryNode( + transformResultFilters( + oldQueryResults?.filters + ? { ...oldQueryResults.filters, explicit_date: true } + : filtersFromExperiment + ) + ), + showTable: true, + showLastComputation: true, + showLastComputationRefresh: false, + } } return ( diff --git a/frontend/src/scenes/experiments/experimentLogic.tsx b/frontend/src/scenes/experiments/experimentLogic.tsx index 19e33aca83831..4db270269a634 100644 --- a/frontend/src/scenes/experiments/experimentLogic.tsx +++ b/frontend/src/scenes/experiments/experimentLogic.tsx @@ -5,6 +5,7 @@ import { loaders } from 'kea-loaders' import { router, urlToAction } from 'kea-router' import api from 'lib/api' import { EXPERIMENT_DEFAULT_DURATION, FunnelLayout } from 'lib/constants' +import { FEATURE_FLAGS } from 'lib/constants' import { dayjs } from 'lib/dayjs' import { lemonToast } from 'lib/lemon-ui/LemonToast/LemonToast' import { Tooltip } from 'lib/lemon-ui/Tooltip' @@ -27,7 +28,15 @@ import { cohortsModel } from '~/models/cohortsModel' import { groupsModel } from '~/models/groupsModel' import { filtersToQueryNode } from '~/queries/nodes/InsightQuery/utils/filtersToQueryNode' import { queryNodeToFilter } from '~/queries/nodes/InsightQuery/utils/queryNodeToFilter' -import { FunnelsQuery, InsightVizNode, TrendsQuery } from '~/queries/schema' +import { + CachedExperimentFunnelsQueryResponse, + CachedExperimentTrendsQueryResponse, + ExperimentTrendsQuery, + FunnelsQuery, + InsightVizNode, + NodeKind, + TrendsQuery, +} from '~/queries/schema' import { isFunnelsQuery } from '~/queries/utils' import { ActionFilter as ActionFilterType, @@ -62,6 +71,7 @@ const NEW_EXPERIMENT: Experiment = { name: '', feature_flag_key: '', filters: {}, + metrics: [], parameters: { feature_flag_variants: [ { key: 'control', rollout_percentage: 50 }, @@ -767,10 +777,36 @@ export const experimentLogic = kea([ }, }, experimentResults: [ - null as ExperimentResults['result'] | null, + null as + | ExperimentResults['result'] + | CachedExperimentTrendsQueryResponse + | CachedExperimentFunnelsQueryResponse + | null, { - loadExperimentResults: async (refresh?: boolean) => { + loadExperimentResults: async ( + refresh?: boolean + ): Promise< + | ExperimentResults['result'] + | CachedExperimentTrendsQueryResponse + | CachedExperimentFunnelsQueryResponse + | null + > => { try { + if (values.featureFlags[FEATURE_FLAGS.EXPERIMENTS_HOGQL]) { + const query = values.experiment.metrics[0].query + + const response: ExperimentResults = await api.create( + `api/projects/${values.currentTeamId}/query`, + { query } + ) + + return { + ...response, + fakeInsightId: Math.random().toString(36).substring(2, 15), + last_refresh: response.last_refresh || '', + } as unknown as CachedExperimentTrendsQueryResponse | CachedExperimentFunnelsQueryResponse + } + const refreshParam = refresh ? '?refresh=true' : '' const response: ExperimentResults = await api.get( `api/projects/${values.currentTeamId}/experiments/${values.experimentId}/results${refreshParam}` @@ -862,8 +898,13 @@ export const experimentLogic = kea([ (experimentId): Experiment['id'] => experimentId, ], experimentInsightType: [ - (s) => [s.experiment], - (experiment): InsightType => { + (s) => [s.experiment, s.featureFlags], + (experiment, featureFlags): InsightType => { + if (featureFlags[FEATURE_FLAGS.EXPERIMENTS_HOGQL]) { + const query = experiment?.metrics?.[0]?.query + return query?.kind === NodeKind.ExperimentTrendsQuery ? InsightType.TRENDS : InsightType.FUNNELS + } + return experiment?.filters?.insight || InsightType.FUNNELS }, ], @@ -909,31 +950,40 @@ export const experimentLogic = kea([ }, ], experimentMathAggregationForTrends: [ - () => [], - () => - (filters?: FilterType): PropertyMathType | CountPerActorMathType | undefined => { - // Find out if we're using count per actor math aggregates averages per user - const userMathValue = ( - [...(filters?.events || []), ...(filters?.actions || [])] as ActionFilterType[] - ).filter((entity) => - Object.values(CountPerActorMathType).includes(entity?.math as CountPerActorMathType) - )[0]?.math - - // alternatively, if we're using property math - // remove 'sum' property math from the list of math types - // since we can handle that as a regular case - const targetValues = Object.values(PropertyMathType).filter( - (value) => value !== PropertyMathType.Sum - ) - // sync with the backend at https://github.com/PostHog/posthog/blob/master/ee/clickhouse/queries/experiments/trend_experiment_result.py#L44 - // the function uses_math_aggregation_by_user_or_property_value + (s) => [s.experiment, s.featureFlags], + (experiment, featureFlags) => (): PropertyMathType | CountPerActorMathType | undefined => { + let entities: { math?: string }[] = [] + + if (featureFlags[FEATURE_FLAGS.EXPERIMENTS_HOGQL]) { + const query = experiment?.metrics?.[0]?.query as ExperimentTrendsQuery + if (!query) { + return undefined + } + entities = query.count_query?.series || [] + } else { + const filters = experiment?.filters + if (!filters) { + return undefined + } + entities = [...(filters?.events || []), ...(filters?.actions || [])] as ActionFilterType[] + } - const propertyMathValue = ( - [...(filters?.events || []), ...(filters?.actions || [])] as ActionFilterType[] - ).filter((entity) => targetValues.includes(entity?.math as PropertyMathType))[0]?.math + // Find out if we're using count per actor math aggregates averages per user + const userMathValue = entities.filter((entity) => + Object.values(CountPerActorMathType).includes(entity?.math as CountPerActorMathType) + )[0]?.math - return (userMathValue ?? propertyMathValue) as PropertyMathType | CountPerActorMathType | undefined - }, + // alternatively, if we're using property math + // remove 'sum' property math from the list of math types + // since we can handle that as a regular case + const targetValues = Object.values(PropertyMathType).filter((value) => value !== PropertyMathType.Sum) + + const propertyMathValue = entities.filter((entity) => + targetValues.includes(entity?.math as PropertyMathType) + )[0]?.math + + return (userMathValue ?? propertyMathValue) as PropertyMathType | CountPerActorMathType | undefined + }, ], minimumDetectableEffect: [ (s) => [s.experiment, s.experimentInsightType, s.conversionMetrics, s.trendResults], @@ -1126,7 +1176,14 @@ export const experimentLogic = kea([ conversionRateForVariant: [ () => [], () => - (experimentResults: Partial | null, variantKey: string): number | null => { + ( + experimentResults: + | Partial + | CachedExperimentFunnelsQueryResponse + | CachedExperimentTrendsQueryResponse + | null, + variantKey: string + ): number | null => { if (!experimentResults || !experimentResults.insight) { return null } @@ -1144,34 +1201,47 @@ export const experimentLogic = kea([ }, ], getIndexForVariant: [ - () => [], - () => - (experimentResults: Partial | null, variant: string): number | null => { - // TODO: Would be nice for every secondary metric to have the same colour for variants - const insightType = experimentResults?.filters?.insight - let result: number | null = null + (s) => [s.experimentInsightType], + (experimentInsightType) => + ( + experimentResults: + | Partial + | CachedExperimentTrendsQueryResponse + | CachedExperimentFunnelsQueryResponse + | null, + variant: string + ): number | null => { // Ensures we get the right index from results, so the UI can // display the right colour for the variant if (!experimentResults || !experimentResults.insight) { return null } + let index = -1 - if (insightType === InsightType.FUNNELS) { + if (experimentInsightType === InsightType.FUNNELS) { // Funnel Insight is displayed in order of decreasing count - index = ([...experimentResults.insight] as FunnelStep[][]) - .sort((a, b) => b[0]?.count - a[0]?.count) - .findIndex( - (variantFunnel: FunnelStep[]) => variantFunnel[0]?.breakdown_value?.[0] === variant - ) + index = (Array.isArray(experimentResults.insight) ? [...experimentResults.insight] : []) + .sort((a, b) => { + const aCount = (a && Array.isArray(a) && a[0]?.count) || 0 + const bCount = (b && Array.isArray(b) && b[0]?.count) || 0 + return bCount - aCount + }) + .findIndex((variantFunnel) => { + if (!Array.isArray(variantFunnel) || !variantFunnel[0]?.breakdown_value) { + return false + } + const breakdownValue = variantFunnel[0].breakdown_value + return Array.isArray(breakdownValue) && breakdownValue[0] === variant + }) } else { index = (experimentResults.insight as TrendResult[]).findIndex( (variantTrend: TrendResult) => variantTrend.breakdown_value === variant ) } - result = index === -1 ? null : index + const result = index === -1 ? null : index - if (result !== null && insightType === InsightType.FUNNELS) { - result++ + if (result !== null && experimentInsightType === InsightType.FUNNELS) { + return result + 1 } return result }, @@ -1179,10 +1249,15 @@ export const experimentLogic = kea([ countDataForVariant: [ (s) => [s.experimentMathAggregationForTrends], (experimentMathAggregationForTrends) => - (experimentResults: Partial | null, variant: string): number | null => { - const usingMathAggregationType = experimentMathAggregationForTrends( - experimentResults?.filters || {} - ) + ( + experimentResults: + | Partial + | CachedExperimentTrendsQueryResponse + | CachedExperimentFunnelsQueryResponse + | null, + variant: string + ): number | null => { + const usingMathAggregationType = experimentMathAggregationForTrends() if (!experimentResults || !experimentResults.insight) { return null } @@ -1223,7 +1298,14 @@ export const experimentLogic = kea([ exposureCountDataForVariant: [ () => [], () => - (experimentResults: Partial | null, variant: string): number | null => { + ( + experimentResults: + | Partial + | CachedExperimentTrendsQueryResponse + | CachedExperimentFunnelsQueryResponse + | null, + variant: string + ): number | null => { if (!experimentResults || !experimentResults.variants) { return null } @@ -1241,14 +1323,21 @@ export const experimentLogic = kea([ ], getHighestProbabilityVariant: [ () => [], - () => (results: ExperimentResults['result'] | null) => { - if (results && results.probability) { - const maxValue = Math.max(...Object.values(results.probability)) - return Object.keys(results.probability).find( - (key) => Math.abs(results.probability[key] - maxValue) < Number.EPSILON - ) - } - }, + () => + ( + results: + | ExperimentResults['result'] + | CachedExperimentTrendsQueryResponse + | CachedExperimentFunnelsQueryResponse + | null + ) => { + if (results && results.probability) { + const maxValue = Math.max(...Object.values(results.probability)) + return Object.keys(results.probability).find( + (key) => Math.abs(results.probability[key] - maxValue) < Number.EPSILON + ) + } + }, ], sortedExperimentResultVariants: [ (s) => [s.experimentResults, s.experiment], diff --git a/frontend/src/types.ts b/frontend/src/types.ts index eb839f5252bcd..4a17a89a811cd 100644 --- a/frontend/src/types.ts +++ b/frontend/src/types.ts @@ -35,6 +35,8 @@ import { QueryContext } from '~/queries/types' import type { DashboardFilter, DatabaseSchemaField, + ExperimentFunnelsQuery, + ExperimentTrendsQuery, HogQLQuery, HogQLQueryModifiers, HogQLVariable, @@ -3242,6 +3244,11 @@ export interface Group { group_properties: Record } +export interface ExperimentMetric { + type: string + query: ExperimentTrendsQuery | ExperimentFunnelsQuery +} + export interface Experiment { id: number | 'new' name: string @@ -3250,6 +3257,7 @@ export interface Experiment { feature_flag?: FeatureFlagBasicType exposure_cohort?: number filters: FilterType + metrics: ExperimentMetric[] parameters: { minimum_detectable_effect?: number recommended_running_time?: number @@ -3294,7 +3302,7 @@ interface BaseExperimentResults { } export interface _TrendsExperimentResults extends BaseExperimentResults { - insight: TrendResult[] + insight: Record[] filters: TrendsFilterType variants: TrendExperimentVariant[] last_refresh?: string | null @@ -3302,7 +3310,7 @@ export interface _TrendsExperimentResults extends BaseExperimentResults { } export interface _FunnelExperimentResults extends BaseExperimentResults { - insight: FunnelStep[][] + insight: Record[] filters: FunnelsFilterType variants: FunnelExperimentVariant[] last_refresh?: string | null diff --git a/posthog/api/test/__snapshots__/test_api_docs.ambr b/posthog/api/test/__snapshots__/test_api_docs.ambr index 9b7667ec6484b..044ee43f1983e 100644 --- a/posthog/api/test/__snapshots__/test_api_docs.ambr +++ b/posthog/api/test/__snapshots__/test_api_docs.ambr @@ -101,6 +101,8 @@ 'Warning: encountered multiple names for the same choice set (HrefMatchingEnum). This may be unwanted even though the generated schema is technically correct. Add an entry to ENUM_NAME_OVERRIDES to fix the naming.', 'Warning: encountered multiple names for the same choice set (MembershipLevelEnum). This may be unwanted even though the generated schema is technically correct. Add an entry to ENUM_NAME_OVERRIDES to fix the naming.', 'Warning: enum naming encountered a non-optimally resolvable collision for fields named "kind". The same name has been used for multiple choice sets in multiple components. The collision was resolved with "Kind069Enum". add an entry to ENUM_NAME_OVERRIDES to fix the naming.', + 'Warning: enum naming encountered a non-optimally resolvable collision for fields named "kind". The same name has been used for multiple choice sets in multiple components. The collision was resolved with "Kind0ddEnum". add an entry to ENUM_NAME_OVERRIDES to fix the naming.', + 'Warning: enum naming encountered a non-optimally resolvable collision for fields named "kind". The same name has been used for multiple choice sets in multiple components. The collision was resolved with "Kind496Enum". add an entry to ENUM_NAME_OVERRIDES to fix the naming.', 'Warning: enum naming encountered a non-optimally resolvable collision for fields named "kind". The same name has been used for multiple choice sets in multiple components. The collision was resolved with "KindCfaEnum". add an entry to ENUM_NAME_OVERRIDES to fix the naming.', 'Warning: enum naming encountered a non-optimally resolvable collision for fields named "type". The same name has been used for multiple choice sets in multiple components. The collision was resolved with "TypeF73Enum". add an entry to ENUM_NAME_OVERRIDES to fix the naming.', 'Warning: operationId "Funnels" has collisions [(\'/api/environments/{project_id}/insights/funnel/\', \'post\'), (\'/api/projects/{project_id}/insights/funnel/\', \'post\')]. resolving with numeral suffixes.', diff --git a/posthog/hogql/transforms/test/__snapshots__/test_in_cohort.ambr b/posthog/hogql/transforms/test/__snapshots__/test_in_cohort.ambr index f018e96ef067a..06e46e0ca30b0 100644 --- a/posthog/hogql/transforms/test/__snapshots__/test_in_cohort.ambr +++ b/posthog/hogql/transforms/test/__snapshots__/test_in_cohort.ambr @@ -31,7 +31,7 @@ FROM events LEFT JOIN ( SELECT person_static_cohort.person_id AS cohort_person_id, 1 AS matched, person_static_cohort.cohort_id AS cohort_id FROM person_static_cohort - WHERE and(equals(person_static_cohort.team_id, 420), in(person_static_cohort.cohort_id, [4]))) AS __in_cohort ON equals(__in_cohort.cohort_person_id, events.person_id) + WHERE and(equals(person_static_cohort.team_id, 420), in(person_static_cohort.cohort_id, [6]))) AS __in_cohort ON equals(__in_cohort.cohort_person_id, events.person_id) WHERE and(equals(events.team_id, 420), 1, ifNull(equals(__in_cohort.matched, 1), 0)) LIMIT 100 SETTINGS readonly=2, max_execution_time=60, allow_experimental_object_type=1, format_csv_allow_double_quotes=0, max_ast_elements=4000000, max_expanded_ast_elements=4000000, max_bytes_before_external_group_by=0 @@ -42,7 +42,7 @@ FROM events LEFT JOIN ( SELECT person_id AS cohort_person_id, 1 AS matched, cohort_id FROM static_cohort_people - WHERE in(cohort_id, [4])) AS __in_cohort ON equals(__in_cohort.cohort_person_id, person_id) + WHERE in(cohort_id, [6])) AS __in_cohort ON equals(__in_cohort.cohort_person_id, person_id) WHERE and(1, equals(__in_cohort.matched, 1)) LIMIT 100 ''' @@ -55,7 +55,7 @@ FROM events LEFT JOIN ( SELECT person_static_cohort.person_id AS cohort_person_id, 1 AS matched, person_static_cohort.cohort_id AS cohort_id FROM person_static_cohort - WHERE and(equals(person_static_cohort.team_id, 420), in(person_static_cohort.cohort_id, [5]))) AS __in_cohort ON equals(__in_cohort.cohort_person_id, events.person_id) + WHERE and(equals(person_static_cohort.team_id, 420), in(person_static_cohort.cohort_id, [7]))) AS __in_cohort ON equals(__in_cohort.cohort_person_id, events.person_id) WHERE and(equals(events.team_id, 420), 1, ifNull(equals(__in_cohort.matched, 1), 0)) LIMIT 100 SETTINGS readonly=2, max_execution_time=60, allow_experimental_object_type=1, format_csv_allow_double_quotes=0, max_ast_elements=4000000, max_expanded_ast_elements=4000000, max_bytes_before_external_group_by=0 @@ -66,7 +66,7 @@ FROM events LEFT JOIN ( SELECT person_id AS cohort_person_id, 1 AS matched, cohort_id FROM static_cohort_people - WHERE in(cohort_id, [5])) AS __in_cohort ON equals(__in_cohort.cohort_person_id, person_id) + WHERE in(cohort_id, [7])) AS __in_cohort ON equals(__in_cohort.cohort_person_id, person_id) WHERE and(1, equals(__in_cohort.matched, 1)) LIMIT 100 ''' diff --git a/posthog/hogql_queries/experiments/experiment_funnels_query_runner.py b/posthog/hogql_queries/experiments/experiment_funnels_query_runner.py index c6783daa489e0..23ba38cd742a3 100644 --- a/posthog/hogql_queries/experiments/experiment_funnels_query_runner.py +++ b/posthog/hogql_queries/experiments/experiment_funnels_query_runner.py @@ -36,9 +36,9 @@ def __init__(self, *args, **kwargs): self.experiment = Experiment.objects.get(id=self.query.experiment_id) self.feature_flag = self.experiment.feature_flag self.variants = [variant["key"] for variant in self.feature_flag.variants] - self.prepared_funnel_query = self._prepare_funnel_query() + self.prepared_funnels_query = self._prepare_funnel_query() self.funnels_query_runner = FunnelsQueryRunner( - query=self.prepared_funnel_query, team=self.team, timings=self.timings, limit_context=self.limit_context + query=self.prepared_funnels_query, team=self.team, timings=self.timings, limit_context=self.limit_context ) def calculate(self) -> ExperimentFunnelsQueryResponse: @@ -53,7 +53,9 @@ def calculate(self) -> ExperimentFunnelsQueryResponse: credible_intervals = calculate_credible_intervals([control_variant, *test_variants]) return ExperimentFunnelsQueryResponse( - insight=funnels_result, + kind="ExperimentFunnelsQuery", + funnels_query=self.prepared_funnels_query, + insight=funnels_result.results, variants=[variant.model_dump() for variant in [control_variant, *test_variants]], probability={ variant.key: probability @@ -75,7 +77,7 @@ def _prepare_funnel_query(self) -> FunnelsQuery: to separate results for different experiment variants. """ # Clone the source query - prepared_funnel_query = FunnelsQuery(**self.query.source.model_dump()) + prepared_funnels_query = FunnelsQuery(**self.query.source.model_dump()) # Set the date range to match the experiment's duration, using the project's timezone if self.team.timezone: @@ -86,19 +88,19 @@ def _prepare_funnel_query(self) -> FunnelsQuery: start_date = self.experiment.start_date end_date = self.experiment.end_date - prepared_funnel_query.dateRange = InsightDateRange( + prepared_funnels_query.dateRange = InsightDateRange( date_from=start_date.isoformat() if start_date else None, date_to=end_date.isoformat() if end_date else None, explicitDate=True, ) # Configure the breakdown to use the feature flag key - prepared_funnel_query.breakdownFilter = BreakdownFilter( + prepared_funnels_query.breakdownFilter = BreakdownFilter( breakdown=f"$feature/{self.feature_flag.key}", breakdown_type="event", ) - return prepared_funnel_query + return prepared_funnels_query def _get_variants_with_base_stats( self, funnels_result: FunnelsQueryResponse diff --git a/posthog/hogql_queries/experiments/experiment_trends_query_runner.py b/posthog/hogql_queries/experiments/experiment_trends_query_runner.py index 7389b65a29bf6..2a74202b45f11 100644 --- a/posthog/hogql_queries/experiments/experiment_trends_query_runner.py +++ b/posthog/hogql_queries/experiments/experiment_trends_query_runner.py @@ -106,12 +106,11 @@ def _prepare_count_query(self) -> TrendsQuery: # :TRICKY: for `avg` aggregation, use `sum` data as an approximation if prepared_count_query.series[0].math == PropertyMathType.AVG: prepared_count_query.series[0].math = PropertyMathType.SUM - prepared_count_query.trendsFilter = TrendsFilter(display=ChartDisplayType.ACTIONS_LINE_GRAPH_CUMULATIVE) # TODO: revisit this; using the count data for the remaining aggregation types is likely wrong elif uses_math_aggregation: prepared_count_query.series[0].math = None - prepared_count_query.trendsFilter = TrendsFilter(display=ChartDisplayType.ACTIONS_LINE_GRAPH_CUMULATIVE) + prepared_count_query.trendsFilter = TrendsFilter(display=ChartDisplayType.ACTIONS_LINE_GRAPH_CUMULATIVE) prepared_count_query.dateRange = self._get_insight_date_range() prepared_count_query.breakdownFilter = self._get_breakdown_filter() prepared_count_query.properties = [ @@ -242,7 +241,6 @@ def run(query_runner: TrendsQueryRunner, result_key: str, is_parallel: bool): count_result = shared_results["count_result"] exposure_result = shared_results["exposure_result"] - if count_result is None or exposure_result is None: raise ValueError("One or both query runners failed to produce a response") @@ -255,7 +253,10 @@ def run(query_runner: TrendsQueryRunner, result_key: str, is_parallel: bool): credible_intervals = calculate_credible_intervals([control_variant, *test_variants]) return ExperimentTrendsQueryResponse( - insight=count_result, + kind="ExperimentTrendsQuery", + insight=count_result.results, + count_query=self.prepared_count_query, + exposure_query=self.prepared_exposure_query, variants=[variant.model_dump() for variant in [control_variant, *test_variants]], probability={ variant.key: probability diff --git a/posthog/hogql_queries/insights/trends/test/__snapshots__/test_trends.ambr b/posthog/hogql_queries/insights/trends/test/__snapshots__/test_trends.ambr index 6027f7ca7bb42..4ae57feb8cb96 100644 --- a/posthog/hogql_queries/insights/trends/test/__snapshots__/test_trends.ambr +++ b/posthog/hogql_queries/insights/trends/test/__snapshots__/test_trends.ambr @@ -851,14 +851,49 @@ # --- # name: TestTrends.test_dau_with_breakdown_filtering_with_sampling.1 ''' - /* celery:posthog.tasks.tasks.sync_insight_caching_state */ - SELECT team_id, - date_diff('second', max(timestamp), now()) AS age - FROM events - WHERE timestamp > date_sub(DAY, 3, now()) - AND timestamp < now() - GROUP BY team_id - ORDER BY age; + SELECT groupArray(1)(date)[1] AS date, + arrayFold((acc, x) -> arrayMap(i -> plus(acc[i], x[i]), range(1, plus(length(date), 1))), groupArray(ifNull(total, 0)), arrayWithConstant(length(date), reinterpretAsFloat64(0))) AS total, + if(ifNull(ifNull(greaterOrEquals(row_number, 25), 0), 0), '$$_posthog_breakdown_other_$$', breakdown_value) AS breakdown_value + FROM + (SELECT arrayMap(number -> plus(toStartOfDay(assumeNotNull(parseDateTime64BestEffortOrNull('2019-12-28 00:00:00', 6, 'UTC'))), toIntervalDay(number)), range(0, plus(coalesce(dateDiff('day', toStartOfDay(assumeNotNull(parseDateTime64BestEffortOrNull('2019-12-28 00:00:00', 6, 'UTC'))), toStartOfDay(assumeNotNull(parseDateTime64BestEffortOrNull('2020-01-04 23:59:59', 6, 'UTC'))))), 1))) AS date, + arrayMap(_match_date -> arraySum(arraySlice(groupArray(ifNull(count, 0)), indexOf(groupArray(day_start) AS _days_for_count, _match_date) AS _index, plus(minus(arrayLastIndex(x -> ifNull(equals(x, _match_date), isNull(x) + and isNull(_match_date)), _days_for_count), _index), 1))), date) AS total, + breakdown_value AS breakdown_value, + rowNumberInAllBlocks() AS row_number + FROM + (SELECT sum(total) AS count, + day_start AS day_start, + breakdown_value AS breakdown_value + FROM + (SELECT count(DISTINCT if(not(empty(e__override.distinct_id)), e__override.person_id, e.person_id)) AS total, + toStartOfDay(toTimeZone(e.timestamp, 'UTC')) AS day_start, + ifNull(nullIf(toString(replaceRegexpAll(nullIf(nullIf(JSONExtractRaw(e.properties, '$some_property'), ''), 'null'), '^"|"$', '')), ''), '$$_posthog_breakdown_null_$$') AS breakdown_value + FROM events AS e SAMPLE 1.0 + LEFT OUTER JOIN + (SELECT argMax(person_distinct_id_overrides.person_id, person_distinct_id_overrides.version) AS person_id, + person_distinct_id_overrides.distinct_id AS distinct_id + FROM person_distinct_id_overrides + WHERE equals(person_distinct_id_overrides.team_id, 2) + GROUP BY person_distinct_id_overrides.distinct_id + HAVING ifNull(equals(argMax(person_distinct_id_overrides.is_deleted, person_distinct_id_overrides.version), 0), 0) SETTINGS optimize_aggregation_in_order=1) AS e__override ON equals(e.distinct_id, e__override.distinct_id) + WHERE and(equals(e.team_id, 2), greaterOrEquals(toTimeZone(e.timestamp, 'UTC'), toStartOfDay(assumeNotNull(parseDateTime64BestEffortOrNull('2019-12-28 00:00:00', 6, 'UTC')))), lessOrEquals(toTimeZone(e.timestamp, 'UTC'), assumeNotNull(parseDateTime64BestEffortOrNull('2020-01-04 23:59:59', 6, 'UTC'))), equals(e.event, 'sign up')) + GROUP BY day_start, + breakdown_value) + GROUP BY day_start, + breakdown_value + ORDER BY day_start ASC, breakdown_value ASC) + GROUP BY breakdown_value + ORDER BY if(ifNull(equals(breakdown_value, '$$_posthog_breakdown_other_$$'), 0), 2, if(ifNull(equals(breakdown_value, '$$_posthog_breakdown_null_$$'), 0), 1, 0)) ASC, arraySum(total) DESC, breakdown_value ASC) + WHERE isNotNull(breakdown_value) + GROUP BY breakdown_value + ORDER BY if(ifNull(equals(breakdown_value, '$$_posthog_breakdown_other_$$'), 0), 2, if(ifNull(equals(breakdown_value, '$$_posthog_breakdown_null_$$'), 0), 1, 0)) ASC, arraySum(total) DESC, breakdown_value ASC + LIMIT 50000 SETTINGS readonly=2, + max_execution_time=60, + allow_experimental_object_type=1, + format_csv_allow_double_quotes=0, + max_ast_elements=4000000, + max_expanded_ast_elements=4000000, + max_bytes_before_external_group_by=0 ''' # --- # name: TestTrends.test_dau_with_breakdown_filtering_with_sampling.10 @@ -1075,38 +1110,143 @@ # --- # name: TestTrends.test_dau_with_breakdown_filtering_with_sampling.2 ''' - /* celery:posthog.tasks.tasks.sync_insight_caching_state */ - SELECT team_id, - date_diff('second', max(timestamp), now()) AS age - FROM events - WHERE timestamp > date_sub(DAY, 3, now()) - AND timestamp < now() - GROUP BY team_id - ORDER BY age; + SELECT groupArray(1)(date)[1] AS date, + arrayFold((acc, x) -> arrayMap(i -> plus(acc[i], x[i]), range(1, plus(length(date), 1))), groupArray(ifNull(total, 0)), arrayWithConstant(length(date), reinterpretAsFloat64(0))) AS total, + if(ifNull(ifNull(greaterOrEquals(row_number, 25), 0), 0), '$$_posthog_breakdown_other_$$', breakdown_value) AS breakdown_value + FROM + (SELECT arrayMap(number -> plus(toStartOfDay(assumeNotNull(parseDateTime64BestEffortOrNull('2019-12-28 00:00:00', 6, 'UTC'))), toIntervalDay(number)), range(0, plus(coalesce(dateDiff('day', toStartOfDay(assumeNotNull(parseDateTime64BestEffortOrNull('2019-12-28 00:00:00', 6, 'UTC'))), toStartOfDay(assumeNotNull(parseDateTime64BestEffortOrNull('2020-01-04 23:59:59', 6, 'UTC'))))), 1))) AS date, + arrayMap(_match_date -> arraySum(arraySlice(groupArray(ifNull(count, 0)), indexOf(groupArray(day_start) AS _days_for_count, _match_date) AS _index, plus(minus(arrayLastIndex(x -> ifNull(equals(x, _match_date), isNull(x) + and isNull(_match_date)), _days_for_count), _index), 1))), date) AS total, + breakdown_value AS breakdown_value, + rowNumberInAllBlocks() AS row_number + FROM + (SELECT sum(total) AS count, + day_start AS day_start, + breakdown_value AS breakdown_value + FROM + (SELECT count(DISTINCT if(not(empty(e__override.distinct_id)), e__override.person_id, e.person_id)) AS total, + toStartOfDay(toTimeZone(e.timestamp, 'UTC')) AS day_start, + ifNull(nullIf(toString(replaceRegexpAll(nullIf(nullIf(JSONExtractRaw(e.properties, '$some_property'), ''), 'null'), '^"|"$', '')), ''), '$$_posthog_breakdown_null_$$') AS breakdown_value + FROM events AS e SAMPLE 1.0 + LEFT OUTER JOIN + (SELECT argMax(person_distinct_id_overrides.person_id, person_distinct_id_overrides.version) AS person_id, + person_distinct_id_overrides.distinct_id AS distinct_id + FROM person_distinct_id_overrides + WHERE equals(person_distinct_id_overrides.team_id, 2) + GROUP BY person_distinct_id_overrides.distinct_id + HAVING ifNull(equals(argMax(person_distinct_id_overrides.is_deleted, person_distinct_id_overrides.version), 0), 0) SETTINGS optimize_aggregation_in_order=1) AS e__override ON equals(e.distinct_id, e__override.distinct_id) + WHERE and(equals(e.team_id, 2), greaterOrEquals(toTimeZone(e.timestamp, 'UTC'), toStartOfDay(assumeNotNull(parseDateTime64BestEffortOrNull('2019-12-28 00:00:00', 6, 'UTC')))), lessOrEquals(toTimeZone(e.timestamp, 'UTC'), assumeNotNull(parseDateTime64BestEffortOrNull('2020-01-04 23:59:59', 6, 'UTC'))), equals(e.event, 'sign up')) + GROUP BY day_start, + breakdown_value) + GROUP BY day_start, + breakdown_value + ORDER BY day_start ASC, breakdown_value ASC) + GROUP BY breakdown_value + ORDER BY if(ifNull(equals(breakdown_value, '$$_posthog_breakdown_other_$$'), 0), 2, if(ifNull(equals(breakdown_value, '$$_posthog_breakdown_null_$$'), 0), 1, 0)) ASC, arraySum(total) DESC, breakdown_value ASC) + WHERE isNotNull(breakdown_value) + GROUP BY breakdown_value + ORDER BY if(ifNull(equals(breakdown_value, '$$_posthog_breakdown_other_$$'), 0), 2, if(ifNull(equals(breakdown_value, '$$_posthog_breakdown_null_$$'), 0), 1, 0)) ASC, arraySum(total) DESC, breakdown_value ASC + LIMIT 50000 SETTINGS readonly=2, + max_execution_time=60, + allow_experimental_object_type=1, + format_csv_allow_double_quotes=0, + max_ast_elements=4000000, + max_expanded_ast_elements=4000000, + max_bytes_before_external_group_by=0 ''' # --- # name: TestTrends.test_dau_with_breakdown_filtering_with_sampling.3 ''' - /* celery:posthog.tasks.tasks.sync_insight_caching_state */ - SELECT team_id, - date_diff('second', max(timestamp), now()) AS age - FROM events - WHERE timestamp > date_sub(DAY, 3, now()) - AND timestamp < now() - GROUP BY team_id - ORDER BY age; + SELECT groupArray(1)(date)[1] AS date, + arrayFold((acc, x) -> arrayMap(i -> plus(acc[i], x[i]), range(1, plus(length(date), 1))), groupArray(ifNull(total, 0)), arrayWithConstant(length(date), reinterpretAsFloat64(0))) AS total, + arrayMap(i -> if(ifNull(ifNull(greaterOrEquals(row_number, 25), 0), 0), '$$_posthog_breakdown_other_$$', i), breakdown_value) AS breakdown_value + FROM + (SELECT arrayMap(number -> plus(toStartOfDay(assumeNotNull(parseDateTime64BestEffortOrNull('2019-12-28 00:00:00', 6, 'UTC'))), toIntervalDay(number)), range(0, plus(coalesce(dateDiff('day', toStartOfDay(assumeNotNull(parseDateTime64BestEffortOrNull('2019-12-28 00:00:00', 6, 'UTC'))), toStartOfDay(assumeNotNull(parseDateTime64BestEffortOrNull('2020-01-04 23:59:59', 6, 'UTC'))))), 1))) AS date, + arrayMap(_match_date -> arraySum(arraySlice(groupArray(ifNull(count, 0)), indexOf(groupArray(day_start) AS _days_for_count, _match_date) AS _index, plus(minus(arrayLastIndex(x -> ifNull(equals(x, _match_date), isNull(x) + and isNull(_match_date)), _days_for_count), _index), 1))), date) AS total, + breakdown_value AS breakdown_value, + rowNumberInAllBlocks() AS row_number + FROM + (SELECT sum(total) AS count, + day_start AS day_start, + [ifNull(toString(breakdown_value_1), '$$_posthog_breakdown_null_$$')] AS breakdown_value + FROM + (SELECT count(DISTINCT if(not(empty(e__override.distinct_id)), e__override.person_id, e.person_id)) AS total, + toStartOfDay(toTimeZone(e.timestamp, 'UTC')) AS day_start, + ifNull(nullIf(toString(replaceRegexpAll(nullIf(nullIf(JSONExtractRaw(e.properties, '$some_property'), ''), 'null'), '^"|"$', '')), ''), '$$_posthog_breakdown_null_$$') AS breakdown_value_1 + FROM events AS e SAMPLE 1.0 + LEFT OUTER JOIN + (SELECT argMax(person_distinct_id_overrides.person_id, person_distinct_id_overrides.version) AS person_id, + person_distinct_id_overrides.distinct_id AS distinct_id + FROM person_distinct_id_overrides + WHERE equals(person_distinct_id_overrides.team_id, 2) + GROUP BY person_distinct_id_overrides.distinct_id + HAVING ifNull(equals(argMax(person_distinct_id_overrides.is_deleted, person_distinct_id_overrides.version), 0), 0) SETTINGS optimize_aggregation_in_order=1) AS e__override ON equals(e.distinct_id, e__override.distinct_id) + WHERE and(equals(e.team_id, 2), greaterOrEquals(toTimeZone(e.timestamp, 'UTC'), toStartOfDay(assumeNotNull(parseDateTime64BestEffortOrNull('2019-12-28 00:00:00', 6, 'UTC')))), lessOrEquals(toTimeZone(e.timestamp, 'UTC'), assumeNotNull(parseDateTime64BestEffortOrNull('2020-01-04 23:59:59', 6, 'UTC'))), equals(e.event, 'sign up')) + GROUP BY day_start, + breakdown_value_1) + GROUP BY day_start, + breakdown_value_1 + ORDER BY day_start ASC, breakdown_value ASC) + GROUP BY breakdown_value + ORDER BY if(has(breakdown_value, '$$_posthog_breakdown_other_$$'), 2, if(has(breakdown_value, '$$_posthog_breakdown_null_$$'), 1, 0)) ASC, arraySum(total) DESC, breakdown_value ASC) + WHERE arrayExists(x -> isNotNull(x), breakdown_value) + GROUP BY breakdown_value + ORDER BY if(has(breakdown_value, '$$_posthog_breakdown_other_$$'), 2, if(has(breakdown_value, '$$_posthog_breakdown_null_$$'), 1, 0)) ASC, arraySum(total) DESC, breakdown_value ASC + LIMIT 50000 SETTINGS readonly=2, + max_execution_time=60, + allow_experimental_object_type=1, + format_csv_allow_double_quotes=0, + max_ast_elements=4000000, + max_expanded_ast_elements=4000000, + max_bytes_before_external_group_by=0 ''' # --- # name: TestTrends.test_dau_with_breakdown_filtering_with_sampling.4 ''' - /* celery:posthog.tasks.tasks.sync_insight_caching_state */ - SELECT team_id, - date_diff('second', max(timestamp), now()) AS age - FROM events - WHERE timestamp > date_sub(DAY, 3, now()) - AND timestamp < now() - GROUP BY team_id - ORDER BY age; + SELECT groupArray(1)(date)[1] AS date, + arrayFold((acc, x) -> arrayMap(i -> plus(acc[i], x[i]), range(1, plus(length(date), 1))), groupArray(ifNull(total, 0)), arrayWithConstant(length(date), reinterpretAsFloat64(0))) AS total, + arrayMap(i -> if(ifNull(ifNull(greaterOrEquals(row_number, 25), 0), 0), '$$_posthog_breakdown_other_$$', i), breakdown_value) AS breakdown_value + FROM + (SELECT arrayMap(number -> plus(toStartOfDay(assumeNotNull(parseDateTime64BestEffortOrNull('2019-12-28 00:00:00', 6, 'UTC'))), toIntervalDay(number)), range(0, plus(coalesce(dateDiff('day', toStartOfDay(assumeNotNull(parseDateTime64BestEffortOrNull('2019-12-28 00:00:00', 6, 'UTC'))), toStartOfDay(assumeNotNull(parseDateTime64BestEffortOrNull('2020-01-04 23:59:59', 6, 'UTC'))))), 1))) AS date, + arrayMap(_match_date -> arraySum(arraySlice(groupArray(ifNull(count, 0)), indexOf(groupArray(day_start) AS _days_for_count, _match_date) AS _index, plus(minus(arrayLastIndex(x -> ifNull(equals(x, _match_date), isNull(x) + and isNull(_match_date)), _days_for_count), _index), 1))), date) AS total, + breakdown_value AS breakdown_value, + rowNumberInAllBlocks() AS row_number + FROM + (SELECT sum(total) AS count, + day_start AS day_start, + [ifNull(toString(breakdown_value_1), '$$_posthog_breakdown_null_$$')] AS breakdown_value + FROM + (SELECT count(DISTINCT if(not(empty(e__override.distinct_id)), e__override.person_id, e.person_id)) AS total, + toStartOfDay(toTimeZone(e.timestamp, 'UTC')) AS day_start, + ifNull(nullIf(toString(replaceRegexpAll(nullIf(nullIf(JSONExtractRaw(e.properties, '$some_property'), ''), 'null'), '^"|"$', '')), ''), '$$_posthog_breakdown_null_$$') AS breakdown_value_1 + FROM events AS e SAMPLE 1.0 + LEFT OUTER JOIN + (SELECT argMax(person_distinct_id_overrides.person_id, person_distinct_id_overrides.version) AS person_id, + person_distinct_id_overrides.distinct_id AS distinct_id + FROM person_distinct_id_overrides + WHERE equals(person_distinct_id_overrides.team_id, 2) + GROUP BY person_distinct_id_overrides.distinct_id + HAVING ifNull(equals(argMax(person_distinct_id_overrides.is_deleted, person_distinct_id_overrides.version), 0), 0) SETTINGS optimize_aggregation_in_order=1) AS e__override ON equals(e.distinct_id, e__override.distinct_id) + WHERE and(equals(e.team_id, 2), greaterOrEquals(toTimeZone(e.timestamp, 'UTC'), toStartOfDay(assumeNotNull(parseDateTime64BestEffortOrNull('2019-12-28 00:00:00', 6, 'UTC')))), lessOrEquals(toTimeZone(e.timestamp, 'UTC'), assumeNotNull(parseDateTime64BestEffortOrNull('2020-01-04 23:59:59', 6, 'UTC'))), equals(e.event, 'sign up')) + GROUP BY day_start, + breakdown_value_1) + GROUP BY day_start, + breakdown_value_1 + ORDER BY day_start ASC, breakdown_value ASC) + GROUP BY breakdown_value + ORDER BY if(has(breakdown_value, '$$_posthog_breakdown_other_$$'), 2, if(has(breakdown_value, '$$_posthog_breakdown_null_$$'), 1, 0)) ASC, arraySum(total) DESC, breakdown_value ASC) + WHERE arrayExists(x -> isNotNull(x), breakdown_value) + GROUP BY breakdown_value + ORDER BY if(has(breakdown_value, '$$_posthog_breakdown_other_$$'), 2, if(has(breakdown_value, '$$_posthog_breakdown_null_$$'), 1, 0)) ASC, arraySum(total) DESC, breakdown_value ASC + LIMIT 50000 SETTINGS readonly=2, + max_execution_time=60, + allow_experimental_object_type=1, + format_csv_allow_double_quotes=0, + max_ast_elements=4000000, + max_expanded_ast_elements=4000000, + max_bytes_before_external_group_by=0 ''' # --- # name: TestTrends.test_dau_with_breakdown_filtering_with_sampling.5 diff --git a/posthog/schema.py b/posthog/schema.py index b386d5d6c8e97..199a19f1fdfe3 100644 --- a/posthog/schema.py +++ b/posthog/schema.py @@ -1951,31 +1951,6 @@ class CachedEventsQueryResponse(BaseModel): types: list[str] -class CachedExperimentTrendsQueryResponse(BaseModel): - model_config = ConfigDict( - extra="forbid", - ) - cache_key: str - cache_target_age: Optional[AwareDatetime] = None - calculation_trigger: Optional[str] = Field( - default=None, description="What triggered the calculation of the query, leave empty if user/immediate" - ) - credible_intervals: dict[str, list[float]] - insight: TrendsQueryResponse - is_cached: bool - last_refresh: AwareDatetime - next_allowed_client_refresh: AwareDatetime - p_value: float - probability: dict[str, float] - query_status: Optional[QueryStatus] = Field( - default=None, description="Query status indicates whether next to the provided data, a query is still running." - ) - significance_code: ExperimentSignificanceCode - significant: bool - timezone: str - variants: list[ExperimentVariantTrendsBaseStats] - - class CachedFunnelCorrelationResponse(BaseModel): model_config = ConfigDict( extra="forbid", @@ -2700,19 +2675,6 @@ class Response9(BaseModel): ) -class Response11(BaseModel): - model_config = ConfigDict( - extra="forbid", - ) - credible_intervals: dict[str, list[float]] - insight: TrendsQueryResponse - p_value: float - probability: dict[str, float] - significance_code: ExperimentSignificanceCode - significant: bool - variants: list[ExperimentVariantTrendsBaseStats] - - class DataWarehousePersonPropertyFilter(BaseModel): model_config = ConfigDict( extra="forbid", @@ -2863,19 +2825,6 @@ class EventsQueryResponse(BaseModel): types: list[str] -class ExperimentTrendsQueryResponse(BaseModel): - model_config = ConfigDict( - extra="forbid", - ) - credible_intervals: dict[str, list[float]] - insight: TrendsQueryResponse - p_value: float - probability: dict[str, float] - significance_code: ExperimentSignificanceCode - significant: bool - variants: list[ExperimentVariantTrendsBaseStats] - - class BreakdownFilter1(BaseModel): model_config = ConfigDict( extra="forbid", @@ -3466,32 +3415,6 @@ class QueryResponseAlternative15(BaseModel): ) -class QueryResponseAlternative16(BaseModel): - model_config = ConfigDict( - extra="forbid", - ) - credible_intervals: dict[str, list[float]] - expected_loss: float - insight: FunnelsQueryResponse - probability: dict[str, float] - significance_code: ExperimentSignificanceCode - significant: bool - variants: list[ExperimentVariantFunnelsBaseStats] - - -class QueryResponseAlternative17(BaseModel): - model_config = ConfigDict( - extra="forbid", - ) - credible_intervals: dict[str, list[float]] - insight: TrendsQueryResponse - p_value: float - probability: dict[str, float] - significance_code: ExperimentSignificanceCode - significant: bool - variants: list[ExperimentVariantTrendsBaseStats] - - class QueryResponseAlternative18(BaseModel): model_config = ConfigDict( extra="forbid", @@ -3728,32 +3651,6 @@ class QueryResponseAlternative27(BaseModel): ) -class QueryResponseAlternative28(BaseModel): - model_config = ConfigDict( - extra="forbid", - ) - credible_intervals: dict[str, list[float]] - expected_loss: float - insight: FunnelsQueryResponse - probability: dict[str, float] - significance_code: ExperimentSignificanceCode - significant: bool - variants: list[ExperimentVariantFunnelsBaseStats] - - -class QueryResponseAlternative29(BaseModel): - model_config = ConfigDict( - extra="forbid", - ) - credible_intervals: dict[str, list[float]] - insight: TrendsQueryResponse - p_value: float - probability: dict[str, float] - significance_code: ExperimentSignificanceCode - significant: bool - variants: list[ExperimentVariantTrendsBaseStats] - - class QueryResponseAlternative30(BaseModel): model_config = ConfigDict( extra="forbid", @@ -4256,31 +4153,6 @@ class AnyResponseType( ] -class CachedExperimentFunnelsQueryResponse(BaseModel): - model_config = ConfigDict( - extra="forbid", - ) - cache_key: str - cache_target_age: Optional[AwareDatetime] = None - calculation_trigger: Optional[str] = Field( - default=None, description="What triggered the calculation of the query, leave empty if user/immediate" - ) - credible_intervals: dict[str, list[float]] - expected_loss: float - insight: FunnelsQueryResponse - is_cached: bool - last_refresh: AwareDatetime - next_allowed_client_refresh: AwareDatetime - probability: dict[str, float] - query_status: Optional[QueryStatus] = Field( - default=None, description="Query status indicates whether next to the provided data, a query is still running." - ) - significance_code: ExperimentSignificanceCode - significant: bool - timezone: str - variants: list[ExperimentVariantFunnelsBaseStats] - - class CachedHogQLQueryResponse(BaseModel): model_config = ConfigDict( extra="forbid", @@ -4432,19 +4304,6 @@ class Response2(BaseModel): types: Optional[list] = Field(default=None, description="Types of returned columns") -class Response10(BaseModel): - model_config = ConfigDict( - extra="forbid", - ) - credible_intervals: dict[str, list[float]] - expected_loss: float - insight: FunnelsQueryResponse - probability: dict[str, float] - significance_code: ExperimentSignificanceCode - significant: bool - variants: list[ExperimentVariantFunnelsBaseStats] - - class DataWarehouseNode(BaseModel): model_config = ConfigDict( extra="forbid", @@ -4684,19 +4543,6 @@ class EventsNode(BaseModel): response: Optional[dict[str, Any]] = None -class ExperimentFunnelsQueryResponse(BaseModel): - model_config = ConfigDict( - extra="forbid", - ) - credible_intervals: dict[str, list[float]] - expected_loss: float - insight: FunnelsQueryResponse - probability: dict[str, float] - significance_code: ExperimentSignificanceCode - significant: bool - variants: list[ExperimentVariantFunnelsBaseStats] - - class FunnelExclusionActionsNode(BaseModel): model_config = ConfigDict( extra="forbid", @@ -5530,6 +5376,50 @@ class VisualizationMessage(BaseModel): type: Literal["ai/viz"] = "ai/viz" +class CachedExperimentTrendsQueryResponse(BaseModel): + model_config = ConfigDict( + extra="forbid", + ) + cache_key: str + cache_target_age: Optional[AwareDatetime] = None + calculation_trigger: Optional[str] = Field( + default=None, description="What triggered the calculation of the query, leave empty if user/immediate" + ) + count_query: Optional[TrendsQuery] = None + credible_intervals: dict[str, list[float]] + exposure_query: Optional[TrendsQuery] = None + insight: list[dict[str, Any]] + is_cached: bool + kind: Literal["ExperimentTrendsQuery"] = "ExperimentTrendsQuery" + last_refresh: AwareDatetime + next_allowed_client_refresh: AwareDatetime + p_value: float + probability: dict[str, float] + query_status: Optional[QueryStatus] = Field( + default=None, description="Query status indicates whether next to the provided data, a query is still running." + ) + significance_code: ExperimentSignificanceCode + significant: bool + timezone: str + variants: list[ExperimentVariantTrendsBaseStats] + + +class Response11(BaseModel): + model_config = ConfigDict( + extra="forbid", + ) + count_query: Optional[TrendsQuery] = None + credible_intervals: dict[str, list[float]] + exposure_query: Optional[TrendsQuery] = None + insight: list[dict[str, Any]] + kind: Literal["ExperimentTrendsQuery"] = "ExperimentTrendsQuery" + p_value: float + probability: dict[str, float] + significance_code: ExperimentSignificanceCode + significant: bool + variants: list[ExperimentVariantTrendsBaseStats] + + class ErrorTrackingQuery(BaseModel): model_config = ConfigDict( extra="forbid", @@ -5617,18 +5507,20 @@ class EventsQuery(BaseModel): where: Optional[list[str]] = Field(default=None, description="HogQL filters to apply on returned data") -class ExperimentTrendsQuery(BaseModel): +class ExperimentTrendsQueryResponse(BaseModel): model_config = ConfigDict( extra="forbid", ) - count_query: TrendsQuery - experiment_id: int + count_query: Optional[TrendsQuery] = None + credible_intervals: dict[str, list[float]] exposure_query: Optional[TrendsQuery] = None + insight: list[dict[str, Any]] kind: Literal["ExperimentTrendsQuery"] = "ExperimentTrendsQuery" - modifiers: Optional[HogQLQueryModifiers] = Field( - default=None, description="Modifiers used when performing the query" - ) - response: Optional[ExperimentTrendsQueryResponse] = None + p_value: float + probability: dict[str, float] + significance_code: ExperimentSignificanceCode + significant: bool + variants: list[ExperimentVariantTrendsBaseStats] class FunnelsQuery(BaseModel): @@ -5928,6 +5820,68 @@ class LifecycleQuery(BaseModel): ) +class QueryResponseAlternative16(BaseModel): + model_config = ConfigDict( + extra="forbid", + ) + credible_intervals: dict[str, list[float]] + expected_loss: float + funnels_query: Optional[FunnelsQuery] = None + insight: list[list[dict[str, Any]]] + kind: Literal["ExperimentFunnelsQuery"] = "ExperimentFunnelsQuery" + probability: dict[str, float] + significance_code: ExperimentSignificanceCode + significant: bool + variants: list[ExperimentVariantFunnelsBaseStats] + + +class QueryResponseAlternative17(BaseModel): + model_config = ConfigDict( + extra="forbid", + ) + count_query: Optional[TrendsQuery] = None + credible_intervals: dict[str, list[float]] + exposure_query: Optional[TrendsQuery] = None + insight: list[dict[str, Any]] + kind: Literal["ExperimentTrendsQuery"] = "ExperimentTrendsQuery" + p_value: float + probability: dict[str, float] + significance_code: ExperimentSignificanceCode + significant: bool + variants: list[ExperimentVariantTrendsBaseStats] + + +class QueryResponseAlternative28(BaseModel): + model_config = ConfigDict( + extra="forbid", + ) + credible_intervals: dict[str, list[float]] + expected_loss: float + funnels_query: Optional[FunnelsQuery] = None + insight: list[list[dict[str, Any]]] + kind: Literal["ExperimentFunnelsQuery"] = "ExperimentFunnelsQuery" + probability: dict[str, float] + significance_code: ExperimentSignificanceCode + significant: bool + variants: list[ExperimentVariantFunnelsBaseStats] + + +class QueryResponseAlternative29(BaseModel): + model_config = ConfigDict( + extra="forbid", + ) + count_query: Optional[TrendsQuery] = None + credible_intervals: dict[str, list[float]] + exposure_query: Optional[TrendsQuery] = None + insight: list[dict[str, Any]] + kind: Literal["ExperimentTrendsQuery"] = "ExperimentTrendsQuery" + p_value: float + probability: dict[str, float] + significance_code: ExperimentSignificanceCode + significant: bool + variants: list[ExperimentVariantTrendsBaseStats] + + class QueryResponseAlternative37(BaseModel): model_config = ConfigDict( extra="forbid", @@ -6036,6 +5990,48 @@ class RootAssistantMessage(RootModel[Union[VisualizationMessage, AssistantMessag root: Union[VisualizationMessage, AssistantMessage, HumanMessage] +class CachedExperimentFunnelsQueryResponse(BaseModel): + model_config = ConfigDict( + extra="forbid", + ) + cache_key: str + cache_target_age: Optional[AwareDatetime] = None + calculation_trigger: Optional[str] = Field( + default=None, description="What triggered the calculation of the query, leave empty if user/immediate" + ) + credible_intervals: dict[str, list[float]] + expected_loss: float + funnels_query: Optional[FunnelsQuery] = None + insight: list[list[dict[str, Any]]] + is_cached: bool + kind: Literal["ExperimentFunnelsQuery"] = "ExperimentFunnelsQuery" + last_refresh: AwareDatetime + next_allowed_client_refresh: AwareDatetime + probability: dict[str, float] + query_status: Optional[QueryStatus] = Field( + default=None, description="Query status indicates whether next to the provided data, a query is still running." + ) + significance_code: ExperimentSignificanceCode + significant: bool + timezone: str + variants: list[ExperimentVariantFunnelsBaseStats] + + +class Response10(BaseModel): + model_config = ConfigDict( + extra="forbid", + ) + credible_intervals: dict[str, list[float]] + expected_loss: float + funnels_query: Optional[FunnelsQuery] = None + insight: list[list[dict[str, Any]]] + kind: Literal["ExperimentFunnelsQuery"] = "ExperimentFunnelsQuery" + probability: dict[str, float] + significance_code: ExperimentSignificanceCode + significant: bool + variants: list[ExperimentVariantFunnelsBaseStats] + + class DatabaseSchemaQueryResponse(BaseModel): model_config = ConfigDict( extra="forbid", @@ -6052,17 +6048,33 @@ class DatabaseSchemaQueryResponse(BaseModel): ] -class ExperimentFunnelsQuery(BaseModel): +class ExperimentFunnelsQueryResponse(BaseModel): model_config = ConfigDict( extra="forbid", ) - experiment_id: int + credible_intervals: dict[str, list[float]] + expected_loss: float + funnels_query: Optional[FunnelsQuery] = None + insight: list[list[dict[str, Any]]] kind: Literal["ExperimentFunnelsQuery"] = "ExperimentFunnelsQuery" + probability: dict[str, float] + significance_code: ExperimentSignificanceCode + significant: bool + variants: list[ExperimentVariantFunnelsBaseStats] + + +class ExperimentTrendsQuery(BaseModel): + model_config = ConfigDict( + extra="forbid", + ) + count_query: TrendsQuery + experiment_id: int + exposure_query: Optional[TrendsQuery] = None + kind: Literal["ExperimentTrendsQuery"] = "ExperimentTrendsQuery" modifiers: Optional[HogQLQueryModifiers] = Field( default=None, description="Modifiers used when performing the query" ) - response: Optional[ExperimentFunnelsQueryResponse] = None - source: FunnelsQuery + response: Optional[ExperimentTrendsQueryResponse] = None class FunnelPathsFilter(BaseModel): @@ -6166,6 +6178,19 @@ class DatabaseSchemaQuery(BaseModel): response: Optional[DatabaseSchemaQueryResponse] = None +class ExperimentFunnelsQuery(BaseModel): + model_config = ConfigDict( + extra="forbid", + ) + experiment_id: int + kind: Literal["ExperimentFunnelsQuery"] = "ExperimentFunnelsQuery" + modifiers: Optional[HogQLQueryModifiers] = Field( + default=None, description="Modifiers used when performing the query" + ) + response: Optional[ExperimentFunnelsQueryResponse] = None + source: FunnelsQuery + + class FunnelCorrelationQuery(BaseModel): model_config = ConfigDict( extra="forbid", From 3ed93f7201ae93e748d156b6f0c65dcb9261bcc6 Mon Sep 17 00:00:00 2001 From: David Newell Date: Wed, 30 Oct 2024 12:13:10 +0000 Subject: [PATCH 14/14] chore: add kafka producer to context (#25899) --- rust/cymbal/src/app_context.rs | 24 ++++++++++++++++++------ rust/cymbal/src/main.rs | 2 +- 2 files changed, 19 insertions(+), 7 deletions(-) diff --git a/rust/cymbal/src/app_context.rs b/rust/cymbal/src/app_context.rs index 5d7d130b89c9a..381c4de941f6b 100644 --- a/rust/cymbal/src/app_context.rs +++ b/rust/cymbal/src/app_context.rs @@ -1,8 +1,11 @@ -use std::time::Duration; - -use common_kafka::kafka_consumer::SingleTopicConsumer; +use common_kafka::{ + kafka_consumer::SingleTopicConsumer, kafka_producer::create_kafka_producer, + kafka_producer::KafkaContext, +}; use health::{HealthHandle, HealthRegistry}; +use rdkafka::producer::FutureProducer; use sqlx::{postgres::PgPoolOptions, PgPool}; +use std::time::Duration; use tracing::info; use crate::{ @@ -14,7 +17,8 @@ use crate::{ pub struct AppContext { pub health_registry: HealthRegistry, pub worker_liveness: HealthHandle, - pub consumer: SingleTopicConsumer, + pub kafka_consumer: SingleTopicConsumer, + pub kafka_producer: FutureProducer, pub pool: PgPool, pub catalog: Catalog, } @@ -25,8 +29,15 @@ impl AppContext { let worker_liveness = health_registry .register("worker".to_string(), Duration::from_secs(60)) .await; + let kafka_liveness = health_registry + .register("rdkafka".to_string(), Duration::from_secs(30)) + .await; - let consumer = SingleTopicConsumer::new(config.kafka.clone(), config.consumer.clone())?; + let kafka_consumer = + SingleTopicConsumer::new(config.kafka.clone(), config.consumer.clone())?; + let kafka_producer = create_kafka_producer(&config.kafka, kafka_liveness) + .await + .expect("failed to create kafka producer"); let options = PgPoolOptions::new().max_connections(config.max_pg_connections); let pool = options.connect(&config.database_url).await?; @@ -44,7 +55,8 @@ impl AppContext { Ok(Self { health_registry, worker_liveness, - consumer, + kafka_consumer, + kafka_producer, pool, catalog, }) diff --git a/rust/cymbal/src/main.rs b/rust/cymbal/src/main.rs index 29086defed700..9ea6c02b4a065 100644 --- a/rust/cymbal/src/main.rs +++ b/rust/cymbal/src/main.rs @@ -64,7 +64,7 @@ async fn main() -> Result<(), Error> { context.worker_liveness.report_healthy().await; // Just grab the event as a serde_json::Value and immediately drop it, // we can work out a real type for it later (once we're deployed etc) - let (event, offset): (ClickHouseEvent, _) = match context.consumer.json_recv().await { + let (event, offset): (ClickHouseEvent, _) = match context.kafka_consumer.json_recv().await { Ok(r) => r, Err(RecvErr::Kafka(e)) => { return Err(e.into()); // Just die if we recieve a Kafka error