From 18b03864b6437e9e15c43522b66c4eaeb3eab3cd Mon Sep 17 00:00:00 2001 From: OmarTawfik <15987992+OmarTawfik@users.noreply.github.com> Date: Sat, 2 Dec 2023 03:24:37 -0800 Subject: [PATCH] remove `FieldKind` from DSL v2 Makes the grammar a lot simpler, since it is no longer needed after enums were simplified in #610 --- .../src/compiler/analysis/definitions.rs | 6 +- .../src/compiler/analysis/references.rs | 182 +- .../language/definition/src/model/item.rs | 3 +- .../src/model/non_terminals/field.rs | 12 +- .../src/model/non_terminals/precedence.rs | 2 +- .../internal_macros/src/derive/spanned.rs | 1 - .../duplicate_expression_name/test.rs | 2 +- .../definitions/duplicate_item_name/test.rs | 6 +- .../duplicate_item_name/test.stderr | 2 +- .../fail/parsing/duplicate_map_key/test.rs | 6 +- .../parsing/duplicate_map_key/test.stderr | 2 +- .../fail/parsing/unrecognized_variant/test.rs | 4 +- .../src/fail/reachability/unreachable/test.rs | 8 +- .../fail/reachability/unreachable/test.stderr | 4 +- .../fail/reachability/unused_version/test.rs | 2 +- .../fail/references/disabled_too_late/test.rs | 7 +- .../references/disabled_too_late/test.stderr | 6 +- .../fail/references/enabled_too_early/test.rs | 7 +- .../references/enabled_too_early/test.stderr | 6 +- .../fail/references/invalid_filter/test.rs | 2 +- .../references/invalid_filter/test.stderr | 8 +- .../fail/references/invalid_version/test.rs | 8 +- .../references/invalid_version/test.stderr | 18 +- .../fail/references/unknown_reference/test.rs | 5 +- .../references/unknown_reference/test.stderr | 6 +- .../references/unordered_version_pair/test.rs | 4 +- .../fail/references/version_not_found/test.rs | 4 +- .../references/version_not_found/test.stderr | 6 +- .../language/tests/src/pass/tiny_language.rs | 22 +- .../inputs/language/src/definition.rs | 1106 +++--- .../solidity/inputs/language/src/grammar.rs | 41 +- .../cargo/crate/src/generated/language.rs | 3063 ++++++++++++----- .../npm/crate/src/generated/language.rs | 3063 ++++++++++++----- .../generated/0.4.11-failure.yml | 6 +- 34 files changed, 5270 insertions(+), 2360 deletions(-) diff --git a/crates/codegen/language/definition/src/compiler/analysis/definitions.rs b/crates/codegen/language/definition/src/compiler/analysis/definitions.rs index 038cd32749..effe9d3292 100644 --- a/crates/codegen/language/definition/src/compiler/analysis/definitions.rs +++ b/crates/codegen/language/definition/src/compiler/analysis/definitions.rs @@ -87,12 +87,12 @@ fn check_precedence_items(analysis: &mut Analysis) { } for primary_expression in &item.primary_expressions { - let expression = &primary_expression.expression; + let reference = &primary_expression.reference; - if !current_expressions.insert(expression) { + if !current_expressions.insert(reference) { analysis .errors - .add(expression, &Errors::ExistingExpression(expression)); + .add(reference, &Errors::ExistingExpression(reference)); } } } diff --git a/crates/codegen/language/definition/src/compiler/analysis/references.rs b/crates/codegen/language/definition/src/compiler/analysis/references.rs index 98adb32f9e..80cb0b190b 100644 --- a/crates/codegen/language/definition/src/compiler/analysis/references.rs +++ b/crates/codegen/language/definition/src/compiler/analysis/references.rs @@ -2,18 +2,19 @@ use crate::{ compiler::{analysis::Analysis, version_set::VersionSet}, internals::Spanned, model::{ - Identifier, SpannedEnumItem, SpannedEnumVariant, SpannedField, SpannedFieldKind, - SpannedFragmentItem, SpannedItem, SpannedKeywordDefinition, SpannedKeywordItem, - SpannedPrecedenceExpression, SpannedPrecedenceItem, SpannedPrecedenceOperator, - SpannedPrimaryExpression, SpannedRepeatedItem, SpannedScanner, SpannedSeparatedItem, - SpannedStructItem, SpannedTokenDefinition, SpannedTokenItem, SpannedTriviaItem, - SpannedTriviaParser, SpannedVersionSpecifier, + Identifier, SpannedEnumItem, SpannedEnumVariant, SpannedField, SpannedFragmentItem, + SpannedItem, + SpannedItemDiscriminants::{self, *}, + SpannedKeywordDefinition, SpannedKeywordItem, SpannedPrecedenceExpression, + SpannedPrecedenceItem, SpannedPrecedenceOperator, SpannedPrimaryExpression, + SpannedRepeatedItem, SpannedScanner, SpannedSeparatedItem, SpannedStructItem, + SpannedTokenDefinition, SpannedTokenItem, SpannedTriviaItem, SpannedTriviaParser, + SpannedVersionSpecifier, }, }; use indexmap::IndexMap; use semver::Version; use std::fmt::Debug; -use strum_macros::Display; pub(crate) fn analyze_references(analysis: &mut Analysis) { let language = analysis.language.clone(); @@ -26,7 +27,7 @@ pub(crate) fn analyze_references(analysis: &mut Analysis) { None, &language.root_item, &enablement, - ReferenceFilter::NonTerminals, + &[Struct, Enum, Repeated, Separated, Precedence], ); check_trivia_parser(analysis, &language.leading_trivia, &enablement); @@ -105,7 +106,9 @@ fn check_enum(analysis: &mut Analysis, item: &SpannedEnumItem, enablement: &Vers Some(name), reference, &enablement, - ReferenceFilter::Nodes, + &[ + Struct, Enum, Repeated, Separated, Precedence, Keyword, Token, + ], ); } } @@ -125,7 +128,9 @@ fn check_repeated(analysis: &mut Analysis, item: &SpannedRepeatedItem, enablemen Some(name), repeated, &enablement, - ReferenceFilter::Nodes, + &[ + Struct, Enum, Repeated, Separated, Precedence, Keyword, Token, + ], ); } @@ -145,15 +150,12 @@ fn check_separated(analysis: &mut Analysis, item: &SpannedSeparatedItem, enablem Some(name), separated, &enablement, - ReferenceFilter::Nodes, - ); - check_reference( - analysis, - Some(name), - separator, - &enablement, - ReferenceFilter::Tokens, + &[ + Struct, Enum, Repeated, Separated, Precedence, Keyword, Token, + ], ); + + check_reference(analysis, Some(name), separator, &enablement, &[Token]); } fn check_precedence( @@ -192,19 +194,18 @@ fn check_precedence( } for primary_expression in primary_expressions { - let SpannedPrimaryExpression { - expression, - enabled, - } = primary_expression; + let SpannedPrimaryExpression { reference, enabled } = primary_expression; let enablement = update_enablement(analysis, &enablement, enabled); check_reference( analysis, Some(name), - expression, + reference, &enablement, - ReferenceFilter::Nodes, + &[ + Struct, Enum, Repeated, Separated, Precedence, Keyword, Token, + ], ); } } @@ -217,46 +218,34 @@ fn check_fields( ) { for field in fields.values() { match field { - SpannedField::Required { kind } => { - check_field_kind(analysis, source, kind, enablement); + SpannedField::Required { reference } => { + check_reference( + analysis, + source, + reference, + enablement, + &[ + Struct, Enum, Repeated, Separated, Precedence, Keyword, Token, + ], + ); } - SpannedField::Optional { kind, enabled } => { + SpannedField::Optional { reference, enabled } => { let enablement = update_enablement(analysis, enablement, enabled); - check_field_kind(analysis, source, kind, &enablement); - } - }; - } -} - -fn check_field_kind( - analysis: &mut Analysis, - source: Option<&Identifier>, - kind: &SpannedFieldKind, - enablement: &VersionSet, -) { - match kind { - SpannedFieldKind::NonTerminal { item } => { - check_reference( - analysis, - source, - item, - enablement, - ReferenceFilter::NonTerminals, - ); - } - SpannedFieldKind::Terminal { items } => { - for item in items { check_reference( analysis, source, - item, - enablement, - ReferenceFilter::Terminals, + reference, + &enablement, + &[ + // TODO(#638): remove [Separated] and [Repeated] from here, once they are allowed to be empty. + // Therefore, we ensure we always produce the parent node, even if it has no children. + Struct, Enum, Repeated, Separated, Precedence, Keyword, Token, + ], ); } - } - }; + }; + } } fn check_trivia_parser( @@ -276,7 +265,7 @@ fn check_trivia_parser( check_trivia_parser(analysis, parser, enablement); } SpannedTriviaParser::Trivia { trivia } => { - check_reference(analysis, None, trivia, enablement, ReferenceFilter::Trivia); + check_reference(analysis, None, trivia, enablement, &[Trivia]); } }; } @@ -294,13 +283,7 @@ fn check_keyword(analysis: &mut Analysis, item: &SpannedKeywordItem, enablement: definitions, } = item; - check_reference( - analysis, - Some(name), - identifier, - enablement, - ReferenceFilter::Tokens, - ); + check_reference(analysis, Some(name), identifier, enablement, &[Token]); for definition in definitions { let SpannedKeywordDefinition { @@ -374,71 +357,17 @@ fn check_scanner( check_scanner(analysis, source, not_followed_by, enablement); } SpannedScanner::Fragment { reference } => { - check_reference( - analysis, - source, - reference, - enablement, - ReferenceFilter::Fragments, - ); + check_reference(analysis, source, reference, enablement, &[Fragment]); } }; } -/// Used by different checks above to make sure that references to other items are valid. -/// For example, struct fields can reference anything, but tokens can only reference fragments. -#[derive(Debug, Display, PartialEq, Eq)] -enum ReferenceFilter { - Nodes, - - NonTerminals, - Terminals, - - Trivia, - Tokens, - - Fragments, -} - -impl ReferenceFilter { - fn apply(&self, item: &SpannedItem) -> bool { - match (self, item) { - (Self::Nodes, item) => { - return Self::NonTerminals.apply(item) || Self::Terminals.apply(item); - } - ( - Self::NonTerminals, - SpannedItem::Struct { .. } - | SpannedItem::Enum { .. } - | SpannedItem::Repeated { .. } - | SpannedItem::Separated { .. } - | SpannedItem::Precedence { .. }, - ) - | ( - Self::Terminals, - SpannedItem::Trivia { .. } - | SpannedItem::Keyword { .. } - | SpannedItem::Token { .. }, - ) - | (Self::Trivia, SpannedItem::Trivia { .. }) - | (Self::Tokens, SpannedItem::Token { .. }) - | (Self::Fragments, SpannedItem::Fragment { .. }) => { - return true; - } - - _ => { - return false; - } - }; - } -} - fn check_reference( analysis: &mut Analysis, source: Option<&Identifier>, reference: &Spanned, enablement: &VersionSet, - filter: ReferenceFilter, + expected_kinds: &[SpannedItemDiscriminants], ) { let target = match analysis.metadata.get_mut(&**reference) { Some(target) => target, @@ -458,10 +387,11 @@ fn check_reference( ); } - if !filter.apply(&target.item) { + let actual_kind: SpannedItemDiscriminants = target.item.as_ref().into(); + if !expected_kinds.contains(&actual_kind) { analysis.errors.add( reference, - &Errors::InvalidReferenceFilter(reference, &filter), + &Errors::InvalidReferenceFilter(reference, &actual_kind, expected_kinds), ); } @@ -550,6 +480,10 @@ enum Errors<'err> { UnknownReference(&'err Identifier), #[error("Reference '{0}' is only defined in '{1}', but not in '{2}'.")] InvalidReferenceVersion(&'err Identifier, &'err VersionSet, &'err VersionSet), - #[error("Reference '{0}' is not valid. Expected: {1}.")] - InvalidReferenceFilter(&'err Identifier, &'err ReferenceFilter), + #[error("Reference '{0}' of kind '{1:?}' is not valid. Expected: {2:?}")] + InvalidReferenceFilter( + &'err Identifier, + &'err SpannedItemDiscriminants, + &'err [SpannedItemDiscriminants], + ), } diff --git a/crates/codegen/language/definition/src/model/item.rs b/crates/codegen/language/definition/src/model/item.rs index c220dec1bc..5ac9d8ef7c 100644 --- a/crates/codegen/language/definition/src/model/item.rs +++ b/crates/codegen/language/definition/src/model/item.rs @@ -4,9 +4,10 @@ use crate::model::{ }; use codegen_language_internal_macros::{derive_spanned_type, ParseInputTokens, WriteOutputTokens}; use serde::{Deserialize, Serialize}; +use strum_macros::EnumDiscriminants; #[derive(Clone, Debug, Deserialize, Eq, PartialEq, Serialize)] -#[derive_spanned_type(ParseInputTokens, WriteOutputTokens)] +#[derive_spanned_type(EnumDiscriminants, ParseInputTokens, WriteOutputTokens)] pub enum Item { Struct { item: StructItem }, Enum { item: EnumItem }, diff --git a/crates/codegen/language/definition/src/model/non_terminals/field.rs b/crates/codegen/language/definition/src/model/non_terminals/field.rs index d01a7ac92d..0dc95a6632 100644 --- a/crates/codegen/language/definition/src/model/non_terminals/field.rs +++ b/crates/codegen/language/definition/src/model/non_terminals/field.rs @@ -1,6 +1,5 @@ use crate::model::{Identifier, VersionSpecifier}; use codegen_language_internal_macros::{derive_spanned_type, ParseInputTokens, WriteOutputTokens}; -use indexmap::IndexSet; use serde::{Deserialize, Serialize}; #[derive(Clone, Debug, Deserialize, Eq, PartialEq, Serialize)] @@ -21,18 +20,11 @@ pub struct FieldDelimiters { #[derive_spanned_type(ParseInputTokens, WriteOutputTokens)] pub enum Field { Required { - kind: FieldKind, + reference: Identifier, }, Optional { - kind: FieldKind, + reference: Identifier, enabled: Option, }, } - -#[derive(Clone, Debug, Deserialize, Eq, PartialEq, Serialize)] -#[derive_spanned_type(ParseInputTokens, WriteOutputTokens)] -pub enum FieldKind { - NonTerminal { item: Identifier }, - Terminal { items: IndexSet }, -} diff --git a/crates/codegen/language/definition/src/model/non_terminals/precedence.rs b/crates/codegen/language/definition/src/model/non_terminals/precedence.rs index aeb2359879..eb4c2ec702 100644 --- a/crates/codegen/language/definition/src/model/non_terminals/precedence.rs +++ b/crates/codegen/language/definition/src/model/non_terminals/precedence.rs @@ -48,7 +48,7 @@ pub enum OperatorModel { #[derive(Clone, Debug, Deserialize, Eq, PartialEq, Serialize)] #[derive_spanned_type(ParseInputTokens, WriteOutputTokens)] pub struct PrimaryExpression { - pub expression: Identifier, + pub reference: Identifier, pub enabled: Option, } diff --git a/crates/codegen/language/internal_macros/src/derive/spanned.rs b/crates/codegen/language/internal_macros/src/derive/spanned.rs index b2668ea5a2..4f460fcd2c 100644 --- a/crates/codegen/language/internal_macros/src/derive/spanned.rs +++ b/crates/codegen/language/internal_macros/src/derive/spanned.rs @@ -112,7 +112,6 @@ fn get_spanned_type(input: Type) -> Type { | "EnumVariant" | "Field" | "FieldDelimiters" - | "FieldKind" | "FieldsErrorRecovery" | "FragmentItem" | "InputItem" diff --git a/crates/codegen/language/tests/src/fail/definitions/duplicate_expression_name/test.rs b/crates/codegen/language/tests/src/fail/definitions/duplicate_expression_name/test.rs index df4baaacc2..1e5c9f00d6 100644 --- a/crates/codegen/language/tests/src/fail/definitions/duplicate_expression_name/test.rs +++ b/crates/codegen/language/tests/src/fail/definitions/duplicate_expression_name/test.rs @@ -18,7 +18,7 @@ codegen_language_macros::compile!(Language( PrecedenceExpression(name = Expression2, rule_name = X, operators = []), PrecedenceExpression(name = Expression1, rule_name = X, operators = []) ], - primary_expressions = [PrimaryExpression(expression = Baz)] + primary_expressions = [PrimaryExpression(reference = Baz)] ), Token( name = Baz, diff --git a/crates/codegen/language/tests/src/fail/definitions/duplicate_item_name/test.rs b/crates/codegen/language/tests/src/fail/definitions/duplicate_item_name/test.rs index 5518052483..ea3aed79b5 100644 --- a/crates/codegen/language/tests/src/fail/definitions/duplicate_item_name/test.rs +++ b/crates/codegen/language/tests/src/fail/definitions/duplicate_item_name/test.rs @@ -11,9 +11,9 @@ codegen_language_macros::compile!(Language( topics = [Topic( title = "Topic One", items = [ - Struct(name = Bar1, fields = (field = Required(NonTerminal(Bar2)))), - Struct(name = Bar1, fields = (field = Required(NonTerminal(Bar2)))), - Struct(name = Bar2, fields = (field = Required(NonTerminal(Bar1)))) + Struct(name = Bar1, fields = (field = Required(Bar2))), + Struct(name = Bar1, fields = (field = Required(Bar2))), + Struct(name = Bar2, fields = (field = Required(Bar1))) ] )] )] diff --git a/crates/codegen/language/tests/src/fail/definitions/duplicate_item_name/test.stderr b/crates/codegen/language/tests/src/fail/definitions/duplicate_item_name/test.stderr index 42cc9efcdd..f7bcd6ff87 100644 --- a/crates/codegen/language/tests/src/fail/definitions/duplicate_item_name/test.stderr +++ b/crates/codegen/language/tests/src/fail/definitions/duplicate_item_name/test.stderr @@ -1,5 +1,5 @@ error: An item with the name 'Bar1' already exists. --> src/fail/definitions/duplicate_item_name/test.rs:15:31 | -15 | Struct(name = Bar1, fields = (field = Required(NonTerminal(Bar2)))), +15 | Struct(name = Bar1, fields = (field = Required(Bar2))), | ^^^^ diff --git a/crates/codegen/language/tests/src/fail/parsing/duplicate_map_key/test.rs b/crates/codegen/language/tests/src/fail/parsing/duplicate_map_key/test.rs index 17e2c3d9fa..feec6519cc 100644 --- a/crates/codegen/language/tests/src/fail/parsing/duplicate_map_key/test.rs +++ b/crates/codegen/language/tests/src/fail/parsing/duplicate_map_key/test.rs @@ -14,9 +14,9 @@ codegen_language_macros::compile!(Language( Struct( name = Bar, fields = ( - field_1 = Required(Terminal([Baz])), - field_1 = Required(Terminal([Baz])), - field_3 = Required(Terminal([Baz])) + field_1 = Required(Baz), + field_1 = Required(Baz), + field_3 = Required(Baz) ) ), Token( diff --git a/crates/codegen/language/tests/src/fail/parsing/duplicate_map_key/test.stderr b/crates/codegen/language/tests/src/fail/parsing/duplicate_map_key/test.stderr index b023aa033e..e85609480c 100644 --- a/crates/codegen/language/tests/src/fail/parsing/duplicate_map_key/test.stderr +++ b/crates/codegen/language/tests/src/fail/parsing/duplicate_map_key/test.stderr @@ -1,5 +1,5 @@ error: Duplicate map key. --> src/fail/parsing/duplicate_map_key/test.rs:18:25 | -18 | field_1 = Required(Terminal([Baz])), +18 | field_1 = Required(Baz), | ^^^^^^^ diff --git a/crates/codegen/language/tests/src/fail/parsing/unrecognized_variant/test.rs b/crates/codegen/language/tests/src/fail/parsing/unrecognized_variant/test.rs index ff0f51200a..dcf99e3e52 100644 --- a/crates/codegen/language/tests/src/fail/parsing/unrecognized_variant/test.rs +++ b/crates/codegen/language/tests/src/fail/parsing/unrecognized_variant/test.rs @@ -12,8 +12,8 @@ codegen_language_macros::compile!(Language( Topic( title = "Topic One", items = [ - Struct(name = Bar1, fields = (field = Required(NonTerminal(Bar2)))), - Struct(name = Bar2, fields = (field = Required(NonTerminal(Bar1)))) + Struct(name = Bar1, fields = (field = Required(Bar2))), + Struct(name = Bar2, fields = (field = Required(Bar1))) ] ), Topic(title = "Topic Two", items = [Unrecognized(true)]) diff --git a/crates/codegen/language/tests/src/fail/reachability/unreachable/test.rs b/crates/codegen/language/tests/src/fail/reachability/unreachable/test.rs index dd50c2800f..8eba153d8d 100644 --- a/crates/codegen/language/tests/src/fail/reachability/unreachable/test.rs +++ b/crates/codegen/language/tests/src/fail/reachability/unreachable/test.rs @@ -12,11 +12,11 @@ codegen_language_macros::compile!(Language( title = "Topic One", items = [ // reachable (from root) - Struct(name = Bar1, fields = (field = Required(NonTerminal(Bar2)))), - Struct(name = Bar2, fields = (field = Required(NonTerminal(Bar1)))), + Struct(name = Bar1, fields = (field = Required(Bar2))), + Struct(name = Bar2, fields = (field = Required(Bar1))), // not-reachable - Struct(name = Baz1, fields = (field = Required(NonTerminal(Baz2)))), - Struct(name = Baz2, fields = (field = Required(NonTerminal(Baz1)))) + Struct(name = Baz1, fields = (field = Required(Baz2))), + Struct(name = Baz2, fields = (field = Required(Baz1))) ] )] )] diff --git a/crates/codegen/language/tests/src/fail/reachability/unreachable/test.stderr b/crates/codegen/language/tests/src/fail/reachability/unreachable/test.stderr index 3eb13eb69a..acdd4fcef9 100644 --- a/crates/codegen/language/tests/src/fail/reachability/unreachable/test.stderr +++ b/crates/codegen/language/tests/src/fail/reachability/unreachable/test.stderr @@ -1,11 +1,11 @@ error: Item 'Baz1' is not reachable from grammar root. --> src/fail/reachability/unreachable/test.rs:18:31 | -18 | Struct(name = Baz1, fields = (field = Required(NonTerminal(Baz2)))), +18 | Struct(name = Baz1, fields = (field = Required(Baz2))), | ^^^^ error: Item 'Baz2' is not reachable from grammar root. --> src/fail/reachability/unreachable/test.rs:19:31 | -19 | Struct(name = Baz2, fields = (field = Required(NonTerminal(Baz1)))) +19 | Struct(name = Baz2, fields = (field = Required(Baz1))) | ^^^^ diff --git a/crates/codegen/language/tests/src/fail/reachability/unused_version/test.rs b/crates/codegen/language/tests/src/fail/reachability/unused_version/test.rs index f6d9818426..674e48778c 100644 --- a/crates/codegen/language/tests/src/fail/reachability/unused_version/test.rs +++ b/crates/codegen/language/tests/src/fail/reachability/unused_version/test.rs @@ -13,7 +13,7 @@ codegen_language_macros::compile!(Language( items = [ Struct( name = Bar, - fields = (field_1 = Optional(kind = Terminal([Baz]), enabled = From("2.0.0"))) + fields = (field_1 = Optional(reference = Baz, enabled = From("2.0.0"))) ), Token( name = Baz, diff --git a/crates/codegen/language/tests/src/fail/references/disabled_too_late/test.rs b/crates/codegen/language/tests/src/fail/references/disabled_too_late/test.rs index 7df883a410..b544de07f5 100644 --- a/crates/codegen/language/tests/src/fail/references/disabled_too_late/test.rs +++ b/crates/codegen/language/tests/src/fail/references/disabled_too_late/test.rs @@ -15,17 +15,16 @@ codegen_language_macros::compile!(Language( name = One, fields = ( field_1 = Optional( - kind = NonTerminal(Two), + reference = Two, enabled = Range(from = "2.0.0", till = "3.0.0") ), - field_2 = Optional(kind = Terminal([Three])) + field_2 = Optional(reference = Three) ) ), Struct( name = Two, enabled = Range(from = "2.0.0", till = "3.0.0"), - fields = - (field_1 = Optional(kind = Terminal([Three]), enabled = Till("4.0.0"))) + fields = (field_1 = Optional(reference = Three, enabled = Till("4.0.0"))) ), Token( name = Three, diff --git a/crates/codegen/language/tests/src/fail/references/disabled_too_late/test.stderr b/crates/codegen/language/tests/src/fail/references/disabled_too_late/test.stderr index 1e5417bd4c..ef98d468f9 100644 --- a/crates/codegen/language/tests/src/fail/references/disabled_too_late/test.stderr +++ b/crates/codegen/language/tests/src/fail/references/disabled_too_late/test.stderr @@ -1,5 +1,5 @@ error: Parent scope is only enabled in '2.0.0..3.0.0'. - --> src/fail/references/disabled_too_late/test.rs:28:81 + --> src/fail/references/disabled_too_late/test.rs:27:79 | -28 | (field_1 = Optional(kind = Terminal([Three]), enabled = Till("4.0.0"))) - | ^^^^ +27 | fields = (field_1 = Optional(reference = Three, enabled = Till("4.0.0"))) + | ^^^^ diff --git a/crates/codegen/language/tests/src/fail/references/enabled_too_early/test.rs b/crates/codegen/language/tests/src/fail/references/enabled_too_early/test.rs index ccf3e84075..6afefcd14a 100644 --- a/crates/codegen/language/tests/src/fail/references/enabled_too_early/test.rs +++ b/crates/codegen/language/tests/src/fail/references/enabled_too_early/test.rs @@ -15,17 +15,16 @@ codegen_language_macros::compile!(Language( name = One, fields = ( field_1 = Optional( - kind = NonTerminal(Two), + reference = Two, enabled = Range(from = "2.0.0", till = "3.0.0") ), - field_2 = Optional(kind = Terminal([Three])) + field_2 = Optional(reference = Three) ) ), Struct( name = Two, enabled = Range(from = "2.0.0", till = "3.0.0"), - fields = - (field_1 = Optional(kind = Terminal([Three]), enabled = From("1.0.0"))) + fields = (field_1 = Optional(reference = Three, enabled = From("1.0.0"))) ), Token( name = Three, diff --git a/crates/codegen/language/tests/src/fail/references/enabled_too_early/test.stderr b/crates/codegen/language/tests/src/fail/references/enabled_too_early/test.stderr index 4e1df65522..f0bb061d70 100644 --- a/crates/codegen/language/tests/src/fail/references/enabled_too_early/test.stderr +++ b/crates/codegen/language/tests/src/fail/references/enabled_too_early/test.stderr @@ -1,5 +1,5 @@ error: Parent scope is only enabled in '2.0.0..3.0.0'. - --> src/fail/references/enabled_too_early/test.rs:28:81 + --> src/fail/references/enabled_too_early/test.rs:27:79 | -28 | (field_1 = Optional(kind = Terminal([Three]), enabled = From("1.0.0"))) - | ^^^^ +27 | fields = (field_1 = Optional(reference = Three, enabled = From("1.0.0"))) + | ^^^^ diff --git a/crates/codegen/language/tests/src/fail/references/invalid_filter/test.rs b/crates/codegen/language/tests/src/fail/references/invalid_filter/test.rs index dc983ea7b5..20446f1c43 100644 --- a/crates/codegen/language/tests/src/fail/references/invalid_filter/test.rs +++ b/crates/codegen/language/tests/src/fail/references/invalid_filter/test.rs @@ -11,7 +11,7 @@ codegen_language_macros::compile!(Language( topics = [Topic( title = "Topic One", items = [ - Struct(name = Bar, fields = (field = Required(NonTerminal(Baz)))), + Struct(name = Bar, fields = (field = Required(Baz))), Fragment(name = Baz, scanner = Atom("baz")) ] )] diff --git a/crates/codegen/language/tests/src/fail/references/invalid_filter/test.stderr b/crates/codegen/language/tests/src/fail/references/invalid_filter/test.stderr index eb25b9e53c..7833556c97 100644 --- a/crates/codegen/language/tests/src/fail/references/invalid_filter/test.stderr +++ b/crates/codegen/language/tests/src/fail/references/invalid_filter/test.stderr @@ -1,5 +1,5 @@ -error: Reference 'Baz' is not valid. Expected: NonTerminals. - --> src/fail/references/invalid_filter/test.rs:14:75 +error: Reference 'Baz' of kind 'Fragment' is not valid. Expected: [Struct, Enum, Repeated, Separated, Precedence, Keyword, Token] + --> src/fail/references/invalid_filter/test.rs:14:63 | -14 | Struct(name = Bar, fields = (field = Required(NonTerminal(Baz)))), - | ^^^ +14 | Struct(name = Bar, fields = (field = Required(Baz))), + | ^^^ diff --git a/crates/codegen/language/tests/src/fail/references/invalid_version/test.rs b/crates/codegen/language/tests/src/fail/references/invalid_version/test.rs index d96e285384..7eeb3e062a 100644 --- a/crates/codegen/language/tests/src/fail/references/invalid_version/test.rs +++ b/crates/codegen/language/tests/src/fail/references/invalid_version/test.rs @@ -16,21 +16,21 @@ codegen_language_macros::compile!(Language( fields = ( field_1 = Optional( // should have been disabled in "3.0.0" - kind = Terminal([Baz]), + reference = Baz, enabled = From("2.0.0") ), field_2 = Optional( // should have been enabled in "2.0.0" - kind = Terminal([Baz]), + reference = Baz, enabled = Till("3.0.0") ), field_3 = Optional( // should have been enabled in "2.0.0" and disabled in "3.0.0" - kind = Terminal([Baz]) + reference = Baz ), field_4 = Optional( // correct - kind = Terminal([Baz]), + reference = Baz, enabled = Range(from = "2.0.0", till = "3.0.0") ) ) diff --git a/crates/codegen/language/tests/src/fail/references/invalid_version/test.stderr b/crates/codegen/language/tests/src/fail/references/invalid_version/test.stderr index 72f4255f39..0b6987dd0d 100644 --- a/crates/codegen/language/tests/src/fail/references/invalid_version/test.stderr +++ b/crates/codegen/language/tests/src/fail/references/invalid_version/test.stderr @@ -1,17 +1,17 @@ error: Reference 'Baz' is only defined in '2.0.0..3.0.0', but not in '3.0.0..MAX'. - --> src/fail/references/invalid_version/test.rs:19:46 + --> src/fail/references/invalid_version/test.rs:19:41 | -19 | ... kind = Terminal([Baz]), - | ^^^ +19 | ... reference = Baz, + | ^^^ error: Reference 'Baz' is only defined in '2.0.0..3.0.0', but not in '1.0.0..2.0.0'. - --> src/fail/references/invalid_version/test.rs:24:46 + --> src/fail/references/invalid_version/test.rs:24:41 | -24 | ... kind = Terminal([Baz]), - | ^^^ +24 | ... reference = Baz, + | ^^^ error: Reference 'Baz' is only defined in '2.0.0..3.0.0', but not in '1.0.0..2.0.0 | 3.0.0..MAX'. - --> src/fail/references/invalid_version/test.rs:29:46 + --> src/fail/references/invalid_version/test.rs:29:41 | -29 | ... kind = Terminal([Baz]) - | ^^^ +29 | ... reference = Baz + | ^^^ diff --git a/crates/codegen/language/tests/src/fail/references/unknown_reference/test.rs b/crates/codegen/language/tests/src/fail/references/unknown_reference/test.rs index dde40bd4d3..dd950357b4 100644 --- a/crates/codegen/language/tests/src/fail/references/unknown_reference/test.rs +++ b/crates/codegen/language/tests/src/fail/references/unknown_reference/test.rs @@ -13,10 +13,7 @@ codegen_language_macros::compile!(Language( items = [ Struct( name = Bar, - fields = ( - field_1 = Required(Terminal([Baz])), - field_2 = Required(Terminal([Unknown])) - ) + fields = (field_1 = Required(Baz), field_2 = Required(Unknown)) ), Token( name = Baz, diff --git a/crates/codegen/language/tests/src/fail/references/unknown_reference/test.stderr b/crates/codegen/language/tests/src/fail/references/unknown_reference/test.stderr index 6c783e5921..0ccda2cae7 100644 --- a/crates/codegen/language/tests/src/fail/references/unknown_reference/test.stderr +++ b/crates/codegen/language/tests/src/fail/references/unknown_reference/test.stderr @@ -1,5 +1,5 @@ error: Reference to unknown item 'Unknown'. - --> src/fail/references/unknown_reference/test.rs:18:54 + --> src/fail/references/unknown_reference/test.rs:16:75 | -18 | field_2 = Required(Terminal([Unknown])) - | ^^^^^^^ +16 | fields = (field_1 = Required(Baz), field_2 = Required(Unknown)) + | ^^^^^^^ diff --git a/crates/codegen/language/tests/src/fail/references/unordered_version_pair/test.rs b/crates/codegen/language/tests/src/fail/references/unordered_version_pair/test.rs index c8243cccea..eafcad0ba3 100644 --- a/crates/codegen/language/tests/src/fail/references/unordered_version_pair/test.rs +++ b/crates/codegen/language/tests/src/fail/references/unordered_version_pair/test.rs @@ -15,10 +15,10 @@ codegen_language_macros::compile!(Language( name = One, fields = ( field_1 = Optional( - kind = Terminal([Two]), + reference = Two, enabled = Range(from = "3.0.0", till = "2.0.0") ), - field_2 = Optional(kind = Terminal([Two])) + field_2 = Optional(reference = Two) ) ), Token( diff --git a/crates/codegen/language/tests/src/fail/references/version_not_found/test.rs b/crates/codegen/language/tests/src/fail/references/version_not_found/test.rs index b56e8a69ea..ea3f69dbab 100644 --- a/crates/codegen/language/tests/src/fail/references/version_not_found/test.rs +++ b/crates/codegen/language/tests/src/fail/references/version_not_found/test.rs @@ -14,8 +14,8 @@ codegen_language_macros::compile!(Language( Struct( name = One, fields = ( - field_1 = Optional(kind = Terminal([Two]), enabled = From("3.0.0")), - field_2 = Optional(kind = Terminal([Two])) + field_1 = Optional(reference = Two, enabled = From("3.0.0")), + field_2 = Optional(reference = Two) ) ), Token( diff --git a/crates/codegen/language/tests/src/fail/references/version_not_found/test.stderr b/crates/codegen/language/tests/src/fail/references/version_not_found/test.stderr index 699ed4b888..872ce9f560 100644 --- a/crates/codegen/language/tests/src/fail/references/version_not_found/test.stderr +++ b/crates/codegen/language/tests/src/fail/references/version_not_found/test.stderr @@ -1,5 +1,5 @@ error: Version '3.0.0' does not exist in the language definition. - --> src/fail/references/version_not_found/test.rs:17:83 + --> src/fail/references/version_not_found/test.rs:17:76 | -17 | field_1 = Optional(kind = Terminal([Two]), enabled = From("3.0.0")), - | ^^^^^^^ +17 | field_1 = Optional(reference = Two, enabled = From("3.0.0")), + | ^^^^^^^ diff --git a/crates/codegen/language/tests/src/pass/tiny_language.rs b/crates/codegen/language/tests/src/pass/tiny_language.rs index d4821579b2..87e63587e5 100644 --- a/crates/codegen/language/tests/src/pass/tiny_language.rs +++ b/crates/codegen/language/tests/src/pass/tiny_language.rs @@ -1,6 +1,6 @@ use codegen_language_definition::model::{ - Field, FieldKind, Item, Language, Scanner, Section, StructItem, TokenDefinition, TokenItem, - Topic, TriviaParser, + Field, Item, Language, Scanner, Section, StructItem, TokenDefinition, TokenItem, Topic, + TriviaParser, }; use semver::Version; @@ -18,9 +18,9 @@ codegen_language_macros::compile!(Language( Struct( name = Foo, fields = ( - bar = Required(Terminal([Bar])), - baz = Required(Terminal([Baz])), - baz_again = Required(Terminal([Baz])) + bar = Required(Bar), + baz = Required(Baz), + baz_again = Required(Baz) ) ), Token( @@ -67,25 +67,19 @@ fn definition() { ( "bar".into(), Field::Required { - kind: FieldKind::Terminal { - items: ["Bar".into()].into() - } + reference: "Bar".into() } ), ( "baz".into(), Field::Required { - kind: FieldKind::Terminal { - items: ["Baz".into()].into() - } + reference: "Baz".into() } ), ( "baz_again".into(), Field::Required { - kind: FieldKind::Terminal { - items: ["Baz".into()].into() - } + reference: "Baz".into() } ) ] diff --git a/crates/solidity/inputs/language/src/definition.rs b/crates/solidity/inputs/language/src/definition.rs index 6a1625bf77..5157b19f2e 100644 --- a/crates/solidity/inputs/language/src/definition.rs +++ b/crates/solidity/inputs/language/src/definition.rs @@ -36,7 +36,7 @@ codegen_language_macros::compile!(Language( items = [ Struct( name = SourceUnit, - fields = (members = Optional(kind = NonTerminal(SourceUnitMembers))) + fields = (members = Optional(reference = SourceUnitMembers)) ), Repeated(name = SourceUnitMembers, repeated = SourceUnitMember), Enum( @@ -99,9 +99,9 @@ codegen_language_macros::compile!(Language( name = PragmaDirective, error_recovery = FieldsErrorRecovery(terminator = semicolon), fields = ( - pragma_keyword = Required(Terminal([PragmaKeyword])), - pragma = Required(NonTerminal(Pragma)), - semicolon = Required(Terminal([Semicolon])) + pragma_keyword = Required(PragmaKeyword), + pragma = Required(Pragma), + semicolon = Required(Semicolon) ) ), Enum( @@ -115,15 +115,15 @@ codegen_language_macros::compile!(Language( Struct( name = ABICoderPragma, fields = ( - abicoder_keyword = Required(Terminal([AbicoderKeyword])), - version = Required(Terminal([Identifier])) + abicoder_keyword = Required(AbicoderKeyword), + version = Required(Identifier) ) ), Struct( name = ExperimentalPragma, fields = ( - experimental_keyword = Required(Terminal([ExperimentalKeyword])), - feature = Required(NonTerminal(ExperimentalFeature)) + experimental_keyword = Required(ExperimentalKeyword), + feature = Required(ExperimentalFeature) ) ), Enum( @@ -136,8 +136,8 @@ codegen_language_macros::compile!(Language( Struct( name = VersionPragma, fields = ( - solidity_keyword = Required(Terminal([SolidityKeyword])), - expressions = Required(NonTerminal(VersionPragmaExpressions)) + solidity_keyword = Required(SolidityKeyword), + expressions = Required(VersionPragmaExpressions) ) ), Repeated( @@ -152,7 +152,7 @@ codegen_language_macros::compile!(Language( rule_name = VersionPragmaBinaryExpression, operators = [PrecedenceOperator( model = BinaryLeftAssociative, - fields = (operator = Required(Terminal([BarBar]))) + fields = (operator = Required(BarBar)) )] ), PrecedenceExpression( @@ -160,28 +160,46 @@ codegen_language_macros::compile!(Language( rule_name = VersionPragmaBinaryExpression, operators = [PrecedenceOperator( model = BinaryLeftAssociative, - fields = (operator = Required(Terminal([Minus]))) + fields = (operator = Required(Minus)) )] ), PrecedenceExpression( name = VersionPragmaPrefixExpression, rule_name = VersionPragmaUnaryExpression, - operators = [PrecedenceOperator( - model = Prefix, - fields = (operator = Required(Terminal([ - Caret, - Tilde, - Equal, - LessThan, - GreaterThan, - LessThanEqual, - GreaterThanEqual - ]))) - )] + operators = [ + PrecedenceOperator( + model = Prefix, + fields = (operator = Required(Caret)) + ), + PrecedenceOperator( + model = Prefix, + fields = (operator = Required(Tilde)) + ), + PrecedenceOperator( + model = Prefix, + fields = (operator = Required(Equal)) + ), + PrecedenceOperator( + model = Prefix, + fields = (operator = Required(LessThan)) + ), + PrecedenceOperator( + model = Prefix, + fields = (operator = Required(GreaterThan)) + ), + PrecedenceOperator( + model = Prefix, + fields = (operator = Required(LessThanEqual)) + ), + PrecedenceOperator( + model = Prefix, + fields = (operator = Required(GreaterThanEqual)) + ) + ] ) ], primary_expressions = - [PrimaryExpression(expression = VersionPragmaSpecifier)] + [PrimaryExpression(reference = VersionPragmaSpecifier)] ), Separated( name = VersionPragmaSpecifier, @@ -223,9 +241,9 @@ codegen_language_macros::compile!(Language( name = ImportDirective, error_recovery = FieldsErrorRecovery(terminator = semicolon), fields = ( - import_keyword = Required(Terminal([ImportKeyword])), - clause = Required(NonTerminal(ImportClause)), - semicolon = Required(Terminal([Semicolon])) + import_keyword = Required(ImportKeyword), + clause = Required(ImportClause), + semicolon = Required(Semicolon) ) ), Enum( @@ -242,17 +260,17 @@ codegen_language_macros::compile!(Language( Struct( name = PathImport, fields = ( - path = Required(Terminal([AsciiStringLiteral])), - alias = Optional(kind = NonTerminal(ImportAlias)) + path = Required(AsciiStringLiteral), + alias = Optional(reference = ImportAlias) ) ), Struct( name = NamedImport, fields = ( - asterisk = Required(Terminal([Asterisk])), - alias = Required(NonTerminal(ImportAlias)), - from_keyword = Required(Terminal([FromKeyword])), - path = Required(Terminal([AsciiStringLiteral])) + asterisk = Required(Asterisk), + alias = Required(ImportAlias), + from_keyword = Required(FromKeyword), + path = Required(AsciiStringLiteral) ) ), Struct( @@ -262,11 +280,11 @@ codegen_language_macros::compile!(Language( FieldDelimiters(open = open_brace, close = close_brace) ), fields = ( - open_brace = Required(Terminal([OpenBrace])), - symbols = Required(NonTerminal(ImportDeconstructionSymbols)), - close_brace = Required(Terminal([CloseBrace])), - from_keyword = Required(Terminal([FromKeyword])), - path = Required(Terminal([AsciiStringLiteral])) + open_brace = Required(OpenBrace), + symbols = Required(ImportDeconstructionSymbols), + close_brace = Required(CloseBrace), + from_keyword = Required(FromKeyword), + path = Required(AsciiStringLiteral) ) ), Separated( @@ -277,15 +295,15 @@ codegen_language_macros::compile!(Language( Struct( name = ImportDeconstructionSymbol, fields = ( - name = Required(Terminal([Identifier])), - alias = Optional(kind = NonTerminal(ImportAlias)) + name = Required(Identifier), + alias = Optional(reference = ImportAlias) ) ), Struct( name = ImportAlias, fields = ( - as_keyword = Required(Terminal([AsKeyword])), - identifier = Required(Terminal([Identifier])) + as_keyword = Required(AsKeyword), + identifier = Required(Identifier) ) ) ] @@ -297,15 +315,13 @@ codegen_language_macros::compile!(Language( name = UsingDirective, error_recovery = FieldsErrorRecovery(terminator = semicolon), fields = ( - using_keyword = Required(Terminal([UsingKeyword])), - clause = Required(NonTerminal(UsingClause)), - for_keyword = Required(Terminal([ForKeyword])), - target = Required(NonTerminal(UsingTarget)), - global_keyword = Optional( - kind = Terminal([GlobalKeyword]), - enabled = From("0.8.13") - ), - semicolon = Required(Terminal([Semicolon])) + using_keyword = Required(UsingKeyword), + clause = Required(UsingClause), + for_keyword = Required(ForKeyword), + target = Required(UsingTarget), + global_keyword = + Optional(reference = GlobalKeyword, enabled = From("0.8.13")), + semicolon = Required(Semicolon) ) ), Enum( @@ -327,9 +343,9 @@ codegen_language_macros::compile!(Language( FieldDelimiters(open = open_brace, close = close_brace) ), fields = ( - open_brace = Required(Terminal([OpenBrace])), - symbols = Required(NonTerminal(UsingDeconstructionSymbols)), - close_brace = Required(Terminal([CloseBrace])) + open_brace = Required(OpenBrace), + symbols = Required(UsingDeconstructionSymbols), + close_brace = Required(CloseBrace) ) ), Separated( @@ -342,37 +358,39 @@ codegen_language_macros::compile!(Language( name = UsingDeconstructionSymbol, enabled = From("0.8.13"), fields = ( - name = Required(NonTerminal(IdentifierPath)), - alias = Optional( - kind = NonTerminal(UsingAlias), - enabled = From("0.8.19") - ) + name = Required(IdentifierPath), + alias = Optional(reference = UsingAlias, enabled = From("0.8.19")) ) ), Struct( name = UsingAlias, enabled = From("0.8.19"), fields = ( - as_keyword = Required(Terminal([AsKeyword])), - operator = Required(Terminal([ - Ampersand, - Asterisk, - BangEqual, - Bar, - Caret, - EqualEqual, - GreaterThan, - GreaterThanEqual, - LessThan, - LessThanEqual, - Minus, - Percent, - Plus, - Slash, - Tilde - ])) + as_keyword = Required(AsKeyword), + operator = Required(UsingOperator) ) ), + Enum( + name = UsingOperator, + enabled = From("0.8.19"), + variants = [ + EnumVariant(name = Ampersand, reference = Ampersand), + EnumVariant(name = Asterisk, reference = Asterisk), + EnumVariant(name = BangEqual, reference = BangEqual), + EnumVariant(name = Bar, reference = Bar), + EnumVariant(name = Caret, reference = Caret), + EnumVariant(name = EqualEqual, reference = EqualEqual), + EnumVariant(name = GreaterThan, reference = GreaterThan), + EnumVariant(name = GreaterThanEqual, reference = GreaterThanEqual), + EnumVariant(name = LessThan, reference = LessThan), + EnumVariant(name = LessThanEqual, reference = LessThanEqual), + EnumVariant(name = Minus, reference = Minus), + EnumVariant(name = Percent, reference = Percent), + EnumVariant(name = Plus, reference = Plus), + EnumVariant(name = Slash, reference = Slash), + EnumVariant(name = Tilde, reference = Tilde) + ] + ), Enum( name = UsingTarget, variants = [ @@ -2080,23 +2098,21 @@ codegen_language_macros::compile!(Language( FieldDelimiters(open = open_brace, close = close_brace) ), fields = ( - abstract_keyword = Optional( - kind = Terminal([AbstractKeyword]), - enabled = From("0.6.0") - ), - contract_keyword = Required(Terminal([ContractKeyword])), - name = Required(Terminal([Identifier])), - inheritence = Optional(kind = NonTerminal(InheritanceSpecifier)), - open_brace = Required(Terminal([OpenBrace])), - members = Optional(kind = NonTerminal(ContractMembers)), - close_brace = Required(Terminal([CloseBrace])) + abstract_keyword = + Optional(reference = AbstractKeyword, enabled = From("0.6.0")), + contract_keyword = Required(ContractKeyword), + name = Required(Identifier), + inheritence = Optional(reference = InheritanceSpecifier), + open_brace = Required(OpenBrace), + members = Optional(reference = ContractMembers), + close_brace = Required(CloseBrace) ) ), Struct( name = InheritanceSpecifier, fields = ( - is_keyword = Required(Terminal([IsKeyword])), - types = Required(NonTerminal(InheritanceTypes)) + is_keyword = Required(IsKeyword), + types = Required(InheritanceTypes) ) ), Separated( @@ -2107,8 +2123,8 @@ codegen_language_macros::compile!(Language( Struct( name = InheritanceType, fields = ( - type_name = Required(NonTerminal(IdentifierPath)), - arguments = Optional(kind = NonTerminal(ArgumentsDeclaration)) + type_name = Required(IdentifierPath), + arguments = Optional(reference = ArgumentsDeclaration) ) ), Repeated(name = ContractMembers, repeated = ContractMember), @@ -2169,12 +2185,12 @@ codegen_language_macros::compile!(Language( FieldDelimiters(open = open_brace, close = close_brace) ), fields = ( - interface_keyword = Required(Terminal([InterfaceKeyword])), - name = Required(Terminal([Identifier])), - inheritence = Optional(kind = NonTerminal(InheritanceSpecifier)), - open_brace = Required(Terminal([OpenBrace])), - members = Optional(kind = NonTerminal(InterfaceMembers)), - close_brace = Required(Terminal([CloseBrace])) + interface_keyword = Required(InterfaceKeyword), + name = Required(Identifier), + inheritence = Optional(reference = InheritanceSpecifier), + open_brace = Required(OpenBrace), + members = Optional(reference = InterfaceMembers), + close_brace = Required(CloseBrace) ) ), Repeated(name = InterfaceMembers, repeated = ContractMember) @@ -2190,11 +2206,11 @@ codegen_language_macros::compile!(Language( FieldDelimiters(open = open_brace, close = close_brace) ), fields = ( - library_keyword = Required(Terminal([LibraryKeyword])), - name = Required(Terminal([Identifier])), - open_brace = Required(Terminal([OpenBrace])), - members = Optional(kind = NonTerminal(LibraryMembers)), - close_brace = Required(Terminal([CloseBrace])) + library_keyword = Required(LibraryKeyword), + name = Required(Identifier), + open_brace = Required(OpenBrace), + members = Optional(reference = LibraryMembers), + close_brace = Required(CloseBrace) ) ), Repeated(name = LibraryMembers, repeated = ContractMember) @@ -2210,11 +2226,11 @@ codegen_language_macros::compile!(Language( FieldDelimiters(open = open_brace, close = close_brace) ), fields = ( - struct_keyword = Required(Terminal([StructKeyword])), - name = Required(Terminal([Identifier])), - open_brace = Required(Terminal([OpenBrace])), - members = Optional(kind = NonTerminal(StructMembers)), - close_brace = Required(Terminal([CloseBrace])) + struct_keyword = Required(StructKeyword), + name = Required(Identifier), + open_brace = Required(OpenBrace), + members = Optional(reference = StructMembers), + close_brace = Required(CloseBrace) ) ), Repeated(name = StructMembers, repeated = StructMember), @@ -2222,9 +2238,9 @@ codegen_language_macros::compile!(Language( name = StructMember, error_recovery = FieldsErrorRecovery(terminator = semicolon), fields = ( - type_name = Required(NonTerminal(TypeName)), - name = Required(Terminal([Identifier])), - semicolon = Required(Terminal([Semicolon])) + type_name = Required(TypeName), + name = Required(Identifier), + semicolon = Required(Semicolon) ) ) ] @@ -2239,11 +2255,11 @@ codegen_language_macros::compile!(Language( FieldDelimiters(open = open_brace, close = close_brace) ), fields = ( - enum_keyword = Required(Terminal([EnumKeyword])), - name = Required(Terminal([Identifier])), - open_brace = Required(Terminal([OpenBrace])), - members = Optional(kind = NonTerminal(EnumMembers)), - close_brace = Required(Terminal([CloseBrace])) + enum_keyword = Required(EnumKeyword), + name = Required(Identifier), + open_brace = Required(OpenBrace), + members = Optional(reference = EnumMembers), + close_brace = Required(CloseBrace) ) ), Separated( @@ -2260,12 +2276,12 @@ codegen_language_macros::compile!(Language( enabled = From("0.7.4"), error_recovery = FieldsErrorRecovery(terminator = semicolon), fields = ( - type_name = Required(NonTerminal(TypeName)), - constant_keyword = Required(Terminal([ConstantKeyword])), - name = Required(Terminal([Identifier])), - equal = Required(Terminal([Equal])), - value = Required(NonTerminal(Expression)), - semicolon = Required(Terminal([Semicolon])) + type_name = Required(TypeName), + constant_keyword = Required(ConstantKeyword), + name = Required(Identifier), + equal = Required(Equal), + value = Required(Expression), + semicolon = Required(Semicolon) ) )] ), @@ -2276,19 +2292,16 @@ codegen_language_macros::compile!(Language( name = StateVariableDefinition, error_recovery = FieldsErrorRecovery(terminator = semicolon), fields = ( - type_name = Required(NonTerminal(TypeName)), - attributes = Optional(kind = NonTerminal(StateVariableAttributes)), - name = Required(Terminal([Identifier])), - value = Optional(kind = NonTerminal(StateVariableDefinitionValue)), - semicolon = Required(Terminal([Semicolon])) + type_name = Required(TypeName), + attributes = Optional(reference = StateVariableAttributes), + name = Required(Identifier), + value = Optional(reference = StateVariableDefinitionValue), + semicolon = Required(Semicolon) ) ), Struct( name = StateVariableDefinitionValue, - fields = ( - equal = Required(Terminal([Equal])), - value = Required(NonTerminal(Expression)) - ) + fields = (equal = Required(Equal), value = Required(Expression)) ), Repeated( name = StateVariableAttributes, @@ -2317,18 +2330,22 @@ codegen_language_macros::compile!(Language( Struct( name = FunctionDefinition, fields = ( - function_keyword = Required(Terminal([FunctionKeyword])), - name = Required(Terminal([ - Identifier, - FallbackKeyword, - ReceiveKeyword - ])), - parameters = Required(NonTerminal(ParametersDeclaration)), - attributes = Optional(kind = NonTerminal(FunctionAttributes)), - returns = Optional(kind = NonTerminal(ReturnsDeclaration)), - body = Required(NonTerminal(FunctionBody)) + function_keyword = Required(FunctionKeyword), + name = Required(FunctionName), + parameters = Required(ParametersDeclaration), + attributes = Optional(reference = FunctionAttributes), + returns = Optional(reference = ReturnsDeclaration), + body = Required(FunctionBody) ) ), + Enum( + name = FunctionName, + variants = [ + EnumVariant(name = Identifier, reference = Identifier), + EnumVariant(name = Fallback, reference = FallbackKeyword), + EnumVariant(name = Receive, reference = ReceiveKeyword) + ] + ), Struct( name = ParametersDeclaration, error_recovery = FieldsErrorRecovery( @@ -2336,18 +2353,18 @@ codegen_language_macros::compile!(Language( FieldDelimiters(open = open_paren, close = close_paren) ), fields = ( - open_paren = Required(Terminal([OpenParen])), - parameters = Optional(kind = NonTerminal(Parameters)), - close_paren = Required(Terminal([CloseParen])) + open_paren = Required(OpenParen), + parameters = Optional(reference = Parameters), + close_paren = Required(CloseParen) ) ), Separated(name = Parameters, separated = Parameter, separator = Comma), Struct( name = Parameter, fields = ( - type_name = Required(NonTerminal(TypeName)), - storage_location = Optional(kind = NonTerminal(StorageLocation)), - name = Optional(kind = Terminal([Identifier])) + type_name = Required(TypeName), + storage_location = Optional(reference = StorageLocation), + name = Optional(reference = Identifier) ) ), Repeated(name = FunctionAttributes, repeated = FunctionAttribute), @@ -2378,8 +2395,8 @@ codegen_language_macros::compile!(Language( Struct( name = OverrideSpecifier, fields = ( - override_keyword = Required(Terminal([OverrideKeyword])), - overridden = Optional(kind = NonTerminal(OverridePathsDeclaration)) + override_keyword = Required(OverrideKeyword), + overridden = Optional(reference = OverridePathsDeclaration) ) ), Struct( @@ -2389,9 +2406,9 @@ codegen_language_macros::compile!(Language( FieldDelimiters(open = open_paren, close = close_paren) ), fields = ( - open_paren = Required(Terminal([OpenParen])), - paths = Required(NonTerminal(OverridePaths)), - close_paren = Required(Terminal([CloseParen])) + open_paren = Required(OpenParen), + paths = Required(OverridePaths), + close_paren = Required(CloseParen) ) ), Separated( @@ -2402,8 +2419,8 @@ codegen_language_macros::compile!(Language( Struct( name = ReturnsDeclaration, fields = ( - returns_keyword = Required(Terminal([ReturnsKeyword])), - variables = Required(NonTerminal(ParametersDeclaration)) + returns_keyword = Required(ReturnsKeyword), + variables = Required(ParametersDeclaration) ) ), Enum( @@ -2417,10 +2434,10 @@ codegen_language_macros::compile!(Language( name = ConstructorDefinition, enabled = From("0.4.22"), fields = ( - constructor_keyword = Required(Terminal([ConstructorKeyword])), - parameters = Required(NonTerminal(ParametersDeclaration)), - attributes = Optional(kind = NonTerminal(ConstructorAttributes)), - body = Required(NonTerminal(Block)) + constructor_keyword = Required(ConstructorKeyword), + parameters = Required(ParametersDeclaration), + attributes = Optional(reference = ConstructorAttributes), + body = Required(Block) ) ), Repeated( @@ -2442,11 +2459,10 @@ codegen_language_macros::compile!(Language( name = UnnamedFunctionDefinition, enabled = Till("0.6.0"), fields = ( - function_keyword = Required(Terminal([FunctionKeyword])), - parameters = Required(NonTerminal(ParametersDeclaration)), - attributes = - Optional(kind = NonTerminal(UnnamedFunctionAttributes)), - body = Required(NonTerminal(FunctionBody)) + function_keyword = Required(FunctionKeyword), + parameters = Required(ParametersDeclaration), + attributes = Optional(reference = UnnamedFunctionAttributes), + body = Required(FunctionBody) ) ), Repeated( @@ -2470,12 +2486,11 @@ codegen_language_macros::compile!(Language( name = FallbackFunctionDefinition, enabled = From("0.6.0"), fields = ( - fallback_keyword = Required(Terminal([FallbackKeyword])), - parameters = Required(NonTerminal(ParametersDeclaration)), - attributes = - Optional(kind = NonTerminal(FallbackFunctionAttributes)), - returns = Optional(kind = NonTerminal(ReturnsDeclaration)), - body = Required(NonTerminal(FunctionBody)) + fallback_keyword = Required(FallbackKeyword), + parameters = Required(ParametersDeclaration), + attributes = Optional(reference = FallbackFunctionAttributes), + returns = Optional(reference = ReturnsDeclaration), + body = Required(FunctionBody) ) ), Repeated( @@ -2500,11 +2515,10 @@ codegen_language_macros::compile!(Language( name = ReceiveFunctionDefinition, enabled = From("0.6.0"), fields = ( - receive_keyword = Required(Terminal([ReceiveKeyword])), - parameters = Required(NonTerminal(ParametersDeclaration)), - attributes = - Optional(kind = NonTerminal(ReceiveFunctionAttributes)), - body = Required(NonTerminal(FunctionBody)) + receive_keyword = Required(ReceiveKeyword), + parameters = Required(ParametersDeclaration), + attributes = Optional(reference = ReceiveFunctionAttributes), + body = Required(FunctionBody) ) ), Repeated( @@ -2531,11 +2545,11 @@ codegen_language_macros::compile!(Language( Struct( name = ModifierDefinition, fields = ( - modifier_keyword = Required(Terminal([ModifierKeyword])), - name = Required(Terminal([Identifier])), - parameters = Optional(kind = NonTerminal(ParametersDeclaration)), - attributes = Optional(kind = NonTerminal(ModifierAttributes)), - body = Required(NonTerminal(FunctionBody)) + modifier_keyword = Required(ModifierKeyword), + name = Required(Identifier), + parameters = Optional(reference = ParametersDeclaration), + attributes = Optional(reference = ModifierAttributes), + body = Required(FunctionBody) ) ), Repeated(name = ModifierAttributes, repeated = ModifierAttribute), @@ -2553,8 +2567,8 @@ codegen_language_macros::compile!(Language( Struct( name = ModifierInvocation, fields = ( - name = Required(NonTerminal(IdentifierPath)), - arguments = Optional(kind = NonTerminal(ArgumentsDeclaration)) + name = Required(IdentifierPath), + arguments = Optional(reference = ArgumentsDeclaration) ) ) ] @@ -2566,11 +2580,11 @@ codegen_language_macros::compile!(Language( name = EventDefinition, error_recovery = FieldsErrorRecovery(terminator = semicolon), fields = ( - event_keyword = Required(Terminal([EventKeyword])), - name = Required(Terminal([Identifier])), - parameters = Required(NonTerminal(EventParametersDeclaration)), - anonymous_keyword = Optional(kind = Terminal([AnonymousKeyword])), - semicolon = Required(Terminal([Semicolon])) + event_keyword = Required(EventKeyword), + name = Required(Identifier), + parameters = Required(EventParametersDeclaration), + anonymous_keyword = Optional(reference = AnonymousKeyword), + semicolon = Required(Semicolon) ) ), Struct( @@ -2580,9 +2594,9 @@ codegen_language_macros::compile!(Language( FieldDelimiters(open = open_paren, close = close_paren) ), fields = ( - open_paren = Required(Terminal([OpenParen])), - parameters = Optional(kind = NonTerminal(EventParameters)), - close_paren = Required(Terminal([CloseParen])) + open_paren = Required(OpenParen), + parameters = Optional(reference = EventParameters), + close_paren = Required(CloseParen) ) ), Separated( @@ -2593,9 +2607,9 @@ codegen_language_macros::compile!(Language( Struct( name = EventParameter, fields = ( - type_name = Required(NonTerminal(TypeName)), - indexed_keyword = Optional(kind = Terminal([IndexedKeyword])), - name = Optional(kind = Terminal([Identifier])) + type_name = Required(TypeName), + indexed_keyword = Optional(reference = IndexedKeyword), + name = Optional(reference = Identifier) ) ) ] @@ -2607,11 +2621,11 @@ codegen_language_macros::compile!(Language( enabled = From("0.8.8"), error_recovery = FieldsErrorRecovery(terminator = semicolon), fields = ( - type_keyword = Required(Terminal([TypeKeyword])), - name = Required(Terminal([Identifier])), - is_keyword = Required(Terminal([IsKeyword])), - value_type = Required(NonTerminal(ElementaryType)), - semicolon = Required(Terminal([Semicolon])) + type_keyword = Required(TypeKeyword), + name = Required(Identifier), + is_keyword = Required(IsKeyword), + value_type = Required(ElementaryType), + semicolon = Required(Semicolon) ) )] ), @@ -2623,10 +2637,10 @@ codegen_language_macros::compile!(Language( enabled = From("0.8.4"), error_recovery = FieldsErrorRecovery(terminator = semicolon), fields = ( - error_keyword = Required(Terminal([ErrorKeyword])), - name = Required(Terminal([Identifier])), - members = Required(NonTerminal(ErrorParametersDeclaration)), - semicolon = Required(Terminal([Semicolon])) + error_keyword = Required(ErrorKeyword), + name = Required(Identifier), + members = Required(ErrorParametersDeclaration), + semicolon = Required(Semicolon) ) ), Struct( @@ -2637,9 +2651,9 @@ codegen_language_macros::compile!(Language( FieldDelimiters(open = open_paren, close = close_paren) ), fields = ( - open_paren = Required(Terminal([OpenParen])), - parameters = Optional(kind = NonTerminal(ErrorParameters)), - close_paren = Required(Terminal([CloseParen])) + open_paren = Required(OpenParen), + parameters = Optional(reference = ErrorParameters), + close_paren = Required(CloseParen) ) ), Separated( @@ -2652,8 +2666,8 @@ codegen_language_macros::compile!(Language( name = ErrorParameter, enabled = From("0.8.4"), fields = ( - type_name = Required(NonTerminal(TypeName)), - name = Optional(kind = Terminal([Identifier])) + type_name = Required(TypeName), + name = Optional(reference = Identifier) ) ) ] @@ -2680,26 +2694,26 @@ codegen_language_macros::compile!(Language( ) ), fields = ( - open_bracket = Required(Terminal([OpenBracket])), - index = Optional(kind = NonTerminal(Expression)), - close_bracket = Required(Terminal([CloseBracket])) + open_bracket = Required(OpenBracket), + index = Optional(reference = Expression), + close_bracket = Required(CloseBracket) ) )] )], primary_expressions = [ - PrimaryExpression(expression = FunctionType), - PrimaryExpression(expression = MappingType), - PrimaryExpression(expression = ElementaryType), - PrimaryExpression(expression = IdentifierPath) + PrimaryExpression(reference = FunctionType), + PrimaryExpression(reference = MappingType), + PrimaryExpression(reference = ElementaryType), + PrimaryExpression(reference = IdentifierPath) ] ), Struct( name = FunctionType, fields = ( - function_keyword = Required(Terminal([FunctionKeyword])), - parameters = Required(NonTerminal(ParametersDeclaration)), - attributes = Optional(kind = NonTerminal(FunctionTypeAttributes)), - returns = Optional(kind = NonTerminal(ReturnsDeclaration)) + function_keyword = Required(FunctionKeyword), + parameters = Required(ParametersDeclaration), + attributes = Optional(reference = FunctionTypeAttributes), + returns = Optional(reference = ReturnsDeclaration) ) ), Repeated( @@ -2725,22 +2739,19 @@ codegen_language_macros::compile!(Language( FieldDelimiters(open = open_paren, close = close_paren) ), fields = ( - mapping_keyword = Required(Terminal([MappingKeyword])), - open_paren = Required(Terminal([OpenParen])), - key_type = Required(NonTerminal(MappingKey)), - equal_greater_than = Required(Terminal([EqualGreaterThan])), - value_type = Required(NonTerminal(MappingValue)), - close_paren = Required(Terminal([CloseParen])) + mapping_keyword = Required(MappingKeyword), + open_paren = Required(OpenParen), + key_type = Required(MappingKey), + equal_greater_than = Required(EqualGreaterThan), + value_type = Required(MappingValue), + close_paren = Required(CloseParen) ) ), Struct( name = MappingKey, fields = ( - key_type = Required(NonTerminal(MappingKeyType)), - name = Optional( - kind = Terminal([Identifier]), - enabled = From("0.8.18") - ) + key_type = Required(MappingKeyType), + name = Optional(reference = Identifier, enabled = From("0.8.18")) ) ), Enum( @@ -2753,11 +2764,8 @@ codegen_language_macros::compile!(Language( Struct( name = MappingValue, fields = ( - type_name = Required(NonTerminal(TypeName)), - name = Optional( - kind = Terminal([Identifier]), - enabled = From("0.8.18") - ) + type_name = Required(TypeName), + name = Optional(reference = Identifier, enabled = From("0.8.18")) ) ) ] @@ -2793,8 +2801,8 @@ codegen_language_macros::compile!(Language( Struct( name = AddressType, fields = ( - address_keyword = Required(Terminal([AddressKeyword])), - payable_keyword = Optional(kind = Terminal([PayableKeyword])) + address_keyword = Required(AddressKeyword), + payable_keyword = Optional(reference = PayableKeyword) ) ) ] @@ -2814,9 +2822,9 @@ codegen_language_macros::compile!(Language( FieldDelimiters(open = open_brace, close = close_brace) ), fields = ( - open_brace = Required(Terminal([OpenBrace])), - statements = Optional(kind = NonTerminal(Statements)), - close_brace = Required(Terminal([CloseBrace])) + open_brace = Required(OpenBrace), + statements = Optional(reference = Statements), + close_brace = Required(CloseBrace) ) ), Repeated(name = Statements, repeated = Statement), @@ -2875,25 +2883,25 @@ codegen_language_macros::compile!(Language( name = UncheckedBlock, enabled = From("0.8.0"), fields = ( - unchecked_keyword = Required(Terminal([UncheckedKeyword])), - block = Required(NonTerminal(Block)) + unchecked_keyword = Required(UncheckedKeyword), + block = Required(Block) ) ), Struct( name = ExpressionStatement, error_recovery = FieldsErrorRecovery(terminator = semicolon), fields = ( - expression = Required(NonTerminal(Expression)), - semicolon = Required(Terminal([Semicolon])) + expression = Required(Expression), + semicolon = Required(Semicolon) ) ), Struct( name = AssemblyStatement, fields = ( - assembly_keyword = Required(Terminal([AssemblyKeyword])), - label = Optional(kind = Terminal([AsciiStringLiteral])), - flags = Optional(kind = NonTerminal(AssemblyFlagsDeclaration)), - body = Required(NonTerminal(YulBlock)) + assembly_keyword = Required(AssemblyKeyword), + label = Optional(reference = AsciiStringLiteral), + flags = Optional(reference = AssemblyFlagsDeclaration), + body = Required(YulBlock) ) ), Struct( @@ -2903,9 +2911,9 @@ codegen_language_macros::compile!(Language( FieldDelimiters(open = open_paren, close = close_paren) ), fields = ( - open_paren = Required(Terminal([OpenParen])), - flags = Required(NonTerminal(AssemblyFlags)), - close_paren = Required(Terminal([CloseParen])) + open_paren = Required(OpenParen), + flags = Required(AssemblyFlags), + close_paren = Required(CloseParen) ) ), Separated( @@ -2926,12 +2934,12 @@ codegen_language_macros::compile!(Language( FieldDelimiters(open = open_paren, close = close_paren) ), fields = ( - open_paren = Required(Terminal([OpenParen])), - elements = Required(NonTerminal(TupleDeconstructionElements)), - close_paren = Required(Terminal([CloseParen])), - equal = Required(Terminal([Equal])), - expression = Required(NonTerminal(Expression)), - semicolon = Required(Terminal([Semicolon])) + open_paren = Required(OpenParen), + elements = Required(TupleDeconstructionElements), + close_paren = Required(CloseParen), + equal = Required(Equal), + expression = Required(Expression), + semicolon = Required(Semicolon) ) ), Separated( @@ -2941,7 +2949,7 @@ codegen_language_macros::compile!(Language( ), Struct( name = TupleDeconstructionElement, - fields = (member = Optional(kind = NonTerminal(TupleMember))) + fields = (member = Optional(reference = TupleMember)) ), Enum( name = TupleMember, @@ -2953,27 +2961,27 @@ codegen_language_macros::compile!(Language( Struct( name = TypedTupleMember, fields = ( - type_name = Required(NonTerminal(TypeName)), - storage_location = Optional(kind = NonTerminal(StorageLocation)), - name = Required(Terminal([Identifier])) + type_name = Required(TypeName), + storage_location = Optional(reference = StorageLocation), + name = Required(Identifier) ) ), Struct( name = UntypedTupleMember, fields = ( - storage_location = Optional(kind = NonTerminal(StorageLocation)), - name = Required(Terminal([Identifier])) + storage_location = Optional(reference = StorageLocation), + name = Required(Identifier) ) ), Struct( name = VariableDeclarationStatement, error_recovery = FieldsErrorRecovery(terminator = semicolon), fields = ( - variable_type = Required(NonTerminal(VariableDeclarationType)), - storage_location = Optional(kind = NonTerminal(StorageLocation)), - name = Required(Terminal([Identifier])), - value = Optional(kind = NonTerminal(VariableDeclarationValue)), - semicolon = Required(Terminal([Semicolon])) + variable_type = Required(VariableDeclarationType), + storage_location = Optional(reference = StorageLocation), + name = Required(Identifier), + value = Optional(reference = VariableDeclarationValue), + semicolon = Required(Semicolon) ) ), Enum( @@ -2989,10 +2997,7 @@ codegen_language_macros::compile!(Language( ), Struct( name = VariableDeclarationValue, - fields = ( - equal = Required(Terminal([Equal])), - expression = Required(NonTerminal(Expression)) - ) + fields = (equal = Required(Equal), expression = Required(Expression)) ), Enum( name = StorageLocation, @@ -3018,19 +3023,19 @@ codegen_language_macros::compile!(Language( FieldDelimiters(open = open_paren, close = close_paren) ), fields = ( - if_keyword = Required(Terminal([IfKeyword])), - open_paren = Required(Terminal([OpenParen])), - condition = Required(NonTerminal(Expression)), - close_paren = Required(Terminal([CloseParen])), - body = Required(NonTerminal(Statement)), - else_branch = Optional(kind = NonTerminal(ElseBranch)) + if_keyword = Required(IfKeyword), + open_paren = Required(OpenParen), + condition = Required(Expression), + close_paren = Required(CloseParen), + body = Required(Statement), + else_branch = Optional(reference = ElseBranch) ) ), Struct( name = ElseBranch, fields = ( - else_keyword = Required(Terminal([ElseKeyword])), - body = Required(NonTerminal(Statement)) + else_keyword = Required(ElseKeyword), + body = Required(Statement) ) ), Struct( @@ -3040,13 +3045,13 @@ codegen_language_macros::compile!(Language( FieldDelimiters(open = open_paren, close = close_paren) ), fields = ( - for_keyword = Required(Terminal([ForKeyword])), - open_paren = Required(Terminal([OpenParen])), - initialization = Required(NonTerminal(ForStatementInitialization)), - condition = Required(NonTerminal(ForStatementCondition)), - iterator = Optional(kind = NonTerminal(Expression)), - close_paren = Required(Terminal([CloseParen])), - body = Required(NonTerminal(Statement)) + for_keyword = Required(ForKeyword), + open_paren = Required(OpenParen), + initialization = Required(ForStatementInitialization), + condition = Required(ForStatementCondition), + iterator = Optional(reference = Expression), + close_paren = Required(CloseParen), + body = Required(Statement) ) ), Enum( @@ -3078,11 +3083,11 @@ codegen_language_macros::compile!(Language( FieldDelimiters(open = open_paren, close = close_paren) ), fields = ( - while_keyword = Required(Terminal([WhileKeyword])), - open_paren = Required(Terminal([OpenParen])), - condition = Required(NonTerminal(Expression)), - close_paren = Required(Terminal([CloseParen])), - body = Required(NonTerminal(Statement)) + while_keyword = Required(WhileKeyword), + open_paren = Required(OpenParen), + condition = Required(Expression), + close_paren = Required(CloseParen), + body = Required(Statement) ) ), Struct( @@ -3093,38 +3098,38 @@ codegen_language_macros::compile!(Language( FieldDelimiters(open = open_paren, close = close_paren) ), fields = ( - do_keyword = Required(Terminal([DoKeyword])), - body = Required(NonTerminal(Statement)), - while_keyword = Required(Terminal([WhileKeyword])), - open_paren = Required(Terminal([OpenParen])), - condition = Required(NonTerminal(Expression)), - close_paren = Required(Terminal([CloseParen])), - semicolon = Required(Terminal([Semicolon])) + do_keyword = Required(DoKeyword), + body = Required(Statement), + while_keyword = Required(WhileKeyword), + open_paren = Required(OpenParen), + condition = Required(Expression), + close_paren = Required(CloseParen), + semicolon = Required(Semicolon) ) ), Struct( name = ContinueStatement, error_recovery = FieldsErrorRecovery(terminator = semicolon), fields = ( - continue_keyword = Required(Terminal([ContinueKeyword])), - semicolon = Required(Terminal([Semicolon])) + continue_keyword = Required(ContinueKeyword), + semicolon = Required(Semicolon) ) ), Struct( name = BreakStatement, error_recovery = FieldsErrorRecovery(terminator = semicolon), fields = ( - break_keyword = Required(Terminal([BreakKeyword])), - semicolon = Required(Terminal([Semicolon])) + break_keyword = Required(BreakKeyword), + semicolon = Required(Semicolon) ) ), Struct( name = ReturnStatement, error_recovery = FieldsErrorRecovery(terminator = semicolon), fields = ( - return_keyword = Required(Terminal([ReturnKeyword])), - expression = Optional(kind = NonTerminal(Expression)), - semicolon = Required(Terminal([Semicolon])) + return_keyword = Required(ReturnKeyword), + expression = Optional(reference = Expression), + semicolon = Required(Semicolon) ) ), Struct( @@ -3132,19 +3137,19 @@ codegen_language_macros::compile!(Language( enabled = From("0.4.21"), error_recovery = FieldsErrorRecovery(terminator = semicolon), fields = ( - emit_keyword = Required(Terminal([EmitKeyword])), - event = Required(NonTerminal(IdentifierPath)), - arguments = Required(NonTerminal(ArgumentsDeclaration)), - semicolon = Required(Terminal([Semicolon])) + emit_keyword = Required(EmitKeyword), + event = Required(IdentifierPath), + arguments = Required(ArgumentsDeclaration), + semicolon = Required(Semicolon) ) ), Struct( name = DeleteStatement, error_recovery = FieldsErrorRecovery(terminator = semicolon), fields = ( - delete_keyword = Required(Terminal([DeleteKeyword])), - expression = Required(NonTerminal(Expression)), - semicolon = Required(Terminal([Semicolon])) + delete_keyword = Required(DeleteKeyword), + expression = Required(Expression), + semicolon = Required(Semicolon) ) ) ] @@ -3156,11 +3161,11 @@ codegen_language_macros::compile!(Language( name = TryStatement, enabled = From("0.6.0"), fields = ( - try_keyword = Required(Terminal([TryKeyword])), - expression = Required(NonTerminal(Expression)), - returns = Optional(kind = NonTerminal(ReturnsDeclaration)), - body = Required(NonTerminal(Block)), - catch_clauses = Required(NonTerminal(CatchClauses)) + try_keyword = Required(TryKeyword), + expression = Required(Expression), + returns = Optional(reference = ReturnsDeclaration), + body = Required(Block), + catch_clauses = Required(CatchClauses) ) ), Repeated( @@ -3172,17 +3177,17 @@ codegen_language_macros::compile!(Language( name = CatchClause, enabled = From("0.6.0"), fields = ( - catch_keyword = Required(Terminal([CatchKeyword])), - error = Optional(kind = NonTerminal(CatchClauseError)), - body = Required(NonTerminal(Block)) + catch_keyword = Required(CatchKeyword), + error = Optional(reference = CatchClauseError), + body = Required(Block) ) ), Struct( name = CatchClauseError, enabled = From("0.6.0"), fields = ( - name = Optional(kind = Terminal([Identifier])), - parameters = Required(NonTerminal(ParametersDeclaration)) + name = Optional(reference = Identifier), + parameters = Required(ParametersDeclaration) ) ), Struct( @@ -3190,10 +3195,10 @@ codegen_language_macros::compile!(Language( enabled = From("0.8.4"), error_recovery = FieldsErrorRecovery(terminator = semicolon), fields = ( - revert_keyword = Required(Terminal([RevertKeyword])), - error = Optional(kind = NonTerminal(IdentifierPath)), - arguments = Required(NonTerminal(ArgumentsDeclaration)), - semicolon = Required(Terminal([Semicolon])) + revert_keyword = Required(RevertKeyword), + error = Optional(reference = IdentifierPath), + arguments = Required(ArgumentsDeclaration), + semicolon = Required(Semicolon) ) ), Struct( @@ -3201,8 +3206,8 @@ codegen_language_macros::compile!(Language( enabled = Till("0.5.0"), error_recovery = FieldsErrorRecovery(terminator = semicolon), fields = ( - throw_keyword = Required(Terminal([ThrowKeyword])), - semicolon = Required(Terminal([Semicolon])) + throw_keyword = Required(ThrowKeyword), + semicolon = Required(Semicolon) ) ) ] @@ -3221,23 +3226,58 @@ codegen_language_macros::compile!(Language( PrecedenceExpression( name = AssignmentExpression, rule_name = BinaryExpression, - operators = [PrecedenceOperator( - model = BinaryLeftAssociative, - fields = (operator = Required(Terminal([ - Equal, - BarEqual, - PlusEqual, - MinusEqual, - CaretEqual, - SlashEqual, - PercentEqual, - AsteriskEqual, - AmpersandEqual, - LessThanLessThanEqual, - GreaterThanGreaterThanEqual, - GreaterThanGreaterThanGreaterThanEqual - ]))) - )] + operators = [ + PrecedenceOperator( + model = BinaryLeftAssociative, + fields = (operator = Required(Equal)) + ), + PrecedenceOperator( + model = BinaryLeftAssociative, + fields = (operator = Required(BarEqual)) + ), + PrecedenceOperator( + model = BinaryLeftAssociative, + fields = (operator = Required(PlusEqual)) + ), + PrecedenceOperator( + model = BinaryLeftAssociative, + fields = (operator = Required(MinusEqual)) + ), + PrecedenceOperator( + model = BinaryLeftAssociative, + fields = (operator = Required(CaretEqual)) + ), + PrecedenceOperator( + model = BinaryLeftAssociative, + fields = (operator = Required(SlashEqual)) + ), + PrecedenceOperator( + model = BinaryLeftAssociative, + fields = (operator = Required(PercentEqual)) + ), + PrecedenceOperator( + model = BinaryLeftAssociative, + fields = (operator = Required(AsteriskEqual)) + ), + PrecedenceOperator( + model = BinaryLeftAssociative, + fields = (operator = Required(AmpersandEqual)) + ), + PrecedenceOperator( + model = BinaryLeftAssociative, + fields = (operator = Required(LessThanLessThanEqual)) + ), + PrecedenceOperator( + model = BinaryLeftAssociative, + fields = + (operator = Required(GreaterThanGreaterThanEqual)) + ), + PrecedenceOperator( + model = BinaryLeftAssociative, + fields = (operator = + Required(GreaterThanGreaterThanGreaterThanEqual)) + ) + ] ), PrecedenceExpression( name = ConditionalExpression, @@ -3245,10 +3285,10 @@ codegen_language_macros::compile!(Language( operators = [PrecedenceOperator( model = Postfix, fields = ( - question_mark = Required(Terminal([QuestionMark])), - true_expression = Required(NonTerminal(Expression)), - colon = Required(Terminal([Colon])), - false_expression = Required(NonTerminal(Expression)) + question_mark = Required(QuestionMark), + true_expression = Required(Expression), + colon = Required(Colon), + false_expression = Required(Expression) ) )] ), @@ -3257,7 +3297,7 @@ codegen_language_macros::compile!(Language( rule_name = BinaryExpression, operators = [PrecedenceOperator( model = BinaryLeftAssociative, - fields = (operator = Required(Terminal([BarBar]))) + fields = (operator = Required(BarBar)) )] ), PrecedenceExpression( @@ -3265,38 +3305,51 @@ codegen_language_macros::compile!(Language( rule_name = BinaryExpression, operators = [PrecedenceOperator( model = BinaryLeftAssociative, - fields = - (operator = Required(Terminal([AmpersandAmpersand]))) + fields = (operator = Required(AmpersandAmpersand)) )] ), PrecedenceExpression( name = EqualityExpression, rule_name = BinaryExpression, - operators = [PrecedenceOperator( - model = BinaryLeftAssociative, - fields = (operator = - Required(Terminal([EqualEqual, BangEqual]))) - )] + operators = [ + PrecedenceOperator( + model = BinaryLeftAssociative, + fields = (operator = Required(EqualEqual)) + ), + PrecedenceOperator( + model = BinaryLeftAssociative, + fields = (operator = Required(BangEqual)) + ) + ] ), PrecedenceExpression( name = ComparisonExpression, rule_name = BinaryExpression, - operators = [PrecedenceOperator( - model = BinaryLeftAssociative, - fields = (operator = Required(Terminal([ - LessThan, - GreaterThan, - LessThanEqual, - GreaterThanEqual - ]))) - )] + operators = [ + PrecedenceOperator( + model = BinaryLeftAssociative, + fields = (operator = Required(LessThan)) + ), + PrecedenceOperator( + model = BinaryLeftAssociative, + fields = (operator = Required(GreaterThan)) + ), + PrecedenceOperator( + model = BinaryLeftAssociative, + fields = (operator = Required(LessThanEqual)) + ), + PrecedenceOperator( + model = BinaryLeftAssociative, + fields = (operator = Required(GreaterThanEqual)) + ) + ] ), PrecedenceExpression( name = BitwiseOrExpression, rule_name = BinaryExpression, operators = [PrecedenceOperator( model = BinaryLeftAssociative, - fields = (operator = Required(Terminal([Bar]))) + fields = (operator = Required(Bar)) )] ), PrecedenceExpression( @@ -3304,7 +3357,7 @@ codegen_language_macros::compile!(Language( rule_name = BinaryExpression, operators = [PrecedenceOperator( model = BinaryLeftAssociative, - fields = (operator = Required(Terminal([Caret]))) + fields = (operator = Required(Caret)) )] ), PrecedenceExpression( @@ -3312,37 +3365,59 @@ codegen_language_macros::compile!(Language( rule_name = BinaryExpression, operators = [PrecedenceOperator( model = BinaryLeftAssociative, - fields = (operator = Required(Terminal([Ampersand]))) + fields = (operator = Required(Ampersand)) )] ), PrecedenceExpression( name = ShiftExpression, rule_name = BinaryExpression, - operators = [PrecedenceOperator( - model = BinaryLeftAssociative, - fields = (operator = Required(Terminal([ - LessThanLessThan, - GreaterThanGreaterThan, - GreaterThanGreaterThanGreaterThan - ]))) - )] + operators = [ + PrecedenceOperator( + model = BinaryLeftAssociative, + fields = (operator = Required(LessThanLessThan)) + ), + PrecedenceOperator( + model = BinaryLeftAssociative, + fields = (operator = Required(GreaterThanGreaterThan)) + ), + PrecedenceOperator( + model = BinaryLeftAssociative, + fields = (operator = + Required(GreaterThanGreaterThanGreaterThan)) + ) + ] ), PrecedenceExpression( name = AdditiveExpression, rule_name = BinaryExpression, - operators = [PrecedenceOperator( - model = BinaryLeftAssociative, - fields = (operator = Required(Terminal([Plus, Minus]))) - )] + operators = [ + PrecedenceOperator( + model = BinaryLeftAssociative, + fields = (operator = Required(Plus)) + ), + PrecedenceOperator( + model = BinaryLeftAssociative, + fields = (operator = Required(Minus)) + ) + ] ), PrecedenceExpression( name = MultiplicativeExpression, rule_name = BinaryExpression, - operators = [PrecedenceOperator( - model = BinaryLeftAssociative, - fields = (operator = - Required(Terminal([Asterisk, Slash, Percent]))) - )] + operators = [ + PrecedenceOperator( + model = BinaryLeftAssociative, + fields = (operator = Required(Asterisk)) + ), + PrecedenceOperator( + model = BinaryLeftAssociative, + fields = (operator = Required(Slash)) + ), + PrecedenceOperator( + model = BinaryLeftAssociative, + fields = (operator = Required(Percent)) + ) + ] ), PrecedenceExpression( name = ExponentiationExpression, @@ -3352,46 +3427,58 @@ codegen_language_macros::compile!(Language( PrecedenceOperator( model = BinaryLeftAssociative, enabled = Till("0.6.0"), - fields = - (operator = Required(Terminal([AsteriskAsterisk]))) + fields = (operator = Required(AsteriskAsterisk)) ), // In '0.6.0', it became right-associative: PrecedenceOperator( model = BinaryRightAssociative, enabled = From("0.6.0"), - fields = - (operator = Required(Terminal([AsteriskAsterisk]))) + fields = (operator = Required(AsteriskAsterisk)) ) ] ), PrecedenceExpression( name = PostfixExpression, rule_name = UnaryPostfixExpression, - operators = [PrecedenceOperator( - model = Postfix, - fields = - (operator = Required(Terminal([PlusPlus, MinusMinus]))) - )] + operators = [ + PrecedenceOperator( + model = Postfix, + fields = (operator = Required(PlusPlus)) + ), + PrecedenceOperator( + model = Postfix, + fields = (operator = Required(MinusMinus)) + ) + ] ), PrecedenceExpression( name = PrefixExpression, rule_name = UnaryPrefixExpression, operators = [ - // Before '0.5.0', 'Plus' was supported: PrecedenceOperator( model = Prefix, - enabled = Till("0.5.0"), - fields = (operator = Required(Terminal([ - PlusPlus, MinusMinus, Tilde, Bang, Minus, Plus - ]))) + fields = (operator = Required(PlusPlus)) + ), + PrecedenceOperator( + model = Prefix, + fields = (operator = Required(MinusMinus)) + ), + PrecedenceOperator( + model = Prefix, + fields = (operator = Required(Tilde)) + ), + PrecedenceOperator( + model = Prefix, + fields = (operator = Required(Bang)) + ), + PrecedenceOperator( + model = Prefix, + fields = (operator = Required(Minus)) ), - // In '0.5.0', 'Plus' was removed: PrecedenceOperator( model = Prefix, - enabled = From("0.5.0"), - fields = (operator = Required(Terminal([ - PlusPlus, MinusMinus, Tilde, Bang, Minus - ]))) + enabled = Till("0.5.0"), + fields = (operator = Required(Plus)) ) ] ), @@ -3402,24 +3489,32 @@ codegen_language_macros::compile!(Language( model = Postfix, fields = ( options = Optional( - kind = NonTerminal(FunctionCallOptions), + reference = FunctionCallOptions, enabled = From("0.6.2") ), - arguments = Required(NonTerminal(ArgumentsDeclaration)) + arguments = Required(ArgumentsDeclaration) ) )] ), PrecedenceExpression( name = MemberAccessExpression, rule_name = MemberAccessExpression, - operators = [PrecedenceOperator( - model = Postfix, - fields = ( - period = Required(Terminal([Period])), - member = - Required(Terminal([Identifier, AddressKeyword])) + operators = [ + PrecedenceOperator( + model = Postfix, + fields = ( + period = Required(Period), + member = Required(Identifier) + ) + ), + PrecedenceOperator( + model = Postfix, + fields = ( + period = Required(Period), + member = Required(AddressKeyword) + ) ) - )] + ] ), PrecedenceExpression( name = IndexAccessExpression, @@ -3433,36 +3528,36 @@ codegen_language_macros::compile!(Language( ) ), fields = ( - open_bracket = Required(Terminal([OpenBracket])), - start = Optional(kind = NonTerminal(Expression)), - end = Optional(kind = NonTerminal(IndexAccessEnd)), - close_bracket = Required(Terminal([CloseBracket])) + open_bracket = Required(OpenBracket), + start = Optional(reference = Expression), + end = Optional(reference = IndexAccessEnd), + close_bracket = Required(CloseBracket) ) )] ) ], primary_expressions = [ - PrimaryExpression(expression = NewExpression), - PrimaryExpression(expression = TupleExpression), + PrimaryExpression(reference = NewExpression), + PrimaryExpression(reference = TupleExpression), PrimaryExpression( - expression = TypeExpression, + reference = TypeExpression, enabled = From("0.5.3") ), - PrimaryExpression(expression = ArrayExpression), - PrimaryExpression(expression = HexNumberExpression), - PrimaryExpression(expression = DecimalNumberExpression), - PrimaryExpression(expression = StringExpression), - PrimaryExpression(expression = ElementaryType), - PrimaryExpression(expression = TrueKeyword), - PrimaryExpression(expression = FalseKeyword), - PrimaryExpression(expression = Identifier) + PrimaryExpression(reference = ArrayExpression), + PrimaryExpression(reference = HexNumberExpression), + PrimaryExpression(reference = DecimalNumberExpression), + PrimaryExpression(reference = StringExpression), + PrimaryExpression(reference = ElementaryType), + PrimaryExpression(reference = TrueKeyword), + PrimaryExpression(reference = FalseKeyword), + PrimaryExpression(reference = Identifier) ] ), Struct( name = IndexAccessEnd, fields = ( - colon = Required(Terminal([Colon])), - end = Optional(kind = NonTerminal(Expression)) + colon = Required(Colon), + end = Optional(reference = Expression) ) ) ] @@ -3503,9 +3598,9 @@ codegen_language_macros::compile!(Language( FieldDelimiters(open = open_paren, close = close_paren) ), fields = ( - open_paren = Required(Terminal([OpenParen])), - arguments = Optional(kind = NonTerminal(PositionalArguments)), - close_paren = Required(Terminal([CloseParen])) + open_paren = Required(OpenParen), + arguments = Optional(reference = PositionalArguments), + close_paren = Required(CloseParen) ) ), Separated( @@ -3520,9 +3615,9 @@ codegen_language_macros::compile!(Language( FieldDelimiters(open = open_paren, close = close_paren) ), fields = ( - open_paren = Required(Terminal([OpenParen])), - arguments = Optional(kind = NonTerminal(NamedArgumentGroup)), - close_paren = Required(Terminal([CloseParen])) + open_paren = Required(OpenParen), + arguments = Optional(reference = NamedArgumentGroup), + close_paren = Required(CloseParen) ) ), Repeated( @@ -3537,9 +3632,9 @@ codegen_language_macros::compile!(Language( FieldDelimiters(open = open_brace, close = close_brace) ), fields = ( - open_brace = Required(Terminal([OpenBrace])), - arguments = Optional(kind = NonTerminal(NamedArguments)), - close_brace = Required(Terminal([CloseBrace])) + open_brace = Required(OpenBrace), + arguments = Optional(reference = NamedArguments), + close_brace = Required(CloseBrace) ) ), Separated( @@ -3550,9 +3645,9 @@ codegen_language_macros::compile!(Language( Struct( name = NamedArgument, fields = ( - name = Required(Terminal([Identifier])), - colon = Required(Terminal([Colon])), - value = Required(NonTerminal(Expression)) + name = Required(Identifier), + colon = Required(Colon), + value = Required(Expression) ) ) ] @@ -3568,17 +3663,17 @@ codegen_language_macros::compile!(Language( FieldDelimiters(open = open_paren, close = close_paren) ), fields = ( - type_keyword = Required(Terminal([TypeKeyword])), - open_paren = Required(Terminal([OpenParen])), - type_name = Required(NonTerminal(TypeName)), - close_paren = Required(Terminal([CloseParen])) + type_keyword = Required(TypeKeyword), + open_paren = Required(OpenParen), + type_name = Required(TypeName), + close_paren = Required(CloseParen) ) ), Struct( name = NewExpression, fields = ( - new_keyword = Required(Terminal([NewKeyword])), - type_name = Required(NonTerminal(TypeName)) + new_keyword = Required(NewKeyword), + type_name = Required(TypeName) ) ), Struct( @@ -3588,9 +3683,9 @@ codegen_language_macros::compile!(Language( FieldDelimiters(open = open_paren, close = close_paren) ), fields = ( - open_paren = Required(Terminal([OpenParen])), - items = Required(NonTerminal(TupleValues)), - close_paren = Required(Terminal([CloseParen])) + open_paren = Required(OpenParen), + items = Required(TupleValues), + close_paren = Required(CloseParen) ) ), Separated( @@ -3600,7 +3695,7 @@ codegen_language_macros::compile!(Language( ), Struct( name = TupleValue, - fields = (expression = Optional(kind = NonTerminal(Expression))) + fields = (expression = Optional(reference = Expression)) ), Struct( name = ArrayExpression, @@ -3609,9 +3704,9 @@ codegen_language_macros::compile!(Language( FieldDelimiters(open = open_bracket, close = close_bracket) ), fields = ( - open_bracket = Required(Terminal([OpenBracket])), - items = Required(NonTerminal(ArrayValues)), - close_bracket = Required(Terminal([CloseBracket])) + open_bracket = Required(OpenBracket), + items = Required(ArrayValues), + close_bracket = Required(CloseBracket) ) ), Separated( @@ -3627,18 +3722,15 @@ codegen_language_macros::compile!(Language( Struct( name = HexNumberExpression, fields = ( - literal = Required(Terminal([HexLiteral])), - unit = Optional( - kind = NonTerminal(NumberUnit), - enabled = Till("0.5.0") - ) + literal = Required(HexLiteral), + unit = Optional(reference = NumberUnit, enabled = Till("0.5.0")) ) ), Struct( name = DecimalNumberExpression, fields = ( - literal = Required(Terminal([DecimalLiteral])), - unit = Optional(kind = NonTerminal(NumberUnit)) + literal = Required(DecimalLiteral), + unit = Optional(reference = NumberUnit) ) ), Token( @@ -4020,9 +4112,9 @@ codegen_language_macros::compile!(Language( FieldDelimiters(open = open_brace, close = close_brace) ), fields = ( - open_brace = Required(Terminal([OpenBrace])), - statements = Optional(kind = NonTerminal(YulStatements)), - close_brace = Required(Terminal([CloseBrace])) + open_brace = Required(OpenBrace), + statements = Optional(reference = YulStatements), + close_brace = Required(CloseBrace) ) ), Repeated(name = YulStatements, repeated = YulStatement), @@ -4052,11 +4144,11 @@ codegen_language_macros::compile!(Language( Struct( name = YulFunctionDefinition, fields = ( - function_keyword = Required(Terminal([YulFunctionKeyword])), - name = Required(Terminal([YulIdentifier])), - parameters = Required(NonTerminal(YulParametersDeclaration)), - returns = Optional(kind = NonTerminal(YulReturnsDeclaration)), - body = Required(NonTerminal(YulBlock)) + function_keyword = Required(YulFunctionKeyword), + name = Required(YulIdentifier), + parameters = Required(YulParametersDeclaration), + returns = Optional(reference = YulReturnsDeclaration), + body = Required(YulBlock) ) ), Struct( @@ -4066,9 +4158,9 @@ codegen_language_macros::compile!(Language( FieldDelimiters(open = open_paren, close = close_paren) ), fields = ( - open_paren = Required(Terminal([OpenParen])), - parameters = Optional(kind = NonTerminal(YulParameters)), - close_paren = Required(Terminal([CloseParen])) + open_paren = Required(OpenParen), + parameters = Optional(reference = YulParameters), + close_paren = Required(CloseParen) ) ), Separated( @@ -4079,8 +4171,8 @@ codegen_language_macros::compile!(Language( Struct( name = YulReturnsDeclaration, fields = ( - minus_greater_than = Required(Terminal([MinusGreaterThan])), - variables = Required(NonTerminal(YulReturnVariables)) + minus_greater_than = Required(MinusGreaterThan), + variables = Required(YulReturnVariables) ) ), Separated( @@ -4091,63 +4183,63 @@ codegen_language_macros::compile!(Language( Struct( name = YulVariableDeclarationStatement, fields = ( - let_keyword = Required(Terminal([YulLetKeyword])), - names = Required(NonTerminal(YulIdentifierPaths)), - value = Optional(kind = NonTerminal(YulVariableDeclarationValue)) + let_keyword = Required(YulLetKeyword), + names = Required(YulIdentifierPaths), + value = Optional(reference = YulVariableDeclarationValue) ) ), Struct( name = YulVariableDeclarationValue, fields = ( - colon_equal = Required(Terminal([ColonEqual])), - expression = Required(NonTerminal(YulExpression)) + colon_equal = Required(ColonEqual), + expression = Required(YulExpression) ) ), Struct( name = YulAssignmentStatement, fields = ( - names = Required(NonTerminal(YulIdentifierPaths)), - colon_equal = Required(Terminal([ColonEqual])), - expression = Required(NonTerminal(YulExpression)) + names = Required(YulIdentifierPaths), + colon_equal = Required(ColonEqual), + expression = Required(YulExpression) ) ), Struct( name = YulIfStatement, fields = ( - if_keyword = Required(Terminal([YulIfKeyword])), - condition = Required(NonTerminal(YulExpression)), - body = Required(NonTerminal(YulBlock)) + if_keyword = Required(YulIfKeyword), + condition = Required(YulExpression), + body = Required(YulBlock) ) ), Struct( name = YulLeaveStatement, enabled = From("0.6.0"), - fields = (leave_keyword = Required(Terminal([YulLeaveKeyword]))) + fields = (leave_keyword = Required(YulLeaveKeyword)) ), Struct( name = YulBreakStatement, - fields = (break_keyword = Required(Terminal([YulBreakKeyword]))) + fields = (break_keyword = Required(YulBreakKeyword)) ), Struct( name = YulContinueStatement, - fields = (continue_keyword = Required(Terminal([YulContinueKeyword]))) + fields = (continue_keyword = Required(YulContinueKeyword)) ), Struct( name = YulForStatement, fields = ( - for_keyword = Required(Terminal([YulForKeyword])), - initialization = Required(NonTerminal(YulBlock)), - condition = Required(NonTerminal(YulExpression)), - iterator = Required(NonTerminal(YulBlock)), - body = Required(NonTerminal(YulBlock)) + for_keyword = Required(YulForKeyword), + initialization = Required(YulBlock), + condition = Required(YulExpression), + iterator = Required(YulBlock), + body = Required(YulBlock) ) ), Struct( name = YulSwitchStatement, fields = ( - switch_keyword = Required(Terminal([YulSwitchKeyword])), - expression = Required(NonTerminal(YulExpression)), - cases = Required(NonTerminal(YulSwitchCases)) + switch_keyword = Required(YulSwitchKeyword), + expression = Required(YulExpression), + cases = Required(YulSwitchCases) ) ), Repeated(name = YulSwitchCases, repeated = YulSwitchCase), @@ -4161,16 +4253,16 @@ codegen_language_macros::compile!(Language( Struct( name = YulDefaultCase, fields = ( - default_keyword = Required(Terminal([YulDefaultKeyword])), - body = Required(NonTerminal(YulBlock)) + default_keyword = Required(YulDefaultKeyword), + body = Required(YulBlock) ) ), Struct( name = YulValueCase, fields = ( - case_keyword = Required(Terminal([YulCaseKeyword])), - value = Required(NonTerminal(YulLiteral)), - body = Required(NonTerminal(YulBlock)) + case_keyword = Required(YulCaseKeyword), + value = Required(YulLiteral), + body = Required(YulBlock) ) ) ] @@ -4191,15 +4283,15 @@ codegen_language_macros::compile!(Language( FieldDelimiters(open = open_paren, close = close_paren) ), fields = ( - open_paren = Required(Terminal([OpenParen])), - arguments = Optional(kind = NonTerminal(YulArguments)), - close_paren = Required(Terminal([CloseParen])) + open_paren = Required(OpenParen), + arguments = Optional(reference = YulArguments), + close_paren = Required(CloseParen) ) )] )], primary_expressions = [ - PrimaryExpression(expression = YulLiteral), - PrimaryExpression(expression = YulIdentifierPath) + PrimaryExpression(reference = YulLiteral), + PrimaryExpression(reference = YulIdentifierPath) ] ), Separated( diff --git a/crates/solidity/inputs/language/src/grammar.rs b/crates/solidity/inputs/language/src/grammar.rs index 764ac6209e..7fb08538ec 100644 --- a/crates/solidity/inputs/language/src/grammar.rs +++ b/crates/solidity/inputs/language/src/grammar.rs @@ -61,18 +61,15 @@ impl GrammarConstructorDslV2 for Grammar { ( Identifier::from("members"), model::Field::Optional { - kind: model::FieldKind::NonTerminal { - item: Identifier::from("SourceUnitMembers"), - }, + reference: Identifier::from("SourceUnitMembers"), + enabled: None, }, ), ( Identifier::from("eof_trivia"), model::Field::Optional { - kind: model::FieldKind::NonTerminal { - item: Identifier::from("EndOfFileTrivia"), - }, + reference: Identifier::from("EndOfFileTrivia"), enabled: None, }, ), @@ -592,30 +589,14 @@ fn resolve_trivia(parser: model::TriviaParser, ctx: &mut ResolveCtx) -> ParserDe fn resolve_field(field: model::Field, ctx: &mut ResolveCtx) -> ParserDefinitionNode { match field { - model::Field::Required { kind } => resolve_field_kind(kind, ctx), - model::Field::Optional { kind, enabled } => ParserDefinitionNode::Optional(Box::new( - resolve_field_kind(kind, ctx).versioned(enabled), - )), - } -} - -fn resolve_field_kind(kind: model::FieldKind, ctx: &mut ResolveCtx) -> ParserDefinitionNode { - match kind { - model::FieldKind::NonTerminal { item } => { - resolve_grammar_element(&item, ctx).into_parser_def_node() - } - model::FieldKind::Terminal { items } => { - let refs: Vec<_> = items - .iter() - .map(|ident| resolve_grammar_element(ident, ctx).into_parser_def_node()) - .collect(); - - match refs.len() { - 0 => panic!("Field has no definitions"), - 1 => refs.into_iter().next().unwrap(), - _ => ParserDefinitionNode::Choice(refs), - } + model::Field::Required { reference } => { + resolve_grammar_element(&reference, ctx).into_parser_def_node() } + model::Field::Optional { reference, enabled } => ParserDefinitionNode::Optional(Box::new( + resolve_grammar_element(&reference, ctx) + .into_parser_def_node() + .versioned(enabled), + )), } } @@ -751,7 +732,7 @@ fn resolve_precedence( .primary_expressions .into_iter() .map(|prim| { - resolve_grammar_element(&prim.expression, ctx) + resolve_grammar_element(&prim.reference, ctx) .into_parser_def_node() .versioned(prim.enabled) }) diff --git a/crates/solidity/outputs/cargo/crate/src/generated/language.rs b/crates/solidity/outputs/cargo/crate/src/generated/language.rs index c889122236..722029cf75 100644 --- a/crates/solidity/outputs/cargo/crate/src/generated/language.rs +++ b/crates/solidity/outputs/cargo/crate/src/generated/language.rs @@ -1327,432 +1327,1523 @@ impl Language { }), ) }; - let parse_conditional_expression = |input: &mut ParserContext| { - PrecedenceHelper::to_postfix_operator( - RuleKind::ConditionalExpression, - 3u8, - SequenceHelper::run(|mut seq| { - seq.elem(self.parse_token_with_trivia::( - input, - TokenKind::QuestionMark, - ))?; - seq.elem(self.expression(input))?; - seq.elem(self.parse_token_with_trivia::( - input, - TokenKind::Colon, - ))?; - seq.elem(self.expression(input))?; - seq.finish() - }), - ) - }; - let parse_or_expression = |input: &mut ParserContext| { - PrecedenceHelper::to_binary_operator( - RuleKind::BinaryExpression, - 5u8, - 5u8 + 1, - self.parse_token_with_trivia::( - input, - TokenKind::BarBar, - ), - ) - }; - let parse_and_expression = |input: &mut ParserContext| { - PrecedenceHelper::to_binary_operator( - RuleKind::BinaryExpression, - 7u8, - 7u8 + 1, - self.parse_token_with_trivia::( - input, - TokenKind::AmpersandAmpersand, - ), - ) - }; - let parse_equality_expression = |input: &mut ParserContext| { + let parse_assignment_expression = |input: &mut ParserContext| { PrecedenceHelper::to_binary_operator( RuleKind::BinaryExpression, - 9u8, - 9u8 + 1, + 3u8, + 3u8 + 1, ChoiceHelper::run(input, |mut choice, input| { let result = self.parse_token_with_trivia::( input, - TokenKind::EqualEqual, + TokenKind::Equal, ); choice.consider(input, result)?; let result = self.parse_token_with_trivia::( input, - TokenKind::BangEqual, + TokenKind::BarEqual, ); choice.consider(input, result)?; - choice.finish(input) - }), - ) - }; - let parse_comparison_expression = |input: &mut ParserContext| { - PrecedenceHelper::to_binary_operator( - RuleKind::BinaryExpression, - 11u8, - 11u8 + 1, - ChoiceHelper::run(input, |mut choice, input| { let result = self.parse_token_with_trivia::( input, - TokenKind::LessThan, + TokenKind::PlusEqual, ); choice.consider(input, result)?; let result = self.parse_token_with_trivia::( input, - TokenKind::GreaterThan, + TokenKind::MinusEqual, ); choice.consider(input, result)?; let result = self.parse_token_with_trivia::( input, - TokenKind::LessThanEqual, + TokenKind::CaretEqual, ); choice.consider(input, result)?; let result = self.parse_token_with_trivia::( input, - TokenKind::GreaterThanEqual, + TokenKind::SlashEqual, ); choice.consider(input, result)?; - choice.finish(input) - }), - ) - }; - let parse_bitwise_or_expression = |input: &mut ParserContext| { - PrecedenceHelper::to_binary_operator( - RuleKind::BinaryExpression, - 13u8, - 13u8 + 1, - self.parse_token_with_trivia::(input, TokenKind::Bar), - ) - }; - let parse_bitwise_xor_expression = |input: &mut ParserContext| { - PrecedenceHelper::to_binary_operator( - RuleKind::BinaryExpression, - 15u8, - 15u8 + 1, - self.parse_token_with_trivia::( - input, - TokenKind::Caret, - ), - ) - }; - let parse_bitwise_and_expression = |input: &mut ParserContext| { - PrecedenceHelper::to_binary_operator( - RuleKind::BinaryExpression, - 17u8, - 17u8 + 1, - self.parse_token_with_trivia::( - input, - TokenKind::Ampersand, - ), - ) - }; - let parse_shift_expression = |input: &mut ParserContext| { - PrecedenceHelper::to_binary_operator( - RuleKind::BinaryExpression, - 19u8, - 19u8 + 1, - ChoiceHelper::run(input, |mut choice, input| { let result = self.parse_token_with_trivia::( input, - TokenKind::LessThanLessThan, + TokenKind::PercentEqual, ); choice.consider(input, result)?; let result = self.parse_token_with_trivia::( input, - TokenKind::GreaterThanGreaterThan, + TokenKind::AsteriskEqual, ); choice.consider(input, result)?; let result = self.parse_token_with_trivia::( input, - TokenKind::GreaterThanGreaterThanGreaterThan, + TokenKind::AmpersandEqual, ); choice.consider(input, result)?; - choice.finish(input) - }), - ) - }; - let parse_additive_expression = |input: &mut ParserContext| { - PrecedenceHelper::to_binary_operator( - RuleKind::BinaryExpression, - 21u8, - 21u8 + 1, - ChoiceHelper::run(input, |mut choice, input| { let result = self.parse_token_with_trivia::( input, - TokenKind::Plus, + TokenKind::LessThanLessThanEqual, ); choice.consider(input, result)?; let result = self.parse_token_with_trivia::( input, - TokenKind::Minus, + TokenKind::GreaterThanGreaterThanEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::GreaterThanGreaterThanGreaterThanEqual, ); choice.consider(input, result)?; choice.finish(input) }), ) }; - let parse_multiplicative_expression = |input: &mut ParserContext| { + let parse_assignment_expression = |input: &mut ParserContext| { PrecedenceHelper::to_binary_operator( RuleKind::BinaryExpression, - 23u8, - 23u8 + 1, + 5u8, + 5u8 + 1, ChoiceHelper::run(input, |mut choice, input| { let result = self.parse_token_with_trivia::( input, - TokenKind::Asterisk, + TokenKind::Equal, ); choice.consider(input, result)?; let result = self.parse_token_with_trivia::( input, - TokenKind::Slash, + TokenKind::BarEqual, ); choice.consider(input, result)?; let result = self.parse_token_with_trivia::( input, - TokenKind::Percent, + TokenKind::PlusEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::MinusEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::CaretEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::SlashEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::PercentEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::AsteriskEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::AmpersandEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::LessThanLessThanEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::GreaterThanGreaterThanEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::GreaterThanGreaterThanGreaterThanEqual, ); choice.consider(input, result)?; choice.finish(input) }), ) }; - let parse_exponentiation_expression_removed_from_0_6_0 = |input: &mut ParserContext| { - PrecedenceHelper::to_binary_operator( - RuleKind::BinaryExpression, - 25u8, - 25u8 + 1, - ChoiceHelper::run(input, |mut choice, input| { - if !self.version_is_at_least_0_6_0 { - let result = self.parse_token_with_trivia::( - input, - TokenKind::AsteriskAsterisk, - ); - choice.consider(input, result)?; - } - if self.version_is_at_least_0_6_0 { - let result = self.parse_token_with_trivia::( - input, - TokenKind::AsteriskAsterisk, - ); - choice.consider(input, result)?; - } - choice.finish(input) - }), - ) - }; - let parse_exponentiation_expression_introduced_from_0_6_0 = |input: &mut ParserContext| { + let parse_assignment_expression = |input: &mut ParserContext| { PrecedenceHelper::to_binary_operator( RuleKind::BinaryExpression, - 27u8 + 1, - 27u8, - ChoiceHelper::run(input, |mut choice, input| { - if !self.version_is_at_least_0_6_0 { - let result = self.parse_token_with_trivia::( - input, - TokenKind::AsteriskAsterisk, - ); - choice.consider(input, result)?; - } - if self.version_is_at_least_0_6_0 { - let result = self.parse_token_with_trivia::( - input, - TokenKind::AsteriskAsterisk, - ); - choice.consider(input, result)?; - } - choice.finish(input) - }), - ) - }; - let parse_postfix_expression = |input: &mut ParserContext| { - PrecedenceHelper::to_postfix_operator( - RuleKind::UnaryPostfixExpression, - 29u8, + 7u8, + 7u8 + 1, ChoiceHelper::run(input, |mut choice, input| { let result = self.parse_token_with_trivia::( input, - TokenKind::PlusPlus, + TokenKind::Equal, ); choice.consider(input, result)?; let result = self.parse_token_with_trivia::( input, - TokenKind::MinusMinus, + TokenKind::BarEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::PlusEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::MinusEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::CaretEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::SlashEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::PercentEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::AsteriskEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::AmpersandEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::LessThanLessThanEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::GreaterThanGreaterThanEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::GreaterThanGreaterThanGreaterThanEqual, + ); + choice.consider(input, result)?; + choice.finish(input) + }), + ) + }; + let parse_assignment_expression = |input: &mut ParserContext| { + PrecedenceHelper::to_binary_operator( + RuleKind::BinaryExpression, + 9u8, + 9u8 + 1, + ChoiceHelper::run(input, |mut choice, input| { + let result = self.parse_token_with_trivia::( + input, + TokenKind::Equal, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::BarEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::PlusEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::MinusEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::CaretEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::SlashEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::PercentEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::AsteriskEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::AmpersandEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::LessThanLessThanEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::GreaterThanGreaterThanEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::GreaterThanGreaterThanGreaterThanEqual, + ); + choice.consider(input, result)?; + choice.finish(input) + }), + ) + }; + let parse_assignment_expression = |input: &mut ParserContext| { + PrecedenceHelper::to_binary_operator( + RuleKind::BinaryExpression, + 11u8, + 11u8 + 1, + ChoiceHelper::run(input, |mut choice, input| { + let result = self.parse_token_with_trivia::( + input, + TokenKind::Equal, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::BarEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::PlusEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::MinusEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::CaretEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::SlashEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::PercentEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::AsteriskEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::AmpersandEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::LessThanLessThanEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::GreaterThanGreaterThanEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::GreaterThanGreaterThanGreaterThanEqual, + ); + choice.consider(input, result)?; + choice.finish(input) + }), + ) + }; + let parse_assignment_expression = |input: &mut ParserContext| { + PrecedenceHelper::to_binary_operator( + RuleKind::BinaryExpression, + 13u8, + 13u8 + 1, + ChoiceHelper::run(input, |mut choice, input| { + let result = self.parse_token_with_trivia::( + input, + TokenKind::Equal, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::BarEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::PlusEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::MinusEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::CaretEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::SlashEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::PercentEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::AsteriskEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::AmpersandEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::LessThanLessThanEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::GreaterThanGreaterThanEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::GreaterThanGreaterThanGreaterThanEqual, + ); + choice.consider(input, result)?; + choice.finish(input) + }), + ) + }; + let parse_assignment_expression = |input: &mut ParserContext| { + PrecedenceHelper::to_binary_operator( + RuleKind::BinaryExpression, + 15u8, + 15u8 + 1, + ChoiceHelper::run(input, |mut choice, input| { + let result = self.parse_token_with_trivia::( + input, + TokenKind::Equal, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::BarEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::PlusEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::MinusEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::CaretEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::SlashEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::PercentEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::AsteriskEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::AmpersandEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::LessThanLessThanEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::GreaterThanGreaterThanEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::GreaterThanGreaterThanGreaterThanEqual, + ); + choice.consider(input, result)?; + choice.finish(input) + }), + ) + }; + let parse_assignment_expression = |input: &mut ParserContext| { + PrecedenceHelper::to_binary_operator( + RuleKind::BinaryExpression, + 17u8, + 17u8 + 1, + ChoiceHelper::run(input, |mut choice, input| { + let result = self.parse_token_with_trivia::( + input, + TokenKind::Equal, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::BarEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::PlusEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::MinusEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::CaretEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::SlashEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::PercentEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::AsteriskEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::AmpersandEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::LessThanLessThanEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::GreaterThanGreaterThanEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::GreaterThanGreaterThanGreaterThanEqual, + ); + choice.consider(input, result)?; + choice.finish(input) + }), + ) + }; + let parse_assignment_expression = |input: &mut ParserContext| { + PrecedenceHelper::to_binary_operator( + RuleKind::BinaryExpression, + 19u8, + 19u8 + 1, + ChoiceHelper::run(input, |mut choice, input| { + let result = self.parse_token_with_trivia::( + input, + TokenKind::Equal, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::BarEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::PlusEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::MinusEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::CaretEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::SlashEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::PercentEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::AsteriskEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::AmpersandEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::LessThanLessThanEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::GreaterThanGreaterThanEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::GreaterThanGreaterThanGreaterThanEqual, + ); + choice.consider(input, result)?; + choice.finish(input) + }), + ) + }; + let parse_assignment_expression = |input: &mut ParserContext| { + PrecedenceHelper::to_binary_operator( + RuleKind::BinaryExpression, + 21u8, + 21u8 + 1, + ChoiceHelper::run(input, |mut choice, input| { + let result = self.parse_token_with_trivia::( + input, + TokenKind::Equal, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::BarEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::PlusEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::MinusEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::CaretEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::SlashEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::PercentEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::AsteriskEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::AmpersandEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::LessThanLessThanEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::GreaterThanGreaterThanEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::GreaterThanGreaterThanGreaterThanEqual, + ); + choice.consider(input, result)?; + choice.finish(input) + }), + ) + }; + let parse_assignment_expression = |input: &mut ParserContext| { + PrecedenceHelper::to_binary_operator( + RuleKind::BinaryExpression, + 23u8, + 23u8 + 1, + ChoiceHelper::run(input, |mut choice, input| { + let result = self.parse_token_with_trivia::( + input, + TokenKind::Equal, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::BarEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::PlusEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::MinusEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::CaretEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::SlashEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::PercentEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::AsteriskEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::AmpersandEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::LessThanLessThanEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::GreaterThanGreaterThanEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::GreaterThanGreaterThanGreaterThanEqual, + ); + choice.consider(input, result)?; + choice.finish(input) + }), + ) + }; + let parse_conditional_expression = |input: &mut ParserContext| { + PrecedenceHelper::to_postfix_operator( + RuleKind::ConditionalExpression, + 25u8, + SequenceHelper::run(|mut seq| { + seq.elem(self.parse_token_with_trivia::( + input, + TokenKind::QuestionMark, + ))?; + seq.elem(self.expression(input))?; + seq.elem(self.parse_token_with_trivia::( + input, + TokenKind::Colon, + ))?; + seq.elem(self.expression(input))?; + seq.finish() + }), + ) + }; + let parse_or_expression = |input: &mut ParserContext| { + PrecedenceHelper::to_binary_operator( + RuleKind::BinaryExpression, + 27u8, + 27u8 + 1, + self.parse_token_with_trivia::( + input, + TokenKind::BarBar, + ), + ) + }; + let parse_and_expression = |input: &mut ParserContext| { + PrecedenceHelper::to_binary_operator( + RuleKind::BinaryExpression, + 29u8, + 29u8 + 1, + self.parse_token_with_trivia::( + input, + TokenKind::AmpersandAmpersand, + ), + ) + }; + let parse_equality_expression = |input: &mut ParserContext| { + PrecedenceHelper::to_binary_operator( + RuleKind::BinaryExpression, + 31u8, + 31u8 + 1, + ChoiceHelper::run(input, |mut choice, input| { + let result = self.parse_token_with_trivia::( + input, + TokenKind::EqualEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::BangEqual, + ); + choice.consider(input, result)?; + choice.finish(input) + }), + ) + }; + let parse_equality_expression = |input: &mut ParserContext| { + PrecedenceHelper::to_binary_operator( + RuleKind::BinaryExpression, + 33u8, + 33u8 + 1, + ChoiceHelper::run(input, |mut choice, input| { + let result = self.parse_token_with_trivia::( + input, + TokenKind::EqualEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::BangEqual, + ); + choice.consider(input, result)?; + choice.finish(input) + }), + ) + }; + let parse_comparison_expression = |input: &mut ParserContext| { + PrecedenceHelper::to_binary_operator( + RuleKind::BinaryExpression, + 35u8, + 35u8 + 1, + ChoiceHelper::run(input, |mut choice, input| { + let result = self.parse_token_with_trivia::( + input, + TokenKind::LessThan, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::GreaterThan, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::LessThanEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::GreaterThanEqual, + ); + choice.consider(input, result)?; + choice.finish(input) + }), + ) + }; + let parse_comparison_expression = |input: &mut ParserContext| { + PrecedenceHelper::to_binary_operator( + RuleKind::BinaryExpression, + 37u8, + 37u8 + 1, + ChoiceHelper::run(input, |mut choice, input| { + let result = self.parse_token_with_trivia::( + input, + TokenKind::LessThan, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::GreaterThan, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::LessThanEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::GreaterThanEqual, + ); + choice.consider(input, result)?; + choice.finish(input) + }), + ) + }; + let parse_comparison_expression = |input: &mut ParserContext| { + PrecedenceHelper::to_binary_operator( + RuleKind::BinaryExpression, + 39u8, + 39u8 + 1, + ChoiceHelper::run(input, |mut choice, input| { + let result = self.parse_token_with_trivia::( + input, + TokenKind::LessThan, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::GreaterThan, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::LessThanEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::GreaterThanEqual, + ); + choice.consider(input, result)?; + choice.finish(input) + }), + ) + }; + let parse_comparison_expression = |input: &mut ParserContext| { + PrecedenceHelper::to_binary_operator( + RuleKind::BinaryExpression, + 41u8, + 41u8 + 1, + ChoiceHelper::run(input, |mut choice, input| { + let result = self.parse_token_with_trivia::( + input, + TokenKind::LessThan, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::GreaterThan, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::LessThanEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::GreaterThanEqual, + ); + choice.consider(input, result)?; + choice.finish(input) + }), + ) + }; + let parse_bitwise_or_expression = |input: &mut ParserContext| { + PrecedenceHelper::to_binary_operator( + RuleKind::BinaryExpression, + 43u8, + 43u8 + 1, + self.parse_token_with_trivia::(input, TokenKind::Bar), + ) + }; + let parse_bitwise_xor_expression = |input: &mut ParserContext| { + PrecedenceHelper::to_binary_operator( + RuleKind::BinaryExpression, + 45u8, + 45u8 + 1, + self.parse_token_with_trivia::( + input, + TokenKind::Caret, + ), + ) + }; + let parse_bitwise_and_expression = |input: &mut ParserContext| { + PrecedenceHelper::to_binary_operator( + RuleKind::BinaryExpression, + 47u8, + 47u8 + 1, + self.parse_token_with_trivia::( + input, + TokenKind::Ampersand, + ), + ) + }; + let parse_shift_expression = |input: &mut ParserContext| { + PrecedenceHelper::to_binary_operator( + RuleKind::BinaryExpression, + 49u8, + 49u8 + 1, + ChoiceHelper::run(input, |mut choice, input| { + let result = self.parse_token_with_trivia::( + input, + TokenKind::LessThanLessThan, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::GreaterThanGreaterThan, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::GreaterThanGreaterThanGreaterThan, + ); + choice.consider(input, result)?; + choice.finish(input) + }), + ) + }; + let parse_shift_expression = |input: &mut ParserContext| { + PrecedenceHelper::to_binary_operator( + RuleKind::BinaryExpression, + 51u8, + 51u8 + 1, + ChoiceHelper::run(input, |mut choice, input| { + let result = self.parse_token_with_trivia::( + input, + TokenKind::LessThanLessThan, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::GreaterThanGreaterThan, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::GreaterThanGreaterThanGreaterThan, + ); + choice.consider(input, result)?; + choice.finish(input) + }), + ) + }; + let parse_shift_expression = |input: &mut ParserContext| { + PrecedenceHelper::to_binary_operator( + RuleKind::BinaryExpression, + 53u8, + 53u8 + 1, + ChoiceHelper::run(input, |mut choice, input| { + let result = self.parse_token_with_trivia::( + input, + TokenKind::LessThanLessThan, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::GreaterThanGreaterThan, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::GreaterThanGreaterThanGreaterThan, + ); + choice.consider(input, result)?; + choice.finish(input) + }), + ) + }; + let parse_additive_expression = |input: &mut ParserContext| { + PrecedenceHelper::to_binary_operator( + RuleKind::BinaryExpression, + 55u8, + 55u8 + 1, + ChoiceHelper::run(input, |mut choice, input| { + let result = self.parse_token_with_trivia::( + input, + TokenKind::Plus, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::Minus, + ); + choice.consider(input, result)?; + choice.finish(input) + }), + ) + }; + let parse_additive_expression = |input: &mut ParserContext| { + PrecedenceHelper::to_binary_operator( + RuleKind::BinaryExpression, + 57u8, + 57u8 + 1, + ChoiceHelper::run(input, |mut choice, input| { + let result = self.parse_token_with_trivia::( + input, + TokenKind::Plus, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::Minus, + ); + choice.consider(input, result)?; + choice.finish(input) + }), + ) + }; + let parse_multiplicative_expression = |input: &mut ParserContext| { + PrecedenceHelper::to_binary_operator( + RuleKind::BinaryExpression, + 59u8, + 59u8 + 1, + ChoiceHelper::run(input, |mut choice, input| { + let result = self.parse_token_with_trivia::( + input, + TokenKind::Asterisk, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::Slash, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::Percent, + ); + choice.consider(input, result)?; + choice.finish(input) + }), + ) + }; + let parse_multiplicative_expression = |input: &mut ParserContext| { + PrecedenceHelper::to_binary_operator( + RuleKind::BinaryExpression, + 61u8, + 61u8 + 1, + ChoiceHelper::run(input, |mut choice, input| { + let result = self.parse_token_with_trivia::( + input, + TokenKind::Asterisk, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::Slash, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::Percent, + ); + choice.consider(input, result)?; + choice.finish(input) + }), + ) + }; + let parse_multiplicative_expression = |input: &mut ParserContext| { + PrecedenceHelper::to_binary_operator( + RuleKind::BinaryExpression, + 63u8, + 63u8 + 1, + ChoiceHelper::run(input, |mut choice, input| { + let result = self.parse_token_with_trivia::( + input, + TokenKind::Asterisk, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::Slash, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::Percent, + ); + choice.consider(input, result)?; + choice.finish(input) + }), + ) + }; + let parse_exponentiation_expression_removed_from_0_6_0 = |input: &mut ParserContext| { + PrecedenceHelper::to_binary_operator( + RuleKind::BinaryExpression, + 65u8, + 65u8 + 1, + ChoiceHelper::run(input, |mut choice, input| { + if !self.version_is_at_least_0_6_0 { + let result = self.parse_token_with_trivia::( + input, + TokenKind::AsteriskAsterisk, + ); + choice.consider(input, result)?; + } + if self.version_is_at_least_0_6_0 { + let result = self.parse_token_with_trivia::( + input, + TokenKind::AsteriskAsterisk, + ); + choice.consider(input, result)?; + } + choice.finish(input) + }), + ) + }; + let parse_exponentiation_expression_introduced_from_0_6_0 = |input: &mut ParserContext| { + PrecedenceHelper::to_binary_operator( + RuleKind::BinaryExpression, + 67u8 + 1, + 67u8, + ChoiceHelper::run(input, |mut choice, input| { + if !self.version_is_at_least_0_6_0 { + let result = self.parse_token_with_trivia::( + input, + TokenKind::AsteriskAsterisk, + ); + choice.consider(input, result)?; + } + if self.version_is_at_least_0_6_0 { + let result = self.parse_token_with_trivia::( + input, + TokenKind::AsteriskAsterisk, + ); + choice.consider(input, result)?; + } + choice.finish(input) + }), + ) + }; + let parse_postfix_expression = |input: &mut ParserContext| { + PrecedenceHelper::to_postfix_operator( + RuleKind::UnaryPostfixExpression, + 69u8, + ChoiceHelper::run(input, |mut choice, input| { + let result = self.parse_token_with_trivia::( + input, + TokenKind::PlusPlus, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::MinusMinus, + ); + choice.consider(input, result)?; + choice.finish(input) + }), + ) + }; + let parse_postfix_expression = |input: &mut ParserContext| { + PrecedenceHelper::to_postfix_operator( + RuleKind::UnaryPostfixExpression, + 71u8, + ChoiceHelper::run(input, |mut choice, input| { + let result = self.parse_token_with_trivia::( + input, + TokenKind::PlusPlus, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::MinusMinus, + ); + choice.consider(input, result)?; + choice.finish(input) + }), + ) + }; + let parse_prefix_expression = |input: &mut ParserContext| { + PrecedenceHelper::to_prefix_operator( + RuleKind::UnaryPrefixExpression, + 73u8, + ChoiceHelper::run(input, |mut choice, input| { + let result = self.parse_token_with_trivia::( + input, + TokenKind::PlusPlus, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::MinusMinus, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::Tilde, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::Bang, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::Minus, + ); + choice.consider(input, result)?; + if !self.version_is_at_least_0_5_0 { + let result = self.parse_token_with_trivia::( + input, + TokenKind::Plus, + ); + choice.consider(input, result)?; + } + choice.finish(input) + }), + ) + }; + let parse_prefix_expression = |input: &mut ParserContext| { + PrecedenceHelper::to_prefix_operator( + RuleKind::UnaryPrefixExpression, + 75u8, + ChoiceHelper::run(input, |mut choice, input| { + let result = self.parse_token_with_trivia::( + input, + TokenKind::PlusPlus, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::MinusMinus, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::Tilde, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::Bang, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::Minus, ); choice.consider(input, result)?; - choice.finish(input) - }), - ) - }; - let parse_prefix_expression_removed_from_0_5_0 = |input: &mut ParserContext| { - PrecedenceHelper::to_prefix_operator( - RuleKind::UnaryPrefixExpression, - 31u8, - ChoiceHelper::run(input, |mut choice, input| { if !self.version_is_at_least_0_5_0 { - let result = ChoiceHelper::run(input, |mut choice, input| { - let result = self - .parse_token_with_trivia::( - input, - TokenKind::PlusPlus, - ); - choice.consider(input, result)?; - let result = self - .parse_token_with_trivia::( - input, - TokenKind::MinusMinus, - ); - choice.consider(input, result)?; - let result = self - .parse_token_with_trivia::( - input, - TokenKind::Tilde, - ); - choice.consider(input, result)?; - let result = self - .parse_token_with_trivia::( - input, - TokenKind::Bang, - ); - choice.consider(input, result)?; - let result = self - .parse_token_with_trivia::( - input, - TokenKind::Minus, - ); - choice.consider(input, result)?; - let result = self - .parse_token_with_trivia::( - input, - TokenKind::Plus, - ); - choice.consider(input, result)?; - choice.finish(input) - }); + let result = self.parse_token_with_trivia::( + input, + TokenKind::Plus, + ); choice.consider(input, result)?; } - if self.version_is_at_least_0_5_0 { - let result = ChoiceHelper::run(input, |mut choice, input| { - let result = self - .parse_token_with_trivia::( - input, - TokenKind::PlusPlus, - ); - choice.consider(input, result)?; - let result = self - .parse_token_with_trivia::( - input, - TokenKind::MinusMinus, - ); - choice.consider(input, result)?; - let result = self - .parse_token_with_trivia::( - input, - TokenKind::Tilde, - ); - choice.consider(input, result)?; - let result = self - .parse_token_with_trivia::( - input, - TokenKind::Bang, - ); - choice.consider(input, result)?; - let result = self - .parse_token_with_trivia::( - input, - TokenKind::Minus, - ); - choice.consider(input, result)?; - choice.finish(input) - }); + choice.finish(input) + }), + ) + }; + let parse_prefix_expression = |input: &mut ParserContext| { + PrecedenceHelper::to_prefix_operator( + RuleKind::UnaryPrefixExpression, + 77u8, + ChoiceHelper::run(input, |mut choice, input| { + let result = self.parse_token_with_trivia::( + input, + TokenKind::PlusPlus, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::MinusMinus, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::Tilde, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::Bang, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::Minus, + ); + choice.consider(input, result)?; + if !self.version_is_at_least_0_5_0 { + let result = self.parse_token_with_trivia::( + input, + TokenKind::Plus, + ); choice.consider(input, result)?; } choice.finish(input) }), ) }; - let parse_prefix_expression_introduced_from_0_5_0 = |input: &mut ParserContext| { + let parse_prefix_expression = |input: &mut ParserContext| { PrecedenceHelper::to_prefix_operator( RuleKind::UnaryPrefixExpression, - 33u8, + 79u8, + ChoiceHelper::run(input, |mut choice, input| { + let result = self.parse_token_with_trivia::( + input, + TokenKind::PlusPlus, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::MinusMinus, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::Tilde, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::Bang, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::Minus, + ); + choice.consider(input, result)?; + if !self.version_is_at_least_0_5_0 { + let result = self.parse_token_with_trivia::( + input, + TokenKind::Plus, + ); + choice.consider(input, result)?; + } + choice.finish(input) + }), + ) + }; + let parse_prefix_expression = |input: &mut ParserContext| { + PrecedenceHelper::to_prefix_operator( + RuleKind::UnaryPrefixExpression, + 81u8, ChoiceHelper::run(input, |mut choice, input| { + let result = self.parse_token_with_trivia::( + input, + TokenKind::PlusPlus, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::MinusMinus, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::Tilde, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::Bang, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::Minus, + ); + choice.consider(input, result)?; if !self.version_is_at_least_0_5_0 { - let result = ChoiceHelper::run(input, |mut choice, input| { - let result = self - .parse_token_with_trivia::( - input, - TokenKind::PlusPlus, - ); - choice.consider(input, result)?; - let result = self - .parse_token_with_trivia::( - input, - TokenKind::MinusMinus, - ); - choice.consider(input, result)?; - let result = self - .parse_token_with_trivia::( - input, - TokenKind::Tilde, - ); - choice.consider(input, result)?; - let result = self - .parse_token_with_trivia::( - input, - TokenKind::Bang, - ); - choice.consider(input, result)?; - let result = self - .parse_token_with_trivia::( - input, - TokenKind::Minus, - ); - choice.consider(input, result)?; - let result = self - .parse_token_with_trivia::( - input, - TokenKind::Plus, - ); - choice.consider(input, result)?; - choice.finish(input) - }); + let result = self.parse_token_with_trivia::( + input, + TokenKind::Plus, + ); choice.consider(input, result)?; } - if self.version_is_at_least_0_5_0 { - let result = ChoiceHelper::run(input, |mut choice, input| { - let result = self - .parse_token_with_trivia::( - input, - TokenKind::PlusPlus, - ); - choice.consider(input, result)?; - let result = self - .parse_token_with_trivia::( - input, - TokenKind::MinusMinus, - ); - choice.consider(input, result)?; - let result = self - .parse_token_with_trivia::( - input, - TokenKind::Tilde, - ); - choice.consider(input, result)?; - let result = self - .parse_token_with_trivia::( - input, - TokenKind::Bang, - ); - choice.consider(input, result)?; - let result = self - .parse_token_with_trivia::( - input, - TokenKind::Minus, - ); - choice.consider(input, result)?; - choice.finish(input) - }); + choice.finish(input) + }), + ) + }; + let parse_prefix_expression_removed_from_0_5_0 = |input: &mut ParserContext| { + PrecedenceHelper::to_prefix_operator( + RuleKind::UnaryPrefixExpression, + 83u8, + ChoiceHelper::run(input, |mut choice, input| { + let result = self.parse_token_with_trivia::( + input, + TokenKind::PlusPlus, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::MinusMinus, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::Tilde, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::Bang, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::Minus, + ); + choice.consider(input, result)?; + if !self.version_is_at_least_0_5_0 { + let result = self.parse_token_with_trivia::( + input, + TokenKind::Plus, + ); choice.consider(input, result)?; } choice.finish(input) @@ -1762,7 +2853,7 @@ impl Language { let parse_function_call_expression = |input: &mut ParserContext| { PrecedenceHelper::to_postfix_operator( RuleKind::FunctionCallExpression, - 35u8, + 85u8, SequenceHelper::run(|mut seq| { if self.version_is_at_least_0_6_2 { seq.elem(OptionalHelper::transform( @@ -1799,33 +2890,73 @@ impl Language { let parse_member_access_expression = |input: &mut ParserContext| { PrecedenceHelper::to_postfix_operator( RuleKind::MemberAccessExpression, - 37u8, - SequenceHelper::run(|mut seq| { - seq.elem(self.parse_token_with_trivia::( - input, - TokenKind::Period, - ))?; - seq.elem(ChoiceHelper::run(input, |mut choice, input| { - let result = self.parse_token_with_trivia::( + 87u8, + ChoiceHelper::run(input, |mut choice, input| { + let result = SequenceHelper::run(|mut seq| { + seq.elem(self.parse_token_with_trivia::( + input, + TokenKind::Period, + ))?; + seq.elem(self.parse_token_with_trivia::( input, TokenKind::Identifier, - ); - choice.consider(input, result)?; - let result = self.parse_token_with_trivia::( + ))?; + seq.finish() + }); + choice.consider(input, result)?; + let result = SequenceHelper::run(|mut seq| { + seq.elem(self.parse_token_with_trivia::( + input, + TokenKind::Period, + ))?; + seq.elem(self.parse_token_with_trivia::( input, TokenKind::AddressKeyword, - ); - choice.consider(input, result)?; - choice.finish(input) - }))?; - seq.finish() + ))?; + seq.finish() + }); + choice.consider(input, result)?; + choice.finish(input) + }), + ) + }; + let parse_member_access_expression = |input: &mut ParserContext| { + PrecedenceHelper::to_postfix_operator( + RuleKind::MemberAccessExpression, + 89u8, + ChoiceHelper::run(input, |mut choice, input| { + let result = SequenceHelper::run(|mut seq| { + seq.elem(self.parse_token_with_trivia::( + input, + TokenKind::Period, + ))?; + seq.elem(self.parse_token_with_trivia::( + input, + TokenKind::Identifier, + ))?; + seq.finish() + }); + choice.consider(input, result)?; + let result = SequenceHelper::run(|mut seq| { + seq.elem(self.parse_token_with_trivia::( + input, + TokenKind::Period, + ))?; + seq.elem(self.parse_token_with_trivia::( + input, + TokenKind::AddressKeyword, + ))?; + seq.finish() + }); + choice.consider(input, result)?; + choice.finish(input) }), ) }; let parse_index_access_expression = |input: &mut ParserContext| { PrecedenceHelper::to_postfix_operator( RuleKind::IndexAccessExpression, - 39u8, + 91u8, SequenceHelper::run(|mut seq| { let mut delim_guard = input.open_delim(TokenKind::CloseBracket); let input = delim_guard.ctx(); @@ -1856,14 +2987,20 @@ impl Language { }; let prefix_operator_parser = |input: &mut ParserContext| { ChoiceHelper::run(input, |mut choice, input| { + let result = parse_prefix_expression(input); + choice.consider(input, result)?; + let result = parse_prefix_expression(input); + choice.consider(input, result)?; + let result = parse_prefix_expression(input); + choice.consider(input, result)?; + let result = parse_prefix_expression(input); + choice.consider(input, result)?; + let result = parse_prefix_expression(input); + choice.consider(input, result)?; if !self.version_is_at_least_0_5_0 { let result = parse_prefix_expression_removed_from_0_5_0(input); choice.consider(input, result)?; } - if self.version_is_at_least_0_5_0 { - let result = parse_prefix_expression_introduced_from_0_5_0(input); - choice.consider(input, result)?; - } choice.finish(input) }) }; @@ -1972,10 +3109,14 @@ impl Language { choice.consider(input, result)?; let result = parse_postfix_expression(input); choice.consider(input, result)?; + let result = parse_postfix_expression(input); + choice.consider(input, result)?; let result = parse_function_call_expression(input); choice.consider(input, result)?; let result = parse_member_access_expression(input); choice.consider(input, result)?; + let result = parse_member_access_expression(input); + choice.consider(input, result)?; let result = parse_index_access_expression(input); choice.consider(input, result)?; choice.finish(input) @@ -1995,6 +3136,28 @@ impl Language { }; let binary_operator_parser = |input: &mut ParserContext| { ChoiceHelper::run(input, |mut choice, input| { + let result = parse_assignment_expression(input); + choice.consider(input, result)?; + let result = parse_assignment_expression(input); + choice.consider(input, result)?; + let result = parse_assignment_expression(input); + choice.consider(input, result)?; + let result = parse_assignment_expression(input); + choice.consider(input, result)?; + let result = parse_assignment_expression(input); + choice.consider(input, result)?; + let result = parse_assignment_expression(input); + choice.consider(input, result)?; + let result = parse_assignment_expression(input); + choice.consider(input, result)?; + let result = parse_assignment_expression(input); + choice.consider(input, result)?; + let result = parse_assignment_expression(input); + choice.consider(input, result)?; + let result = parse_assignment_expression(input); + choice.consider(input, result)?; + let result = parse_assignment_expression(input); + choice.consider(input, result)?; let result = parse_assignment_expression(input); choice.consider(input, result)?; let result = parse_or_expression(input); @@ -2003,6 +3166,14 @@ impl Language { choice.consider(input, result)?; let result = parse_equality_expression(input); choice.consider(input, result)?; + let result = parse_equality_expression(input); + choice.consider(input, result)?; + let result = parse_comparison_expression(input); + choice.consider(input, result)?; + let result = parse_comparison_expression(input); + choice.consider(input, result)?; + let result = parse_comparison_expression(input); + choice.consider(input, result)?; let result = parse_comparison_expression(input); choice.consider(input, result)?; let result = parse_bitwise_or_expression(input); @@ -2013,10 +3184,20 @@ impl Language { choice.consider(input, result)?; let result = parse_shift_expression(input); choice.consider(input, result)?; + let result = parse_shift_expression(input); + choice.consider(input, result)?; + let result = parse_shift_expression(input); + choice.consider(input, result)?; + let result = parse_additive_expression(input); + choice.consider(input, result)?; let result = parse_additive_expression(input); choice.consider(input, result)?; let result = parse_multiplicative_expression(input); choice.consider(input, result)?; + let result = parse_multiplicative_expression(input); + choice.consider(input, result)?; + let result = parse_multiplicative_expression(input); + choice.consider(input, result)?; if !self.version_is_at_least_0_6_0 { let result = parse_exponentiation_expression_removed_from_0_6_0(input); choice.consider(input, result)?; @@ -4267,44 +5448,183 @@ impl Language { choice.consider(input, result)?; let result = self.parse_token_with_trivia::( input, - TokenKind::UfixedKeyword, + TokenKind::UfixedKeyword, + ); + choice.consider(input, result)?; + choice.finish(input) + }); + choice.consider(input, result)?; + let result = self.identifier_path(input); + choice.consider(input, result)?; + choice.finish(input) + }) + }; + let postfix_operator_parser = |input: &mut ParserContext| { + ChoiceHelper::run(input, |mut choice, input| { + let result = parse_array_type_name(input); + choice.consider(input, result)?; + choice.finish(input) + }) + }; + let linear_expression_parser = |input: &mut ParserContext| { + SequenceHelper::run(|mut seq| { + seq.elem(primary_expression_parser(input))?; + seq.elem(ZeroOrMoreHelper::run(input, |input| { + postfix_operator_parser(input) + }))?; + seq.finish() + }) + }; + PrecedenceHelper::reduce_precedence_result( + Some(RuleKind::TypeName), + linear_expression_parser(input), + ) + .with_kind(RuleKind::TypeName) + } + + #[allow(unused_assignments, unused_parens)] + fn typed_tuple_member(&self, input: &mut ParserContext) -> ParserResult { + SequenceHelper::run(|mut seq| { + seq.elem(self.type_name(input))?; + seq.elem(OptionalHelper::transform(ChoiceHelper::run( + input, + |mut choice, input| { + let result = self.parse_token_with_trivia::( + input, + TokenKind::MemoryKeyword, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::StorageKeyword, + ); + choice.consider(input, result)?; + if self.version_is_at_least_0_5_0 { + let result = self.parse_token_with_trivia::( + input, + TokenKind::CallDataKeyword, + ); + choice.consider(input, result)?; + } + choice.finish(input) + }, + )))?; + seq.elem(self.parse_token_with_trivia::( + input, + TokenKind::Identifier, + ))?; + seq.finish() + }) + .with_kind(RuleKind::TypedTupleMember) + } + + #[allow(unused_assignments, unused_parens)] + fn unchecked_block(&self, input: &mut ParserContext) -> ParserResult { + if self.version_is_at_least_0_8_0 { + SequenceHelper::run(|mut seq| { + seq.elem(self.parse_token_with_trivia::( + input, + TokenKind::UncheckedKeyword, + ))?; + seq.elem(self.block(input))?; + seq.finish() + }) + } else { + ParserResult::disabled() + } + .with_kind(RuleKind::UncheckedBlock) + } + + #[allow(unused_assignments, unused_parens)] + fn unicode_string_literals(&self, input: &mut ParserContext) -> ParserResult { + if self.version_is_at_least_0_7_0 { + OneOrMoreHelper::run(input, |input| { + self.parse_token_with_trivia::( + input, + TokenKind::UnicodeStringLiteral, + ) + }) + } else { + ParserResult::disabled() + } + .with_kind(RuleKind::UnicodeStringLiterals) + } + + #[allow(unused_assignments, unused_parens)] + fn unnamed_function_attributes(&self, input: &mut ParserContext) -> ParserResult { + if !self.version_is_at_least_0_6_0 { + OneOrMoreHelper::run(input, |input| { + if !self.version_is_at_least_0_6_0 { + ChoiceHelper::run(input, |mut choice, input| { + let result = self.modifier_invocation(input); + choice.consider(input, result)?; + let result = self.override_specifier(input); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::ExternalKeyword, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::PayableKeyword, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::PureKeyword, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::ViewKeyword, + ); + choice.consider(input, result)?; + choice.finish(input) + }) + } else { + ParserResult::disabled() + } + }) + } else { + ParserResult::disabled() + } + .with_kind(RuleKind::UnnamedFunctionAttributes) + } + + #[allow(unused_assignments, unused_parens)] + fn unnamed_function_definition(&self, input: &mut ParserContext) -> ParserResult { + if !self.version_is_at_least_0_6_0 { + SequenceHelper::run(|mut seq| { + seq.elem(self.parse_token_with_trivia::( + input, + TokenKind::FunctionKeyword, + ))?; + seq.elem(self.parameters_declaration(input))?; + seq.elem(OptionalHelper::transform( + self.unnamed_function_attributes(input), + ))?; + seq.elem(ChoiceHelper::run(input, |mut choice, input| { + let result = self.block(input); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::Semicolon, ); choice.consider(input, result)?; choice.finish(input) - }); - choice.consider(input, result)?; - let result = self.identifier_path(input); - choice.consider(input, result)?; - choice.finish(input) - }) - }; - let postfix_operator_parser = |input: &mut ParserContext| { - ChoiceHelper::run(input, |mut choice, input| { - let result = parse_array_type_name(input); - choice.consider(input, result)?; - choice.finish(input) - }) - }; - let linear_expression_parser = |input: &mut ParserContext| { - SequenceHelper::run(|mut seq| { - seq.elem(primary_expression_parser(input))?; - seq.elem(ZeroOrMoreHelper::run(input, |input| { - postfix_operator_parser(input) }))?; seq.finish() }) - }; - PrecedenceHelper::reduce_precedence_result( - Some(RuleKind::TypeName), - linear_expression_parser(input), - ) - .with_kind(RuleKind::TypeName) + } else { + ParserResult::disabled() + } + .with_kind(RuleKind::UnnamedFunctionDefinition) } #[allow(unused_assignments, unused_parens)] - fn typed_tuple_member(&self, input: &mut ParserContext) -> ParserResult { + fn untyped_tuple_member(&self, input: &mut ParserContext) -> ParserResult { SequenceHelper::run(|mut seq| { - seq.elem(self.type_name(input))?; seq.elem(OptionalHelper::transform(ChoiceHelper::run( input, |mut choice, input| { @@ -4334,584 +5654,713 @@ impl Language { ))?; seq.finish() }) - .with_kind(RuleKind::TypedTupleMember) + .with_kind(RuleKind::UntypedTupleMember) } #[allow(unused_assignments, unused_parens)] - fn unchecked_block(&self, input: &mut ParserContext) -> ParserResult { - if self.version_is_at_least_0_8_0 { + fn user_defined_value_type_definition(&self, input: &mut ParserContext) -> ParserResult { + if self.version_is_at_least_0_8_8 { SequenceHelper::run(|mut seq| { + seq.elem( + SequenceHelper::run(|mut seq| { + seq.elem(self.parse_token_with_trivia::( + input, + TokenKind::TypeKeyword, + ))?; + seq.elem(self.parse_token_with_trivia::( + input, + TokenKind::Identifier, + ))?; + seq.elem(self.parse_token_with_trivia::( + input, + TokenKind::IsKeyword, + ))?; + seq.elem(ChoiceHelper::run(input, |mut choice, input| { + let result = self + .parse_token_with_trivia::( + input, + TokenKind::BoolKeyword, + ); + choice.consider(input, result)?; + if !self.version_is_at_least_0_8_0 { + let result = self + .parse_token_with_trivia::( + input, + TokenKind::ByteKeyword, + ); + choice.consider(input, result)?; + } + let result = self + .parse_token_with_trivia::( + input, + TokenKind::StringKeyword, + ); + choice.consider(input, result)?; + let result = self.address_type(input); + choice.consider(input, result)?; + let result = self + .parse_token_with_trivia::( + input, + TokenKind::PayableKeyword, + ); + choice.consider(input, result)?; + let result = self + .parse_token_with_trivia::( + input, + TokenKind::BytesKeyword, + ); + choice.consider(input, result)?; + let result = self + .parse_token_with_trivia::( + input, + TokenKind::IntKeyword, + ); + choice.consider(input, result)?; + let result = self + .parse_token_with_trivia::( + input, + TokenKind::UintKeyword, + ); + choice.consider(input, result)?; + let result = self + .parse_token_with_trivia::( + input, + TokenKind::FixedKeyword, + ); + choice.consider(input, result)?; + let result = self + .parse_token_with_trivia::( + input, + TokenKind::UfixedKeyword, + ); + choice.consider(input, result)?; + choice.finish(input) + }))?; + seq.finish() + }) + .recover_until_with_nested_delims::<_, LexicalContextType::Default>( + input, + self, + TokenKind::Semicolon, + RecoverFromNoMatch::No, + ), + )?; seq.elem(self.parse_token_with_trivia::( input, - TokenKind::UncheckedKeyword, + TokenKind::Semicolon, ))?; - seq.elem(self.block(input))?; seq.finish() }) } else { ParserResult::disabled() } - .with_kind(RuleKind::UncheckedBlock) + .with_kind(RuleKind::UserDefinedValueTypeDefinition) } #[allow(unused_assignments, unused_parens)] - fn unicode_string_literals(&self, input: &mut ParserContext) -> ParserResult { - if self.version_is_at_least_0_7_0 { - OneOrMoreHelper::run(input, |input| { - self.parse_token_with_trivia::( + fn using_alias(&self, input: &mut ParserContext) -> ParserResult { + if self.version_is_at_least_0_8_19 { + SequenceHelper::run(|mut seq| { + seq.elem(self.parse_token_with_trivia::( input, - TokenKind::UnicodeStringLiteral, - ) - }) - } else { - ParserResult::disabled() - } - .with_kind(RuleKind::UnicodeStringLiterals) - } - - #[allow(unused_assignments, unused_parens)] - fn unnamed_function_attributes(&self, input: &mut ParserContext) -> ParserResult { - if !self.version_is_at_least_0_6_0 { - OneOrMoreHelper::run(input, |input| { - if !self.version_is_at_least_0_6_0 { + TokenKind::AsKeyword, + ))?; + seq.elem(if self.version_is_at_least_0_8_19 { ChoiceHelper::run(input, |mut choice, input| { - let result = self.modifier_invocation(input); + let result = self.parse_token_with_trivia::( + input, + TokenKind::Ampersand, + ); choice.consider(input, result)?; - let result = self.override_specifier(input); + let result = self.parse_token_with_trivia::( + input, + TokenKind::Asterisk, + ); choice.consider(input, result)?; let result = self.parse_token_with_trivia::( input, - TokenKind::ExternalKeyword, + TokenKind::BangEqual, ); choice.consider(input, result)?; let result = self.parse_token_with_trivia::( input, - TokenKind::PayableKeyword, + TokenKind::Bar, ); choice.consider(input, result)?; let result = self.parse_token_with_trivia::( input, - TokenKind::PureKeyword, + TokenKind::Caret, ); choice.consider(input, result)?; let result = self.parse_token_with_trivia::( input, - TokenKind::ViewKeyword, + TokenKind::EqualEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::GreaterThan, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::GreaterThanEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::LessThan, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::LessThanEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::Minus, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::Percent, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::Plus, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::Slash, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::Tilde, ); choice.consider(input, result)?; choice.finish(input) }) } else { ParserResult::disabled() - } + })?; + seq.finish() + }) + } else { + ParserResult::disabled() + } + .with_kind(RuleKind::UsingAlias) + } + + #[allow(unused_assignments, unused_parens)] + fn using_deconstruction(&self, input: &mut ParserContext) -> ParserResult { + if self.version_is_at_least_0_8_13 { + SequenceHelper::run(|mut seq| { + let mut delim_guard = input.open_delim(TokenKind::CloseBrace); + let input = delim_guard.ctx(); + seq.elem(self.parse_token_with_trivia::( + input, + TokenKind::OpenBrace, + ))?; + seq.elem( + self.using_deconstruction_symbols(input) + .recover_until_with_nested_delims::<_, LexicalContextType::Default>( + input, + self, + TokenKind::CloseBrace, + RecoverFromNoMatch::Yes, + ), + )?; + seq.elem(self.parse_token_with_trivia::( + input, + TokenKind::CloseBrace, + ))?; + seq.finish() }) } else { ParserResult::disabled() } - .with_kind(RuleKind::UnnamedFunctionAttributes) + .with_kind(RuleKind::UsingDeconstruction) } #[allow(unused_assignments, unused_parens)] - fn unnamed_function_definition(&self, input: &mut ParserContext) -> ParserResult { - if !self.version_is_at_least_0_6_0 { + fn using_deconstruction_symbol(&self, input: &mut ParserContext) -> ParserResult { + if self.version_is_at_least_0_8_13 { SequenceHelper::run(|mut seq| { - seq.elem(self.parse_token_with_trivia::( - input, - TokenKind::FunctionKeyword, - ))?; - seq.elem(self.parameters_declaration(input))?; - seq.elem(OptionalHelper::transform( - self.unnamed_function_attributes(input), - ))?; - seq.elem(ChoiceHelper::run(input, |mut choice, input| { - let result = self.block(input); - choice.consider(input, result)?; - let result = self.parse_token_with_trivia::( - input, - TokenKind::Semicolon, - ); - choice.consider(input, result)?; - choice.finish(input) - }))?; + seq.elem(self.identifier_path(input))?; + if self.version_is_at_least_0_8_19 { + seq.elem(OptionalHelper::transform(self.using_alias(input)))?; + } seq.finish() }) } else { ParserResult::disabled() } - .with_kind(RuleKind::UnnamedFunctionDefinition) + .with_kind(RuleKind::UsingDeconstructionSymbol) } #[allow(unused_assignments, unused_parens)] - fn untyped_tuple_member(&self, input: &mut ParserContext) -> ParserResult { - SequenceHelper::run(|mut seq| { - seq.elem(OptionalHelper::transform(ChoiceHelper::run( + fn using_deconstruction_symbols(&self, input: &mut ParserContext) -> ParserResult { + if self.version_is_at_least_0_8_13 { + SeparatedHelper::run::<_, LexicalContextType::Default>( input, - |mut choice, input| { - let result = self.parse_token_with_trivia::( + self, + |input| self.using_deconstruction_symbol(input), + TokenKind::Comma, + ) + } else { + ParserResult::disabled() + } + .with_kind(RuleKind::UsingDeconstructionSymbols) + } + + #[allow(unused_assignments, unused_parens)] + fn using_directive(&self, input: &mut ParserContext) -> ParserResult { + SequenceHelper::run(|mut seq| { + seq.elem( + SequenceHelper::run(|mut seq| { + seq.elem(self.parse_token_with_trivia::( input, - TokenKind::MemoryKeyword, - ); - choice.consider(input, result)?; - let result = self.parse_token_with_trivia::( + TokenKind::UsingKeyword, + ))?; + seq.elem(ChoiceHelper::run(input, |mut choice, input| { + let result = self.identifier_path(input); + choice.consider(input, result)?; + if self.version_is_at_least_0_8_13 { + let result = self.using_deconstruction(input); + choice.consider(input, result)?; + } + choice.finish(input) + }))?; + seq.elem(self.parse_token_with_trivia::( input, - TokenKind::StorageKeyword, - ); - choice.consider(input, result)?; - if self.version_is_at_least_0_5_0 { + TokenKind::ForKeyword, + ))?; + seq.elem(ChoiceHelper::run(input, |mut choice, input| { + let result = self.type_name(input); + choice.consider(input, result)?; let result = self.parse_token_with_trivia::( input, - TokenKind::CallDataKeyword, + TokenKind::Asterisk, ); choice.consider(input, result)?; + choice.finish(input) + }))?; + if self.version_is_at_least_0_8_13 { + seq.elem(OptionalHelper::transform( + self.parse_token_with_trivia::( + input, + TokenKind::GlobalKeyword, + ), + ))?; } - choice.finish(input) - }, - )))?; + seq.finish() + }) + .recover_until_with_nested_delims::<_, LexicalContextType::Default>( + input, + self, + TokenKind::Semicolon, + RecoverFromNoMatch::No, + ), + )?; seq.elem(self.parse_token_with_trivia::( input, - TokenKind::Identifier, + TokenKind::Semicolon, ))?; seq.finish() }) - .with_kind(RuleKind::UntypedTupleMember) + .with_kind(RuleKind::UsingDirective) } #[allow(unused_assignments, unused_parens)] - fn user_defined_value_type_definition(&self, input: &mut ParserContext) -> ParserResult { - if self.version_is_at_least_0_8_8 { - SequenceHelper::run(|mut seq| { - seq.elem( - SequenceHelper::run(|mut seq| { - seq.elem(self.parse_token_with_trivia::( - input, - TokenKind::TypeKeyword, - ))?; - seq.elem(self.parse_token_with_trivia::( - input, - TokenKind::Identifier, - ))?; - seq.elem(self.parse_token_with_trivia::( - input, - TokenKind::IsKeyword, - ))?; - seq.elem(ChoiceHelper::run(input, |mut choice, input| { - let result = self - .parse_token_with_trivia::( - input, - TokenKind::BoolKeyword, - ); - choice.consider(input, result)?; - if !self.version_is_at_least_0_8_0 { - let result = self - .parse_token_with_trivia::( - input, - TokenKind::ByteKeyword, - ); - choice.consider(input, result)?; - } - let result = self - .parse_token_with_trivia::( - input, - TokenKind::StringKeyword, - ); - choice.consider(input, result)?; - let result = self.address_type(input); - choice.consider(input, result)?; - let result = self - .parse_token_with_trivia::( - input, - TokenKind::PayableKeyword, - ); - choice.consider(input, result)?; - let result = self - .parse_token_with_trivia::( - input, - TokenKind::BytesKeyword, - ); - choice.consider(input, result)?; - let result = self - .parse_token_with_trivia::( - input, - TokenKind::IntKeyword, - ); - choice.consider(input, result)?; + fn variable_declaration_statement(&self, input: &mut ParserContext) -> ParserResult { + SequenceHelper::run(|mut seq| { + seq.elem( + SequenceHelper::run(|mut seq| { + seq.elem(ChoiceHelper::run(input, |mut choice, input| { + let result = self.type_name(input); + choice.consider(input, result)?; + if !self.version_is_at_least_0_5_0 { let result = self .parse_token_with_trivia::( input, - TokenKind::UintKeyword, + TokenKind::VarKeyword, ); choice.consider(input, result)?; + } + choice.finish(input) + }))?; + seq.elem(OptionalHelper::transform(ChoiceHelper::run( + input, + |mut choice, input| { let result = self .parse_token_with_trivia::( input, - TokenKind::FixedKeyword, + TokenKind::MemoryKeyword, ); choice.consider(input, result)?; let result = self .parse_token_with_trivia::( input, - TokenKind::UfixedKeyword, + TokenKind::StorageKeyword, ); choice.consider(input, result)?; + if self.version_is_at_least_0_5_0 { + let result = self + .parse_token_with_trivia::( + input, + TokenKind::CallDataKeyword, + ); + choice.consider(input, result)?; + } choice.finish(input) - }))?; - seq.finish() - }) - .recover_until_with_nested_delims::<_, LexicalContextType::Default>( + }, + )))?; + seq.elem(self.parse_token_with_trivia::( input, - self, - TokenKind::Semicolon, - RecoverFromNoMatch::No, - ), - )?; - seq.elem(self.parse_token_with_trivia::( + TokenKind::Identifier, + ))?; + seq.elem(OptionalHelper::transform( + self.variable_declaration_value(input), + ))?; + seq.finish() + }) + .recover_until_with_nested_delims::<_, LexicalContextType::Default>( input, + self, TokenKind::Semicolon, - ))?; - seq.finish() - }) - } else { - ParserResult::disabled() - } - .with_kind(RuleKind::UserDefinedValueTypeDefinition) + RecoverFromNoMatch::No, + ), + )?; + seq.elem(self.parse_token_with_trivia::( + input, + TokenKind::Semicolon, + ))?; + seq.finish() + }) + .with_kind(RuleKind::VariableDeclarationStatement) + } + + #[allow(unused_assignments, unused_parens)] + fn variable_declaration_value(&self, input: &mut ParserContext) -> ParserResult { + SequenceHelper::run(|mut seq| { + seq.elem( + self.parse_token_with_trivia::( + input, + TokenKind::Equal, + ), + )?; + seq.elem(self.expression(input))?; + seq.finish() + }) + .with_kind(RuleKind::VariableDeclarationValue) + } + + #[allow(unused_assignments, unused_parens)] + fn version_pragma(&self, input: &mut ParserContext) -> ParserResult { + SequenceHelper::run(|mut seq| { + seq.elem(self.parse_token_with_trivia::( + input, + TokenKind::SolidityKeyword, + ))?; + seq.elem(self.version_pragma_expressions(input))?; + seq.finish() + }) + .with_kind(RuleKind::VersionPragma) } #[allow(unused_assignments, unused_parens)] - fn using_alias(&self, input: &mut ParserContext) -> ParserResult { - if self.version_is_at_least_0_8_19 { - SequenceHelper::run(|mut seq| { - seq.elem(self.parse_token_with_trivia::( + fn version_pragma_expression(&self, input: &mut ParserContext) -> ParserResult { + let parse_version_pragma_or_expression = |input: &mut ParserContext| { + PrecedenceHelper::to_binary_operator( + RuleKind::VersionPragmaBinaryExpression, + 1u8, + 1u8 + 1, + self.parse_token_with_trivia::( input, - TokenKind::AsKeyword, - ))?; - seq.elem(ChoiceHelper::run(input, |mut choice, input| { - let result = self.parse_token_with_trivia::( + TokenKind::BarBar, + ), + ) + }; + let parse_version_pragma_range_expression = |input: &mut ParserContext| { + PrecedenceHelper::to_binary_operator( + RuleKind::VersionPragmaBinaryExpression, + 3u8, + 3u8 + 1, + self.parse_token_with_trivia::(input, TokenKind::Minus), + ) + }; + let parse_version_pragma_prefix_expression = |input: &mut ParserContext| { + PrecedenceHelper::to_prefix_operator( + RuleKind::VersionPragmaUnaryExpression, + 5u8, + ChoiceHelper::run(input, |mut choice, input| { + let result = self.parse_token_with_trivia::( input, - TokenKind::Ampersand, + TokenKind::Caret, ); choice.consider(input, result)?; - let result = self.parse_token_with_trivia::( + let result = self.parse_token_with_trivia::( input, - TokenKind::Asterisk, + TokenKind::Tilde, ); choice.consider(input, result)?; - let result = self.parse_token_with_trivia::( + let result = self.parse_token_with_trivia::( input, - TokenKind::BangEqual, + TokenKind::Equal, ); choice.consider(input, result)?; - let result = self.parse_token_with_trivia::( + let result = self.parse_token_with_trivia::( input, - TokenKind::Bar, + TokenKind::LessThan, ); choice.consider(input, result)?; - let result = self.parse_token_with_trivia::( + let result = self.parse_token_with_trivia::( + input, + TokenKind::GreaterThan, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::LessThanEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::GreaterThanEqual, + ); + choice.consider(input, result)?; + choice.finish(input) + }), + ) + }; + let parse_version_pragma_prefix_expression = |input: &mut ParserContext| { + PrecedenceHelper::to_prefix_operator( + RuleKind::VersionPragmaUnaryExpression, + 7u8, + ChoiceHelper::run(input, |mut choice, input| { + let result = self.parse_token_with_trivia::( input, TokenKind::Caret, ); choice.consider(input, result)?; - let result = self.parse_token_with_trivia::( + let result = self.parse_token_with_trivia::( input, - TokenKind::EqualEqual, + TokenKind::Tilde, ); choice.consider(input, result)?; - let result = self.parse_token_with_trivia::( + let result = self.parse_token_with_trivia::( + input, + TokenKind::Equal, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::LessThan, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( input, TokenKind::GreaterThan, ); choice.consider(input, result)?; - let result = self.parse_token_with_trivia::( + let result = self.parse_token_with_trivia::( + input, + TokenKind::LessThanEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( input, TokenKind::GreaterThanEqual, ); choice.consider(input, result)?; - let result = self.parse_token_with_trivia::( + choice.finish(input) + }), + ) + }; + let parse_version_pragma_prefix_expression = |input: &mut ParserContext| { + PrecedenceHelper::to_prefix_operator( + RuleKind::VersionPragmaUnaryExpression, + 9u8, + ChoiceHelper::run(input, |mut choice, input| { + let result = self.parse_token_with_trivia::( + input, + TokenKind::Caret, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::Tilde, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::Equal, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( input, TokenKind::LessThan, ); choice.consider(input, result)?; - let result = self.parse_token_with_trivia::( + let result = self.parse_token_with_trivia::( + input, + TokenKind::GreaterThan, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( input, TokenKind::LessThanEqual, ); choice.consider(input, result)?; - let result = self.parse_token_with_trivia::( + let result = self.parse_token_with_trivia::( input, - TokenKind::Minus, + TokenKind::GreaterThanEqual, ); choice.consider(input, result)?; - let result = self.parse_token_with_trivia::( + choice.finish(input) + }), + ) + }; + let parse_version_pragma_prefix_expression = |input: &mut ParserContext| { + PrecedenceHelper::to_prefix_operator( + RuleKind::VersionPragmaUnaryExpression, + 11u8, + ChoiceHelper::run(input, |mut choice, input| { + let result = self.parse_token_with_trivia::( input, - TokenKind::Percent, + TokenKind::Caret, ); choice.consider(input, result)?; - let result = self.parse_token_with_trivia::( + let result = self.parse_token_with_trivia::( input, - TokenKind::Plus, + TokenKind::Tilde, ); choice.consider(input, result)?; - let result = self.parse_token_with_trivia::( + let result = self.parse_token_with_trivia::( input, - TokenKind::Slash, + TokenKind::Equal, ); choice.consider(input, result)?; - let result = self.parse_token_with_trivia::( + let result = self.parse_token_with_trivia::( input, - TokenKind::Tilde, + TokenKind::LessThan, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::GreaterThan, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::LessThanEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::GreaterThanEqual, ); choice.consider(input, result)?; choice.finish(input) - }))?; - seq.finish() - }) - } else { - ParserResult::disabled() - } - .with_kind(RuleKind::UsingAlias) - } - - #[allow(unused_assignments, unused_parens)] - fn using_deconstruction(&self, input: &mut ParserContext) -> ParserResult { - if self.version_is_at_least_0_8_13 { - SequenceHelper::run(|mut seq| { - let mut delim_guard = input.open_delim(TokenKind::CloseBrace); - let input = delim_guard.ctx(); - seq.elem(self.parse_token_with_trivia::( - input, - TokenKind::OpenBrace, - ))?; - seq.elem( - self.using_deconstruction_symbols(input) - .recover_until_with_nested_delims::<_, LexicalContextType::Default>( - input, - self, - TokenKind::CloseBrace, - RecoverFromNoMatch::Yes, - ), - )?; - seq.elem(self.parse_token_with_trivia::( - input, - TokenKind::CloseBrace, - ))?; - seq.finish() - }) - } else { - ParserResult::disabled() - } - .with_kind(RuleKind::UsingDeconstruction) - } - - #[allow(unused_assignments, unused_parens)] - fn using_deconstruction_symbol(&self, input: &mut ParserContext) -> ParserResult { - if self.version_is_at_least_0_8_13 { - SequenceHelper::run(|mut seq| { - seq.elem(self.identifier_path(input))?; - if self.version_is_at_least_0_8_19 { - seq.elem(OptionalHelper::transform(self.using_alias(input)))?; - } - seq.finish() - }) - } else { - ParserResult::disabled() - } - .with_kind(RuleKind::UsingDeconstructionSymbol) - } - - #[allow(unused_assignments, unused_parens)] - fn using_deconstruction_symbols(&self, input: &mut ParserContext) -> ParserResult { - if self.version_is_at_least_0_8_13 { - SeparatedHelper::run::<_, LexicalContextType::Default>( - input, - self, - |input| self.using_deconstruction_symbol(input), - TokenKind::Comma, + }), ) - } else { - ParserResult::disabled() - } - .with_kind(RuleKind::UsingDeconstructionSymbols) - } - - #[allow(unused_assignments, unused_parens)] - fn using_directive(&self, input: &mut ParserContext) -> ParserResult { - SequenceHelper::run(|mut seq| { - seq.elem( - SequenceHelper::run(|mut seq| { - seq.elem(self.parse_token_with_trivia::( + }; + let parse_version_pragma_prefix_expression = |input: &mut ParserContext| { + PrecedenceHelper::to_prefix_operator( + RuleKind::VersionPragmaUnaryExpression, + 13u8, + ChoiceHelper::run(input, |mut choice, input| { + let result = self.parse_token_with_trivia::( input, - TokenKind::UsingKeyword, - ))?; - seq.elem(ChoiceHelper::run(input, |mut choice, input| { - let result = self.identifier_path(input); - choice.consider(input, result)?; - if self.version_is_at_least_0_8_13 { - let result = self.using_deconstruction(input); - choice.consider(input, result)?; - } - choice.finish(input) - }))?; - seq.elem(self.parse_token_with_trivia::( + TokenKind::Caret, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( input, - TokenKind::ForKeyword, - ))?; - seq.elem(ChoiceHelper::run(input, |mut choice, input| { - let result = self.type_name(input); - choice.consider(input, result)?; - let result = self.parse_token_with_trivia::( - input, - TokenKind::Asterisk, - ); - choice.consider(input, result)?; - choice.finish(input) - }))?; - if self.version_is_at_least_0_8_13 { - seq.elem(OptionalHelper::transform( - self.parse_token_with_trivia::( - input, - TokenKind::GlobalKeyword, - ), - ))?; - } - seq.finish() - }) - .recover_until_with_nested_delims::<_, LexicalContextType::Default>( - input, - self, - TokenKind::Semicolon, - RecoverFromNoMatch::No, - ), - )?; - seq.elem(self.parse_token_with_trivia::( - input, - TokenKind::Semicolon, - ))?; - seq.finish() - }) - .with_kind(RuleKind::UsingDirective) - } - - #[allow(unused_assignments, unused_parens)] - fn variable_declaration_statement(&self, input: &mut ParserContext) -> ParserResult { - SequenceHelper::run(|mut seq| { - seq.elem( - SequenceHelper::run(|mut seq| { - seq.elem(ChoiceHelper::run(input, |mut choice, input| { - let result = self.type_name(input); - choice.consider(input, result)?; - if !self.version_is_at_least_0_5_0 { - let result = self - .parse_token_with_trivia::( - input, - TokenKind::VarKeyword, - ); - choice.consider(input, result)?; - } - choice.finish(input) - }))?; - seq.elem(OptionalHelper::transform(ChoiceHelper::run( + TokenKind::Tilde, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( input, - |mut choice, input| { - let result = self - .parse_token_with_trivia::( - input, - TokenKind::MemoryKeyword, - ); - choice.consider(input, result)?; - let result = self - .parse_token_with_trivia::( - input, - TokenKind::StorageKeyword, - ); - choice.consider(input, result)?; - if self.version_is_at_least_0_5_0 { - let result = self - .parse_token_with_trivia::( - input, - TokenKind::CallDataKeyword, - ); - choice.consider(input, result)?; - } - choice.finish(input) - }, - )))?; - seq.elem(self.parse_token_with_trivia::( + TokenKind::Equal, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( input, - TokenKind::Identifier, - ))?; - seq.elem(OptionalHelper::transform( - self.variable_declaration_value(input), - ))?; - seq.finish() - }) - .recover_until_with_nested_delims::<_, LexicalContextType::Default>( - input, - self, - TokenKind::Semicolon, - RecoverFromNoMatch::No, - ), - )?; - seq.elem(self.parse_token_with_trivia::( - input, - TokenKind::Semicolon, - ))?; - seq.finish() - }) - .with_kind(RuleKind::VariableDeclarationStatement) - } - - #[allow(unused_assignments, unused_parens)] - fn variable_declaration_value(&self, input: &mut ParserContext) -> ParserResult { - SequenceHelper::run(|mut seq| { - seq.elem( - self.parse_token_with_trivia::( - input, - TokenKind::Equal, - ), - )?; - seq.elem(self.expression(input))?; - seq.finish() - }) - .with_kind(RuleKind::VariableDeclarationValue) - } - - #[allow(unused_assignments, unused_parens)] - fn version_pragma(&self, input: &mut ParserContext) -> ParserResult { - SequenceHelper::run(|mut seq| { - seq.elem(self.parse_token_with_trivia::( - input, - TokenKind::SolidityKeyword, - ))?; - seq.elem(self.version_pragma_expressions(input))?; - seq.finish() - }) - .with_kind(RuleKind::VersionPragma) - } - - #[allow(unused_assignments, unused_parens)] - fn version_pragma_expression(&self, input: &mut ParserContext) -> ParserResult { - let parse_version_pragma_or_expression = |input: &mut ParserContext| { - PrecedenceHelper::to_binary_operator( - RuleKind::VersionPragmaBinaryExpression, - 1u8, - 1u8 + 1, - self.parse_token_with_trivia::( - input, - TokenKind::BarBar, - ), + TokenKind::LessThan, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::GreaterThan, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::LessThanEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::GreaterThanEqual, + ); + choice.consider(input, result)?; + choice.finish(input) + }), ) }; - let parse_version_pragma_range_expression = |input: &mut ParserContext| { - PrecedenceHelper::to_binary_operator( - RuleKind::VersionPragmaBinaryExpression, - 3u8, - 3u8 + 1, - self.parse_token_with_trivia::(input, TokenKind::Minus), + let parse_version_pragma_prefix_expression = |input: &mut ParserContext| { + PrecedenceHelper::to_prefix_operator( + RuleKind::VersionPragmaUnaryExpression, + 15u8, + ChoiceHelper::run(input, |mut choice, input| { + let result = self.parse_token_with_trivia::( + input, + TokenKind::Caret, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::Tilde, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::Equal, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::LessThan, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::GreaterThan, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::LessThanEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::GreaterThanEqual, + ); + choice.consider(input, result)?; + choice.finish(input) + }), ) }; let parse_version_pragma_prefix_expression = |input: &mut ParserContext| { PrecedenceHelper::to_prefix_operator( RuleKind::VersionPragmaUnaryExpression, - 5u8, + 17u8, ChoiceHelper::run(input, |mut choice, input| { let result = self.parse_token_with_trivia::( input, @@ -4954,6 +6403,18 @@ impl Language { }; let prefix_operator_parser = |input: &mut ParserContext| { ChoiceHelper::run(input, |mut choice, input| { + let result = parse_version_pragma_prefix_expression(input); + choice.consider(input, result)?; + let result = parse_version_pragma_prefix_expression(input); + choice.consider(input, result)?; + let result = parse_version_pragma_prefix_expression(input); + choice.consider(input, result)?; + let result = parse_version_pragma_prefix_expression(input); + choice.consider(input, result)?; + let result = parse_version_pragma_prefix_expression(input); + choice.consider(input, result)?; + let result = parse_version_pragma_prefix_expression(input); + choice.consider(input, result)?; let result = parse_version_pragma_prefix_expression(input); choice.consider(input, result)?; choice.finish(input) diff --git a/crates/solidity/outputs/npm/crate/src/generated/language.rs b/crates/solidity/outputs/npm/crate/src/generated/language.rs index c889122236..722029cf75 100644 --- a/crates/solidity/outputs/npm/crate/src/generated/language.rs +++ b/crates/solidity/outputs/npm/crate/src/generated/language.rs @@ -1327,432 +1327,1523 @@ impl Language { }), ) }; - let parse_conditional_expression = |input: &mut ParserContext| { - PrecedenceHelper::to_postfix_operator( - RuleKind::ConditionalExpression, - 3u8, - SequenceHelper::run(|mut seq| { - seq.elem(self.parse_token_with_trivia::( - input, - TokenKind::QuestionMark, - ))?; - seq.elem(self.expression(input))?; - seq.elem(self.parse_token_with_trivia::( - input, - TokenKind::Colon, - ))?; - seq.elem(self.expression(input))?; - seq.finish() - }), - ) - }; - let parse_or_expression = |input: &mut ParserContext| { - PrecedenceHelper::to_binary_operator( - RuleKind::BinaryExpression, - 5u8, - 5u8 + 1, - self.parse_token_with_trivia::( - input, - TokenKind::BarBar, - ), - ) - }; - let parse_and_expression = |input: &mut ParserContext| { - PrecedenceHelper::to_binary_operator( - RuleKind::BinaryExpression, - 7u8, - 7u8 + 1, - self.parse_token_with_trivia::( - input, - TokenKind::AmpersandAmpersand, - ), - ) - }; - let parse_equality_expression = |input: &mut ParserContext| { + let parse_assignment_expression = |input: &mut ParserContext| { PrecedenceHelper::to_binary_operator( RuleKind::BinaryExpression, - 9u8, - 9u8 + 1, + 3u8, + 3u8 + 1, ChoiceHelper::run(input, |mut choice, input| { let result = self.parse_token_with_trivia::( input, - TokenKind::EqualEqual, + TokenKind::Equal, ); choice.consider(input, result)?; let result = self.parse_token_with_trivia::( input, - TokenKind::BangEqual, + TokenKind::BarEqual, ); choice.consider(input, result)?; - choice.finish(input) - }), - ) - }; - let parse_comparison_expression = |input: &mut ParserContext| { - PrecedenceHelper::to_binary_operator( - RuleKind::BinaryExpression, - 11u8, - 11u8 + 1, - ChoiceHelper::run(input, |mut choice, input| { let result = self.parse_token_with_trivia::( input, - TokenKind::LessThan, + TokenKind::PlusEqual, ); choice.consider(input, result)?; let result = self.parse_token_with_trivia::( input, - TokenKind::GreaterThan, + TokenKind::MinusEqual, ); choice.consider(input, result)?; let result = self.parse_token_with_trivia::( input, - TokenKind::LessThanEqual, + TokenKind::CaretEqual, ); choice.consider(input, result)?; let result = self.parse_token_with_trivia::( input, - TokenKind::GreaterThanEqual, + TokenKind::SlashEqual, ); choice.consider(input, result)?; - choice.finish(input) - }), - ) - }; - let parse_bitwise_or_expression = |input: &mut ParserContext| { - PrecedenceHelper::to_binary_operator( - RuleKind::BinaryExpression, - 13u8, - 13u8 + 1, - self.parse_token_with_trivia::(input, TokenKind::Bar), - ) - }; - let parse_bitwise_xor_expression = |input: &mut ParserContext| { - PrecedenceHelper::to_binary_operator( - RuleKind::BinaryExpression, - 15u8, - 15u8 + 1, - self.parse_token_with_trivia::( - input, - TokenKind::Caret, - ), - ) - }; - let parse_bitwise_and_expression = |input: &mut ParserContext| { - PrecedenceHelper::to_binary_operator( - RuleKind::BinaryExpression, - 17u8, - 17u8 + 1, - self.parse_token_with_trivia::( - input, - TokenKind::Ampersand, - ), - ) - }; - let parse_shift_expression = |input: &mut ParserContext| { - PrecedenceHelper::to_binary_operator( - RuleKind::BinaryExpression, - 19u8, - 19u8 + 1, - ChoiceHelper::run(input, |mut choice, input| { let result = self.parse_token_with_trivia::( input, - TokenKind::LessThanLessThan, + TokenKind::PercentEqual, ); choice.consider(input, result)?; let result = self.parse_token_with_trivia::( input, - TokenKind::GreaterThanGreaterThan, + TokenKind::AsteriskEqual, ); choice.consider(input, result)?; let result = self.parse_token_with_trivia::( input, - TokenKind::GreaterThanGreaterThanGreaterThan, + TokenKind::AmpersandEqual, ); choice.consider(input, result)?; - choice.finish(input) - }), - ) - }; - let parse_additive_expression = |input: &mut ParserContext| { - PrecedenceHelper::to_binary_operator( - RuleKind::BinaryExpression, - 21u8, - 21u8 + 1, - ChoiceHelper::run(input, |mut choice, input| { let result = self.parse_token_with_trivia::( input, - TokenKind::Plus, + TokenKind::LessThanLessThanEqual, ); choice.consider(input, result)?; let result = self.parse_token_with_trivia::( input, - TokenKind::Minus, + TokenKind::GreaterThanGreaterThanEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::GreaterThanGreaterThanGreaterThanEqual, ); choice.consider(input, result)?; choice.finish(input) }), ) }; - let parse_multiplicative_expression = |input: &mut ParserContext| { + let parse_assignment_expression = |input: &mut ParserContext| { PrecedenceHelper::to_binary_operator( RuleKind::BinaryExpression, - 23u8, - 23u8 + 1, + 5u8, + 5u8 + 1, ChoiceHelper::run(input, |mut choice, input| { let result = self.parse_token_with_trivia::( input, - TokenKind::Asterisk, + TokenKind::Equal, ); choice.consider(input, result)?; let result = self.parse_token_with_trivia::( input, - TokenKind::Slash, + TokenKind::BarEqual, ); choice.consider(input, result)?; let result = self.parse_token_with_trivia::( input, - TokenKind::Percent, + TokenKind::PlusEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::MinusEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::CaretEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::SlashEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::PercentEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::AsteriskEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::AmpersandEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::LessThanLessThanEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::GreaterThanGreaterThanEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::GreaterThanGreaterThanGreaterThanEqual, ); choice.consider(input, result)?; choice.finish(input) }), ) }; - let parse_exponentiation_expression_removed_from_0_6_0 = |input: &mut ParserContext| { - PrecedenceHelper::to_binary_operator( - RuleKind::BinaryExpression, - 25u8, - 25u8 + 1, - ChoiceHelper::run(input, |mut choice, input| { - if !self.version_is_at_least_0_6_0 { - let result = self.parse_token_with_trivia::( - input, - TokenKind::AsteriskAsterisk, - ); - choice.consider(input, result)?; - } - if self.version_is_at_least_0_6_0 { - let result = self.parse_token_with_trivia::( - input, - TokenKind::AsteriskAsterisk, - ); - choice.consider(input, result)?; - } - choice.finish(input) - }), - ) - }; - let parse_exponentiation_expression_introduced_from_0_6_0 = |input: &mut ParserContext| { + let parse_assignment_expression = |input: &mut ParserContext| { PrecedenceHelper::to_binary_operator( RuleKind::BinaryExpression, - 27u8 + 1, - 27u8, - ChoiceHelper::run(input, |mut choice, input| { - if !self.version_is_at_least_0_6_0 { - let result = self.parse_token_with_trivia::( - input, - TokenKind::AsteriskAsterisk, - ); - choice.consider(input, result)?; - } - if self.version_is_at_least_0_6_0 { - let result = self.parse_token_with_trivia::( - input, - TokenKind::AsteriskAsterisk, - ); - choice.consider(input, result)?; - } - choice.finish(input) - }), - ) - }; - let parse_postfix_expression = |input: &mut ParserContext| { - PrecedenceHelper::to_postfix_operator( - RuleKind::UnaryPostfixExpression, - 29u8, + 7u8, + 7u8 + 1, ChoiceHelper::run(input, |mut choice, input| { let result = self.parse_token_with_trivia::( input, - TokenKind::PlusPlus, + TokenKind::Equal, ); choice.consider(input, result)?; let result = self.parse_token_with_trivia::( input, - TokenKind::MinusMinus, + TokenKind::BarEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::PlusEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::MinusEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::CaretEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::SlashEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::PercentEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::AsteriskEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::AmpersandEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::LessThanLessThanEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::GreaterThanGreaterThanEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::GreaterThanGreaterThanGreaterThanEqual, + ); + choice.consider(input, result)?; + choice.finish(input) + }), + ) + }; + let parse_assignment_expression = |input: &mut ParserContext| { + PrecedenceHelper::to_binary_operator( + RuleKind::BinaryExpression, + 9u8, + 9u8 + 1, + ChoiceHelper::run(input, |mut choice, input| { + let result = self.parse_token_with_trivia::( + input, + TokenKind::Equal, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::BarEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::PlusEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::MinusEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::CaretEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::SlashEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::PercentEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::AsteriskEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::AmpersandEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::LessThanLessThanEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::GreaterThanGreaterThanEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::GreaterThanGreaterThanGreaterThanEqual, + ); + choice.consider(input, result)?; + choice.finish(input) + }), + ) + }; + let parse_assignment_expression = |input: &mut ParserContext| { + PrecedenceHelper::to_binary_operator( + RuleKind::BinaryExpression, + 11u8, + 11u8 + 1, + ChoiceHelper::run(input, |mut choice, input| { + let result = self.parse_token_with_trivia::( + input, + TokenKind::Equal, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::BarEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::PlusEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::MinusEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::CaretEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::SlashEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::PercentEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::AsteriskEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::AmpersandEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::LessThanLessThanEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::GreaterThanGreaterThanEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::GreaterThanGreaterThanGreaterThanEqual, + ); + choice.consider(input, result)?; + choice.finish(input) + }), + ) + }; + let parse_assignment_expression = |input: &mut ParserContext| { + PrecedenceHelper::to_binary_operator( + RuleKind::BinaryExpression, + 13u8, + 13u8 + 1, + ChoiceHelper::run(input, |mut choice, input| { + let result = self.parse_token_with_trivia::( + input, + TokenKind::Equal, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::BarEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::PlusEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::MinusEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::CaretEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::SlashEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::PercentEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::AsteriskEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::AmpersandEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::LessThanLessThanEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::GreaterThanGreaterThanEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::GreaterThanGreaterThanGreaterThanEqual, + ); + choice.consider(input, result)?; + choice.finish(input) + }), + ) + }; + let parse_assignment_expression = |input: &mut ParserContext| { + PrecedenceHelper::to_binary_operator( + RuleKind::BinaryExpression, + 15u8, + 15u8 + 1, + ChoiceHelper::run(input, |mut choice, input| { + let result = self.parse_token_with_trivia::( + input, + TokenKind::Equal, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::BarEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::PlusEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::MinusEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::CaretEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::SlashEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::PercentEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::AsteriskEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::AmpersandEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::LessThanLessThanEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::GreaterThanGreaterThanEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::GreaterThanGreaterThanGreaterThanEqual, + ); + choice.consider(input, result)?; + choice.finish(input) + }), + ) + }; + let parse_assignment_expression = |input: &mut ParserContext| { + PrecedenceHelper::to_binary_operator( + RuleKind::BinaryExpression, + 17u8, + 17u8 + 1, + ChoiceHelper::run(input, |mut choice, input| { + let result = self.parse_token_with_trivia::( + input, + TokenKind::Equal, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::BarEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::PlusEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::MinusEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::CaretEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::SlashEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::PercentEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::AsteriskEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::AmpersandEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::LessThanLessThanEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::GreaterThanGreaterThanEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::GreaterThanGreaterThanGreaterThanEqual, + ); + choice.consider(input, result)?; + choice.finish(input) + }), + ) + }; + let parse_assignment_expression = |input: &mut ParserContext| { + PrecedenceHelper::to_binary_operator( + RuleKind::BinaryExpression, + 19u8, + 19u8 + 1, + ChoiceHelper::run(input, |mut choice, input| { + let result = self.parse_token_with_trivia::( + input, + TokenKind::Equal, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::BarEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::PlusEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::MinusEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::CaretEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::SlashEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::PercentEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::AsteriskEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::AmpersandEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::LessThanLessThanEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::GreaterThanGreaterThanEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::GreaterThanGreaterThanGreaterThanEqual, + ); + choice.consider(input, result)?; + choice.finish(input) + }), + ) + }; + let parse_assignment_expression = |input: &mut ParserContext| { + PrecedenceHelper::to_binary_operator( + RuleKind::BinaryExpression, + 21u8, + 21u8 + 1, + ChoiceHelper::run(input, |mut choice, input| { + let result = self.parse_token_with_trivia::( + input, + TokenKind::Equal, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::BarEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::PlusEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::MinusEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::CaretEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::SlashEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::PercentEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::AsteriskEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::AmpersandEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::LessThanLessThanEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::GreaterThanGreaterThanEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::GreaterThanGreaterThanGreaterThanEqual, + ); + choice.consider(input, result)?; + choice.finish(input) + }), + ) + }; + let parse_assignment_expression = |input: &mut ParserContext| { + PrecedenceHelper::to_binary_operator( + RuleKind::BinaryExpression, + 23u8, + 23u8 + 1, + ChoiceHelper::run(input, |mut choice, input| { + let result = self.parse_token_with_trivia::( + input, + TokenKind::Equal, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::BarEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::PlusEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::MinusEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::CaretEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::SlashEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::PercentEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::AsteriskEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::AmpersandEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::LessThanLessThanEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::GreaterThanGreaterThanEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::GreaterThanGreaterThanGreaterThanEqual, + ); + choice.consider(input, result)?; + choice.finish(input) + }), + ) + }; + let parse_conditional_expression = |input: &mut ParserContext| { + PrecedenceHelper::to_postfix_operator( + RuleKind::ConditionalExpression, + 25u8, + SequenceHelper::run(|mut seq| { + seq.elem(self.parse_token_with_trivia::( + input, + TokenKind::QuestionMark, + ))?; + seq.elem(self.expression(input))?; + seq.elem(self.parse_token_with_trivia::( + input, + TokenKind::Colon, + ))?; + seq.elem(self.expression(input))?; + seq.finish() + }), + ) + }; + let parse_or_expression = |input: &mut ParserContext| { + PrecedenceHelper::to_binary_operator( + RuleKind::BinaryExpression, + 27u8, + 27u8 + 1, + self.parse_token_with_trivia::( + input, + TokenKind::BarBar, + ), + ) + }; + let parse_and_expression = |input: &mut ParserContext| { + PrecedenceHelper::to_binary_operator( + RuleKind::BinaryExpression, + 29u8, + 29u8 + 1, + self.parse_token_with_trivia::( + input, + TokenKind::AmpersandAmpersand, + ), + ) + }; + let parse_equality_expression = |input: &mut ParserContext| { + PrecedenceHelper::to_binary_operator( + RuleKind::BinaryExpression, + 31u8, + 31u8 + 1, + ChoiceHelper::run(input, |mut choice, input| { + let result = self.parse_token_with_trivia::( + input, + TokenKind::EqualEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::BangEqual, + ); + choice.consider(input, result)?; + choice.finish(input) + }), + ) + }; + let parse_equality_expression = |input: &mut ParserContext| { + PrecedenceHelper::to_binary_operator( + RuleKind::BinaryExpression, + 33u8, + 33u8 + 1, + ChoiceHelper::run(input, |mut choice, input| { + let result = self.parse_token_with_trivia::( + input, + TokenKind::EqualEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::BangEqual, + ); + choice.consider(input, result)?; + choice.finish(input) + }), + ) + }; + let parse_comparison_expression = |input: &mut ParserContext| { + PrecedenceHelper::to_binary_operator( + RuleKind::BinaryExpression, + 35u8, + 35u8 + 1, + ChoiceHelper::run(input, |mut choice, input| { + let result = self.parse_token_with_trivia::( + input, + TokenKind::LessThan, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::GreaterThan, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::LessThanEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::GreaterThanEqual, + ); + choice.consider(input, result)?; + choice.finish(input) + }), + ) + }; + let parse_comparison_expression = |input: &mut ParserContext| { + PrecedenceHelper::to_binary_operator( + RuleKind::BinaryExpression, + 37u8, + 37u8 + 1, + ChoiceHelper::run(input, |mut choice, input| { + let result = self.parse_token_with_trivia::( + input, + TokenKind::LessThan, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::GreaterThan, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::LessThanEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::GreaterThanEqual, + ); + choice.consider(input, result)?; + choice.finish(input) + }), + ) + }; + let parse_comparison_expression = |input: &mut ParserContext| { + PrecedenceHelper::to_binary_operator( + RuleKind::BinaryExpression, + 39u8, + 39u8 + 1, + ChoiceHelper::run(input, |mut choice, input| { + let result = self.parse_token_with_trivia::( + input, + TokenKind::LessThan, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::GreaterThan, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::LessThanEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::GreaterThanEqual, + ); + choice.consider(input, result)?; + choice.finish(input) + }), + ) + }; + let parse_comparison_expression = |input: &mut ParserContext| { + PrecedenceHelper::to_binary_operator( + RuleKind::BinaryExpression, + 41u8, + 41u8 + 1, + ChoiceHelper::run(input, |mut choice, input| { + let result = self.parse_token_with_trivia::( + input, + TokenKind::LessThan, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::GreaterThan, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::LessThanEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::GreaterThanEqual, + ); + choice.consider(input, result)?; + choice.finish(input) + }), + ) + }; + let parse_bitwise_or_expression = |input: &mut ParserContext| { + PrecedenceHelper::to_binary_operator( + RuleKind::BinaryExpression, + 43u8, + 43u8 + 1, + self.parse_token_with_trivia::(input, TokenKind::Bar), + ) + }; + let parse_bitwise_xor_expression = |input: &mut ParserContext| { + PrecedenceHelper::to_binary_operator( + RuleKind::BinaryExpression, + 45u8, + 45u8 + 1, + self.parse_token_with_trivia::( + input, + TokenKind::Caret, + ), + ) + }; + let parse_bitwise_and_expression = |input: &mut ParserContext| { + PrecedenceHelper::to_binary_operator( + RuleKind::BinaryExpression, + 47u8, + 47u8 + 1, + self.parse_token_with_trivia::( + input, + TokenKind::Ampersand, + ), + ) + }; + let parse_shift_expression = |input: &mut ParserContext| { + PrecedenceHelper::to_binary_operator( + RuleKind::BinaryExpression, + 49u8, + 49u8 + 1, + ChoiceHelper::run(input, |mut choice, input| { + let result = self.parse_token_with_trivia::( + input, + TokenKind::LessThanLessThan, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::GreaterThanGreaterThan, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::GreaterThanGreaterThanGreaterThan, + ); + choice.consider(input, result)?; + choice.finish(input) + }), + ) + }; + let parse_shift_expression = |input: &mut ParserContext| { + PrecedenceHelper::to_binary_operator( + RuleKind::BinaryExpression, + 51u8, + 51u8 + 1, + ChoiceHelper::run(input, |mut choice, input| { + let result = self.parse_token_with_trivia::( + input, + TokenKind::LessThanLessThan, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::GreaterThanGreaterThan, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::GreaterThanGreaterThanGreaterThan, + ); + choice.consider(input, result)?; + choice.finish(input) + }), + ) + }; + let parse_shift_expression = |input: &mut ParserContext| { + PrecedenceHelper::to_binary_operator( + RuleKind::BinaryExpression, + 53u8, + 53u8 + 1, + ChoiceHelper::run(input, |mut choice, input| { + let result = self.parse_token_with_trivia::( + input, + TokenKind::LessThanLessThan, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::GreaterThanGreaterThan, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::GreaterThanGreaterThanGreaterThan, + ); + choice.consider(input, result)?; + choice.finish(input) + }), + ) + }; + let parse_additive_expression = |input: &mut ParserContext| { + PrecedenceHelper::to_binary_operator( + RuleKind::BinaryExpression, + 55u8, + 55u8 + 1, + ChoiceHelper::run(input, |mut choice, input| { + let result = self.parse_token_with_trivia::( + input, + TokenKind::Plus, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::Minus, + ); + choice.consider(input, result)?; + choice.finish(input) + }), + ) + }; + let parse_additive_expression = |input: &mut ParserContext| { + PrecedenceHelper::to_binary_operator( + RuleKind::BinaryExpression, + 57u8, + 57u8 + 1, + ChoiceHelper::run(input, |mut choice, input| { + let result = self.parse_token_with_trivia::( + input, + TokenKind::Plus, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::Minus, + ); + choice.consider(input, result)?; + choice.finish(input) + }), + ) + }; + let parse_multiplicative_expression = |input: &mut ParserContext| { + PrecedenceHelper::to_binary_operator( + RuleKind::BinaryExpression, + 59u8, + 59u8 + 1, + ChoiceHelper::run(input, |mut choice, input| { + let result = self.parse_token_with_trivia::( + input, + TokenKind::Asterisk, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::Slash, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::Percent, + ); + choice.consider(input, result)?; + choice.finish(input) + }), + ) + }; + let parse_multiplicative_expression = |input: &mut ParserContext| { + PrecedenceHelper::to_binary_operator( + RuleKind::BinaryExpression, + 61u8, + 61u8 + 1, + ChoiceHelper::run(input, |mut choice, input| { + let result = self.parse_token_with_trivia::( + input, + TokenKind::Asterisk, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::Slash, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::Percent, + ); + choice.consider(input, result)?; + choice.finish(input) + }), + ) + }; + let parse_multiplicative_expression = |input: &mut ParserContext| { + PrecedenceHelper::to_binary_operator( + RuleKind::BinaryExpression, + 63u8, + 63u8 + 1, + ChoiceHelper::run(input, |mut choice, input| { + let result = self.parse_token_with_trivia::( + input, + TokenKind::Asterisk, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::Slash, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::Percent, + ); + choice.consider(input, result)?; + choice.finish(input) + }), + ) + }; + let parse_exponentiation_expression_removed_from_0_6_0 = |input: &mut ParserContext| { + PrecedenceHelper::to_binary_operator( + RuleKind::BinaryExpression, + 65u8, + 65u8 + 1, + ChoiceHelper::run(input, |mut choice, input| { + if !self.version_is_at_least_0_6_0 { + let result = self.parse_token_with_trivia::( + input, + TokenKind::AsteriskAsterisk, + ); + choice.consider(input, result)?; + } + if self.version_is_at_least_0_6_0 { + let result = self.parse_token_with_trivia::( + input, + TokenKind::AsteriskAsterisk, + ); + choice.consider(input, result)?; + } + choice.finish(input) + }), + ) + }; + let parse_exponentiation_expression_introduced_from_0_6_0 = |input: &mut ParserContext| { + PrecedenceHelper::to_binary_operator( + RuleKind::BinaryExpression, + 67u8 + 1, + 67u8, + ChoiceHelper::run(input, |mut choice, input| { + if !self.version_is_at_least_0_6_0 { + let result = self.parse_token_with_trivia::( + input, + TokenKind::AsteriskAsterisk, + ); + choice.consider(input, result)?; + } + if self.version_is_at_least_0_6_0 { + let result = self.parse_token_with_trivia::( + input, + TokenKind::AsteriskAsterisk, + ); + choice.consider(input, result)?; + } + choice.finish(input) + }), + ) + }; + let parse_postfix_expression = |input: &mut ParserContext| { + PrecedenceHelper::to_postfix_operator( + RuleKind::UnaryPostfixExpression, + 69u8, + ChoiceHelper::run(input, |mut choice, input| { + let result = self.parse_token_with_trivia::( + input, + TokenKind::PlusPlus, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::MinusMinus, + ); + choice.consider(input, result)?; + choice.finish(input) + }), + ) + }; + let parse_postfix_expression = |input: &mut ParserContext| { + PrecedenceHelper::to_postfix_operator( + RuleKind::UnaryPostfixExpression, + 71u8, + ChoiceHelper::run(input, |mut choice, input| { + let result = self.parse_token_with_trivia::( + input, + TokenKind::PlusPlus, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::MinusMinus, + ); + choice.consider(input, result)?; + choice.finish(input) + }), + ) + }; + let parse_prefix_expression = |input: &mut ParserContext| { + PrecedenceHelper::to_prefix_operator( + RuleKind::UnaryPrefixExpression, + 73u8, + ChoiceHelper::run(input, |mut choice, input| { + let result = self.parse_token_with_trivia::( + input, + TokenKind::PlusPlus, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::MinusMinus, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::Tilde, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::Bang, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::Minus, + ); + choice.consider(input, result)?; + if !self.version_is_at_least_0_5_0 { + let result = self.parse_token_with_trivia::( + input, + TokenKind::Plus, + ); + choice.consider(input, result)?; + } + choice.finish(input) + }), + ) + }; + let parse_prefix_expression = |input: &mut ParserContext| { + PrecedenceHelper::to_prefix_operator( + RuleKind::UnaryPrefixExpression, + 75u8, + ChoiceHelper::run(input, |mut choice, input| { + let result = self.parse_token_with_trivia::( + input, + TokenKind::PlusPlus, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::MinusMinus, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::Tilde, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::Bang, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::Minus, ); choice.consider(input, result)?; - choice.finish(input) - }), - ) - }; - let parse_prefix_expression_removed_from_0_5_0 = |input: &mut ParserContext| { - PrecedenceHelper::to_prefix_operator( - RuleKind::UnaryPrefixExpression, - 31u8, - ChoiceHelper::run(input, |mut choice, input| { if !self.version_is_at_least_0_5_0 { - let result = ChoiceHelper::run(input, |mut choice, input| { - let result = self - .parse_token_with_trivia::( - input, - TokenKind::PlusPlus, - ); - choice.consider(input, result)?; - let result = self - .parse_token_with_trivia::( - input, - TokenKind::MinusMinus, - ); - choice.consider(input, result)?; - let result = self - .parse_token_with_trivia::( - input, - TokenKind::Tilde, - ); - choice.consider(input, result)?; - let result = self - .parse_token_with_trivia::( - input, - TokenKind::Bang, - ); - choice.consider(input, result)?; - let result = self - .parse_token_with_trivia::( - input, - TokenKind::Minus, - ); - choice.consider(input, result)?; - let result = self - .parse_token_with_trivia::( - input, - TokenKind::Plus, - ); - choice.consider(input, result)?; - choice.finish(input) - }); + let result = self.parse_token_with_trivia::( + input, + TokenKind::Plus, + ); choice.consider(input, result)?; } - if self.version_is_at_least_0_5_0 { - let result = ChoiceHelper::run(input, |mut choice, input| { - let result = self - .parse_token_with_trivia::( - input, - TokenKind::PlusPlus, - ); - choice.consider(input, result)?; - let result = self - .parse_token_with_trivia::( - input, - TokenKind::MinusMinus, - ); - choice.consider(input, result)?; - let result = self - .parse_token_with_trivia::( - input, - TokenKind::Tilde, - ); - choice.consider(input, result)?; - let result = self - .parse_token_with_trivia::( - input, - TokenKind::Bang, - ); - choice.consider(input, result)?; - let result = self - .parse_token_with_trivia::( - input, - TokenKind::Minus, - ); - choice.consider(input, result)?; - choice.finish(input) - }); + choice.finish(input) + }), + ) + }; + let parse_prefix_expression = |input: &mut ParserContext| { + PrecedenceHelper::to_prefix_operator( + RuleKind::UnaryPrefixExpression, + 77u8, + ChoiceHelper::run(input, |mut choice, input| { + let result = self.parse_token_with_trivia::( + input, + TokenKind::PlusPlus, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::MinusMinus, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::Tilde, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::Bang, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::Minus, + ); + choice.consider(input, result)?; + if !self.version_is_at_least_0_5_0 { + let result = self.parse_token_with_trivia::( + input, + TokenKind::Plus, + ); choice.consider(input, result)?; } choice.finish(input) }), ) }; - let parse_prefix_expression_introduced_from_0_5_0 = |input: &mut ParserContext| { + let parse_prefix_expression = |input: &mut ParserContext| { PrecedenceHelper::to_prefix_operator( RuleKind::UnaryPrefixExpression, - 33u8, + 79u8, + ChoiceHelper::run(input, |mut choice, input| { + let result = self.parse_token_with_trivia::( + input, + TokenKind::PlusPlus, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::MinusMinus, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::Tilde, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::Bang, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::Minus, + ); + choice.consider(input, result)?; + if !self.version_is_at_least_0_5_0 { + let result = self.parse_token_with_trivia::( + input, + TokenKind::Plus, + ); + choice.consider(input, result)?; + } + choice.finish(input) + }), + ) + }; + let parse_prefix_expression = |input: &mut ParserContext| { + PrecedenceHelper::to_prefix_operator( + RuleKind::UnaryPrefixExpression, + 81u8, ChoiceHelper::run(input, |mut choice, input| { + let result = self.parse_token_with_trivia::( + input, + TokenKind::PlusPlus, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::MinusMinus, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::Tilde, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::Bang, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::Minus, + ); + choice.consider(input, result)?; if !self.version_is_at_least_0_5_0 { - let result = ChoiceHelper::run(input, |mut choice, input| { - let result = self - .parse_token_with_trivia::( - input, - TokenKind::PlusPlus, - ); - choice.consider(input, result)?; - let result = self - .parse_token_with_trivia::( - input, - TokenKind::MinusMinus, - ); - choice.consider(input, result)?; - let result = self - .parse_token_with_trivia::( - input, - TokenKind::Tilde, - ); - choice.consider(input, result)?; - let result = self - .parse_token_with_trivia::( - input, - TokenKind::Bang, - ); - choice.consider(input, result)?; - let result = self - .parse_token_with_trivia::( - input, - TokenKind::Minus, - ); - choice.consider(input, result)?; - let result = self - .parse_token_with_trivia::( - input, - TokenKind::Plus, - ); - choice.consider(input, result)?; - choice.finish(input) - }); + let result = self.parse_token_with_trivia::( + input, + TokenKind::Plus, + ); choice.consider(input, result)?; } - if self.version_is_at_least_0_5_0 { - let result = ChoiceHelper::run(input, |mut choice, input| { - let result = self - .parse_token_with_trivia::( - input, - TokenKind::PlusPlus, - ); - choice.consider(input, result)?; - let result = self - .parse_token_with_trivia::( - input, - TokenKind::MinusMinus, - ); - choice.consider(input, result)?; - let result = self - .parse_token_with_trivia::( - input, - TokenKind::Tilde, - ); - choice.consider(input, result)?; - let result = self - .parse_token_with_trivia::( - input, - TokenKind::Bang, - ); - choice.consider(input, result)?; - let result = self - .parse_token_with_trivia::( - input, - TokenKind::Minus, - ); - choice.consider(input, result)?; - choice.finish(input) - }); + choice.finish(input) + }), + ) + }; + let parse_prefix_expression_removed_from_0_5_0 = |input: &mut ParserContext| { + PrecedenceHelper::to_prefix_operator( + RuleKind::UnaryPrefixExpression, + 83u8, + ChoiceHelper::run(input, |mut choice, input| { + let result = self.parse_token_with_trivia::( + input, + TokenKind::PlusPlus, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::MinusMinus, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::Tilde, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::Bang, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::Minus, + ); + choice.consider(input, result)?; + if !self.version_is_at_least_0_5_0 { + let result = self.parse_token_with_trivia::( + input, + TokenKind::Plus, + ); choice.consider(input, result)?; } choice.finish(input) @@ -1762,7 +2853,7 @@ impl Language { let parse_function_call_expression = |input: &mut ParserContext| { PrecedenceHelper::to_postfix_operator( RuleKind::FunctionCallExpression, - 35u8, + 85u8, SequenceHelper::run(|mut seq| { if self.version_is_at_least_0_6_2 { seq.elem(OptionalHelper::transform( @@ -1799,33 +2890,73 @@ impl Language { let parse_member_access_expression = |input: &mut ParserContext| { PrecedenceHelper::to_postfix_operator( RuleKind::MemberAccessExpression, - 37u8, - SequenceHelper::run(|mut seq| { - seq.elem(self.parse_token_with_trivia::( - input, - TokenKind::Period, - ))?; - seq.elem(ChoiceHelper::run(input, |mut choice, input| { - let result = self.parse_token_with_trivia::( + 87u8, + ChoiceHelper::run(input, |mut choice, input| { + let result = SequenceHelper::run(|mut seq| { + seq.elem(self.parse_token_with_trivia::( + input, + TokenKind::Period, + ))?; + seq.elem(self.parse_token_with_trivia::( input, TokenKind::Identifier, - ); - choice.consider(input, result)?; - let result = self.parse_token_with_trivia::( + ))?; + seq.finish() + }); + choice.consider(input, result)?; + let result = SequenceHelper::run(|mut seq| { + seq.elem(self.parse_token_with_trivia::( + input, + TokenKind::Period, + ))?; + seq.elem(self.parse_token_with_trivia::( input, TokenKind::AddressKeyword, - ); - choice.consider(input, result)?; - choice.finish(input) - }))?; - seq.finish() + ))?; + seq.finish() + }); + choice.consider(input, result)?; + choice.finish(input) + }), + ) + }; + let parse_member_access_expression = |input: &mut ParserContext| { + PrecedenceHelper::to_postfix_operator( + RuleKind::MemberAccessExpression, + 89u8, + ChoiceHelper::run(input, |mut choice, input| { + let result = SequenceHelper::run(|mut seq| { + seq.elem(self.parse_token_with_trivia::( + input, + TokenKind::Period, + ))?; + seq.elem(self.parse_token_with_trivia::( + input, + TokenKind::Identifier, + ))?; + seq.finish() + }); + choice.consider(input, result)?; + let result = SequenceHelper::run(|mut seq| { + seq.elem(self.parse_token_with_trivia::( + input, + TokenKind::Period, + ))?; + seq.elem(self.parse_token_with_trivia::( + input, + TokenKind::AddressKeyword, + ))?; + seq.finish() + }); + choice.consider(input, result)?; + choice.finish(input) }), ) }; let parse_index_access_expression = |input: &mut ParserContext| { PrecedenceHelper::to_postfix_operator( RuleKind::IndexAccessExpression, - 39u8, + 91u8, SequenceHelper::run(|mut seq| { let mut delim_guard = input.open_delim(TokenKind::CloseBracket); let input = delim_guard.ctx(); @@ -1856,14 +2987,20 @@ impl Language { }; let prefix_operator_parser = |input: &mut ParserContext| { ChoiceHelper::run(input, |mut choice, input| { + let result = parse_prefix_expression(input); + choice.consider(input, result)?; + let result = parse_prefix_expression(input); + choice.consider(input, result)?; + let result = parse_prefix_expression(input); + choice.consider(input, result)?; + let result = parse_prefix_expression(input); + choice.consider(input, result)?; + let result = parse_prefix_expression(input); + choice.consider(input, result)?; if !self.version_is_at_least_0_5_0 { let result = parse_prefix_expression_removed_from_0_5_0(input); choice.consider(input, result)?; } - if self.version_is_at_least_0_5_0 { - let result = parse_prefix_expression_introduced_from_0_5_0(input); - choice.consider(input, result)?; - } choice.finish(input) }) }; @@ -1972,10 +3109,14 @@ impl Language { choice.consider(input, result)?; let result = parse_postfix_expression(input); choice.consider(input, result)?; + let result = parse_postfix_expression(input); + choice.consider(input, result)?; let result = parse_function_call_expression(input); choice.consider(input, result)?; let result = parse_member_access_expression(input); choice.consider(input, result)?; + let result = parse_member_access_expression(input); + choice.consider(input, result)?; let result = parse_index_access_expression(input); choice.consider(input, result)?; choice.finish(input) @@ -1995,6 +3136,28 @@ impl Language { }; let binary_operator_parser = |input: &mut ParserContext| { ChoiceHelper::run(input, |mut choice, input| { + let result = parse_assignment_expression(input); + choice.consider(input, result)?; + let result = parse_assignment_expression(input); + choice.consider(input, result)?; + let result = parse_assignment_expression(input); + choice.consider(input, result)?; + let result = parse_assignment_expression(input); + choice.consider(input, result)?; + let result = parse_assignment_expression(input); + choice.consider(input, result)?; + let result = parse_assignment_expression(input); + choice.consider(input, result)?; + let result = parse_assignment_expression(input); + choice.consider(input, result)?; + let result = parse_assignment_expression(input); + choice.consider(input, result)?; + let result = parse_assignment_expression(input); + choice.consider(input, result)?; + let result = parse_assignment_expression(input); + choice.consider(input, result)?; + let result = parse_assignment_expression(input); + choice.consider(input, result)?; let result = parse_assignment_expression(input); choice.consider(input, result)?; let result = parse_or_expression(input); @@ -2003,6 +3166,14 @@ impl Language { choice.consider(input, result)?; let result = parse_equality_expression(input); choice.consider(input, result)?; + let result = parse_equality_expression(input); + choice.consider(input, result)?; + let result = parse_comparison_expression(input); + choice.consider(input, result)?; + let result = parse_comparison_expression(input); + choice.consider(input, result)?; + let result = parse_comparison_expression(input); + choice.consider(input, result)?; let result = parse_comparison_expression(input); choice.consider(input, result)?; let result = parse_bitwise_or_expression(input); @@ -2013,10 +3184,20 @@ impl Language { choice.consider(input, result)?; let result = parse_shift_expression(input); choice.consider(input, result)?; + let result = parse_shift_expression(input); + choice.consider(input, result)?; + let result = parse_shift_expression(input); + choice.consider(input, result)?; + let result = parse_additive_expression(input); + choice.consider(input, result)?; let result = parse_additive_expression(input); choice.consider(input, result)?; let result = parse_multiplicative_expression(input); choice.consider(input, result)?; + let result = parse_multiplicative_expression(input); + choice.consider(input, result)?; + let result = parse_multiplicative_expression(input); + choice.consider(input, result)?; if !self.version_is_at_least_0_6_0 { let result = parse_exponentiation_expression_removed_from_0_6_0(input); choice.consider(input, result)?; @@ -4267,44 +5448,183 @@ impl Language { choice.consider(input, result)?; let result = self.parse_token_with_trivia::( input, - TokenKind::UfixedKeyword, + TokenKind::UfixedKeyword, + ); + choice.consider(input, result)?; + choice.finish(input) + }); + choice.consider(input, result)?; + let result = self.identifier_path(input); + choice.consider(input, result)?; + choice.finish(input) + }) + }; + let postfix_operator_parser = |input: &mut ParserContext| { + ChoiceHelper::run(input, |mut choice, input| { + let result = parse_array_type_name(input); + choice.consider(input, result)?; + choice.finish(input) + }) + }; + let linear_expression_parser = |input: &mut ParserContext| { + SequenceHelper::run(|mut seq| { + seq.elem(primary_expression_parser(input))?; + seq.elem(ZeroOrMoreHelper::run(input, |input| { + postfix_operator_parser(input) + }))?; + seq.finish() + }) + }; + PrecedenceHelper::reduce_precedence_result( + Some(RuleKind::TypeName), + linear_expression_parser(input), + ) + .with_kind(RuleKind::TypeName) + } + + #[allow(unused_assignments, unused_parens)] + fn typed_tuple_member(&self, input: &mut ParserContext) -> ParserResult { + SequenceHelper::run(|mut seq| { + seq.elem(self.type_name(input))?; + seq.elem(OptionalHelper::transform(ChoiceHelper::run( + input, + |mut choice, input| { + let result = self.parse_token_with_trivia::( + input, + TokenKind::MemoryKeyword, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::StorageKeyword, + ); + choice.consider(input, result)?; + if self.version_is_at_least_0_5_0 { + let result = self.parse_token_with_trivia::( + input, + TokenKind::CallDataKeyword, + ); + choice.consider(input, result)?; + } + choice.finish(input) + }, + )))?; + seq.elem(self.parse_token_with_trivia::( + input, + TokenKind::Identifier, + ))?; + seq.finish() + }) + .with_kind(RuleKind::TypedTupleMember) + } + + #[allow(unused_assignments, unused_parens)] + fn unchecked_block(&self, input: &mut ParserContext) -> ParserResult { + if self.version_is_at_least_0_8_0 { + SequenceHelper::run(|mut seq| { + seq.elem(self.parse_token_with_trivia::( + input, + TokenKind::UncheckedKeyword, + ))?; + seq.elem(self.block(input))?; + seq.finish() + }) + } else { + ParserResult::disabled() + } + .with_kind(RuleKind::UncheckedBlock) + } + + #[allow(unused_assignments, unused_parens)] + fn unicode_string_literals(&self, input: &mut ParserContext) -> ParserResult { + if self.version_is_at_least_0_7_0 { + OneOrMoreHelper::run(input, |input| { + self.parse_token_with_trivia::( + input, + TokenKind::UnicodeStringLiteral, + ) + }) + } else { + ParserResult::disabled() + } + .with_kind(RuleKind::UnicodeStringLiterals) + } + + #[allow(unused_assignments, unused_parens)] + fn unnamed_function_attributes(&self, input: &mut ParserContext) -> ParserResult { + if !self.version_is_at_least_0_6_0 { + OneOrMoreHelper::run(input, |input| { + if !self.version_is_at_least_0_6_0 { + ChoiceHelper::run(input, |mut choice, input| { + let result = self.modifier_invocation(input); + choice.consider(input, result)?; + let result = self.override_specifier(input); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::ExternalKeyword, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::PayableKeyword, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::PureKeyword, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::ViewKeyword, + ); + choice.consider(input, result)?; + choice.finish(input) + }) + } else { + ParserResult::disabled() + } + }) + } else { + ParserResult::disabled() + } + .with_kind(RuleKind::UnnamedFunctionAttributes) + } + + #[allow(unused_assignments, unused_parens)] + fn unnamed_function_definition(&self, input: &mut ParserContext) -> ParserResult { + if !self.version_is_at_least_0_6_0 { + SequenceHelper::run(|mut seq| { + seq.elem(self.parse_token_with_trivia::( + input, + TokenKind::FunctionKeyword, + ))?; + seq.elem(self.parameters_declaration(input))?; + seq.elem(OptionalHelper::transform( + self.unnamed_function_attributes(input), + ))?; + seq.elem(ChoiceHelper::run(input, |mut choice, input| { + let result = self.block(input); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::Semicolon, ); choice.consider(input, result)?; choice.finish(input) - }); - choice.consider(input, result)?; - let result = self.identifier_path(input); - choice.consider(input, result)?; - choice.finish(input) - }) - }; - let postfix_operator_parser = |input: &mut ParserContext| { - ChoiceHelper::run(input, |mut choice, input| { - let result = parse_array_type_name(input); - choice.consider(input, result)?; - choice.finish(input) - }) - }; - let linear_expression_parser = |input: &mut ParserContext| { - SequenceHelper::run(|mut seq| { - seq.elem(primary_expression_parser(input))?; - seq.elem(ZeroOrMoreHelper::run(input, |input| { - postfix_operator_parser(input) }))?; seq.finish() }) - }; - PrecedenceHelper::reduce_precedence_result( - Some(RuleKind::TypeName), - linear_expression_parser(input), - ) - .with_kind(RuleKind::TypeName) + } else { + ParserResult::disabled() + } + .with_kind(RuleKind::UnnamedFunctionDefinition) } #[allow(unused_assignments, unused_parens)] - fn typed_tuple_member(&self, input: &mut ParserContext) -> ParserResult { + fn untyped_tuple_member(&self, input: &mut ParserContext) -> ParserResult { SequenceHelper::run(|mut seq| { - seq.elem(self.type_name(input))?; seq.elem(OptionalHelper::transform(ChoiceHelper::run( input, |mut choice, input| { @@ -4334,584 +5654,713 @@ impl Language { ))?; seq.finish() }) - .with_kind(RuleKind::TypedTupleMember) + .with_kind(RuleKind::UntypedTupleMember) } #[allow(unused_assignments, unused_parens)] - fn unchecked_block(&self, input: &mut ParserContext) -> ParserResult { - if self.version_is_at_least_0_8_0 { + fn user_defined_value_type_definition(&self, input: &mut ParserContext) -> ParserResult { + if self.version_is_at_least_0_8_8 { SequenceHelper::run(|mut seq| { + seq.elem( + SequenceHelper::run(|mut seq| { + seq.elem(self.parse_token_with_trivia::( + input, + TokenKind::TypeKeyword, + ))?; + seq.elem(self.parse_token_with_trivia::( + input, + TokenKind::Identifier, + ))?; + seq.elem(self.parse_token_with_trivia::( + input, + TokenKind::IsKeyword, + ))?; + seq.elem(ChoiceHelper::run(input, |mut choice, input| { + let result = self + .parse_token_with_trivia::( + input, + TokenKind::BoolKeyword, + ); + choice.consider(input, result)?; + if !self.version_is_at_least_0_8_0 { + let result = self + .parse_token_with_trivia::( + input, + TokenKind::ByteKeyword, + ); + choice.consider(input, result)?; + } + let result = self + .parse_token_with_trivia::( + input, + TokenKind::StringKeyword, + ); + choice.consider(input, result)?; + let result = self.address_type(input); + choice.consider(input, result)?; + let result = self + .parse_token_with_trivia::( + input, + TokenKind::PayableKeyword, + ); + choice.consider(input, result)?; + let result = self + .parse_token_with_trivia::( + input, + TokenKind::BytesKeyword, + ); + choice.consider(input, result)?; + let result = self + .parse_token_with_trivia::( + input, + TokenKind::IntKeyword, + ); + choice.consider(input, result)?; + let result = self + .parse_token_with_trivia::( + input, + TokenKind::UintKeyword, + ); + choice.consider(input, result)?; + let result = self + .parse_token_with_trivia::( + input, + TokenKind::FixedKeyword, + ); + choice.consider(input, result)?; + let result = self + .parse_token_with_trivia::( + input, + TokenKind::UfixedKeyword, + ); + choice.consider(input, result)?; + choice.finish(input) + }))?; + seq.finish() + }) + .recover_until_with_nested_delims::<_, LexicalContextType::Default>( + input, + self, + TokenKind::Semicolon, + RecoverFromNoMatch::No, + ), + )?; seq.elem(self.parse_token_with_trivia::( input, - TokenKind::UncheckedKeyword, + TokenKind::Semicolon, ))?; - seq.elem(self.block(input))?; seq.finish() }) } else { ParserResult::disabled() } - .with_kind(RuleKind::UncheckedBlock) + .with_kind(RuleKind::UserDefinedValueTypeDefinition) } #[allow(unused_assignments, unused_parens)] - fn unicode_string_literals(&self, input: &mut ParserContext) -> ParserResult { - if self.version_is_at_least_0_7_0 { - OneOrMoreHelper::run(input, |input| { - self.parse_token_with_trivia::( + fn using_alias(&self, input: &mut ParserContext) -> ParserResult { + if self.version_is_at_least_0_8_19 { + SequenceHelper::run(|mut seq| { + seq.elem(self.parse_token_with_trivia::( input, - TokenKind::UnicodeStringLiteral, - ) - }) - } else { - ParserResult::disabled() - } - .with_kind(RuleKind::UnicodeStringLiterals) - } - - #[allow(unused_assignments, unused_parens)] - fn unnamed_function_attributes(&self, input: &mut ParserContext) -> ParserResult { - if !self.version_is_at_least_0_6_0 { - OneOrMoreHelper::run(input, |input| { - if !self.version_is_at_least_0_6_0 { + TokenKind::AsKeyword, + ))?; + seq.elem(if self.version_is_at_least_0_8_19 { ChoiceHelper::run(input, |mut choice, input| { - let result = self.modifier_invocation(input); + let result = self.parse_token_with_trivia::( + input, + TokenKind::Ampersand, + ); choice.consider(input, result)?; - let result = self.override_specifier(input); + let result = self.parse_token_with_trivia::( + input, + TokenKind::Asterisk, + ); choice.consider(input, result)?; let result = self.parse_token_with_trivia::( input, - TokenKind::ExternalKeyword, + TokenKind::BangEqual, ); choice.consider(input, result)?; let result = self.parse_token_with_trivia::( input, - TokenKind::PayableKeyword, + TokenKind::Bar, ); choice.consider(input, result)?; let result = self.parse_token_with_trivia::( input, - TokenKind::PureKeyword, + TokenKind::Caret, ); choice.consider(input, result)?; let result = self.parse_token_with_trivia::( input, - TokenKind::ViewKeyword, + TokenKind::EqualEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::GreaterThan, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::GreaterThanEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::LessThan, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::LessThanEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::Minus, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::Percent, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::Plus, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::Slash, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::Tilde, ); choice.consider(input, result)?; choice.finish(input) }) } else { ParserResult::disabled() - } + })?; + seq.finish() + }) + } else { + ParserResult::disabled() + } + .with_kind(RuleKind::UsingAlias) + } + + #[allow(unused_assignments, unused_parens)] + fn using_deconstruction(&self, input: &mut ParserContext) -> ParserResult { + if self.version_is_at_least_0_8_13 { + SequenceHelper::run(|mut seq| { + let mut delim_guard = input.open_delim(TokenKind::CloseBrace); + let input = delim_guard.ctx(); + seq.elem(self.parse_token_with_trivia::( + input, + TokenKind::OpenBrace, + ))?; + seq.elem( + self.using_deconstruction_symbols(input) + .recover_until_with_nested_delims::<_, LexicalContextType::Default>( + input, + self, + TokenKind::CloseBrace, + RecoverFromNoMatch::Yes, + ), + )?; + seq.elem(self.parse_token_with_trivia::( + input, + TokenKind::CloseBrace, + ))?; + seq.finish() }) } else { ParserResult::disabled() } - .with_kind(RuleKind::UnnamedFunctionAttributes) + .with_kind(RuleKind::UsingDeconstruction) } #[allow(unused_assignments, unused_parens)] - fn unnamed_function_definition(&self, input: &mut ParserContext) -> ParserResult { - if !self.version_is_at_least_0_6_0 { + fn using_deconstruction_symbol(&self, input: &mut ParserContext) -> ParserResult { + if self.version_is_at_least_0_8_13 { SequenceHelper::run(|mut seq| { - seq.elem(self.parse_token_with_trivia::( - input, - TokenKind::FunctionKeyword, - ))?; - seq.elem(self.parameters_declaration(input))?; - seq.elem(OptionalHelper::transform( - self.unnamed_function_attributes(input), - ))?; - seq.elem(ChoiceHelper::run(input, |mut choice, input| { - let result = self.block(input); - choice.consider(input, result)?; - let result = self.parse_token_with_trivia::( - input, - TokenKind::Semicolon, - ); - choice.consider(input, result)?; - choice.finish(input) - }))?; + seq.elem(self.identifier_path(input))?; + if self.version_is_at_least_0_8_19 { + seq.elem(OptionalHelper::transform(self.using_alias(input)))?; + } seq.finish() }) } else { ParserResult::disabled() } - .with_kind(RuleKind::UnnamedFunctionDefinition) + .with_kind(RuleKind::UsingDeconstructionSymbol) } #[allow(unused_assignments, unused_parens)] - fn untyped_tuple_member(&self, input: &mut ParserContext) -> ParserResult { - SequenceHelper::run(|mut seq| { - seq.elem(OptionalHelper::transform(ChoiceHelper::run( + fn using_deconstruction_symbols(&self, input: &mut ParserContext) -> ParserResult { + if self.version_is_at_least_0_8_13 { + SeparatedHelper::run::<_, LexicalContextType::Default>( input, - |mut choice, input| { - let result = self.parse_token_with_trivia::( + self, + |input| self.using_deconstruction_symbol(input), + TokenKind::Comma, + ) + } else { + ParserResult::disabled() + } + .with_kind(RuleKind::UsingDeconstructionSymbols) + } + + #[allow(unused_assignments, unused_parens)] + fn using_directive(&self, input: &mut ParserContext) -> ParserResult { + SequenceHelper::run(|mut seq| { + seq.elem( + SequenceHelper::run(|mut seq| { + seq.elem(self.parse_token_with_trivia::( input, - TokenKind::MemoryKeyword, - ); - choice.consider(input, result)?; - let result = self.parse_token_with_trivia::( + TokenKind::UsingKeyword, + ))?; + seq.elem(ChoiceHelper::run(input, |mut choice, input| { + let result = self.identifier_path(input); + choice.consider(input, result)?; + if self.version_is_at_least_0_8_13 { + let result = self.using_deconstruction(input); + choice.consider(input, result)?; + } + choice.finish(input) + }))?; + seq.elem(self.parse_token_with_trivia::( input, - TokenKind::StorageKeyword, - ); - choice.consider(input, result)?; - if self.version_is_at_least_0_5_0 { + TokenKind::ForKeyword, + ))?; + seq.elem(ChoiceHelper::run(input, |mut choice, input| { + let result = self.type_name(input); + choice.consider(input, result)?; let result = self.parse_token_with_trivia::( input, - TokenKind::CallDataKeyword, + TokenKind::Asterisk, ); choice.consider(input, result)?; + choice.finish(input) + }))?; + if self.version_is_at_least_0_8_13 { + seq.elem(OptionalHelper::transform( + self.parse_token_with_trivia::( + input, + TokenKind::GlobalKeyword, + ), + ))?; } - choice.finish(input) - }, - )))?; + seq.finish() + }) + .recover_until_with_nested_delims::<_, LexicalContextType::Default>( + input, + self, + TokenKind::Semicolon, + RecoverFromNoMatch::No, + ), + )?; seq.elem(self.parse_token_with_trivia::( input, - TokenKind::Identifier, + TokenKind::Semicolon, ))?; seq.finish() }) - .with_kind(RuleKind::UntypedTupleMember) + .with_kind(RuleKind::UsingDirective) } #[allow(unused_assignments, unused_parens)] - fn user_defined_value_type_definition(&self, input: &mut ParserContext) -> ParserResult { - if self.version_is_at_least_0_8_8 { - SequenceHelper::run(|mut seq| { - seq.elem( - SequenceHelper::run(|mut seq| { - seq.elem(self.parse_token_with_trivia::( - input, - TokenKind::TypeKeyword, - ))?; - seq.elem(self.parse_token_with_trivia::( - input, - TokenKind::Identifier, - ))?; - seq.elem(self.parse_token_with_trivia::( - input, - TokenKind::IsKeyword, - ))?; - seq.elem(ChoiceHelper::run(input, |mut choice, input| { - let result = self - .parse_token_with_trivia::( - input, - TokenKind::BoolKeyword, - ); - choice.consider(input, result)?; - if !self.version_is_at_least_0_8_0 { - let result = self - .parse_token_with_trivia::( - input, - TokenKind::ByteKeyword, - ); - choice.consider(input, result)?; - } - let result = self - .parse_token_with_trivia::( - input, - TokenKind::StringKeyword, - ); - choice.consider(input, result)?; - let result = self.address_type(input); - choice.consider(input, result)?; - let result = self - .parse_token_with_trivia::( - input, - TokenKind::PayableKeyword, - ); - choice.consider(input, result)?; - let result = self - .parse_token_with_trivia::( - input, - TokenKind::BytesKeyword, - ); - choice.consider(input, result)?; - let result = self - .parse_token_with_trivia::( - input, - TokenKind::IntKeyword, - ); - choice.consider(input, result)?; + fn variable_declaration_statement(&self, input: &mut ParserContext) -> ParserResult { + SequenceHelper::run(|mut seq| { + seq.elem( + SequenceHelper::run(|mut seq| { + seq.elem(ChoiceHelper::run(input, |mut choice, input| { + let result = self.type_name(input); + choice.consider(input, result)?; + if !self.version_is_at_least_0_5_0 { let result = self .parse_token_with_trivia::( input, - TokenKind::UintKeyword, + TokenKind::VarKeyword, ); choice.consider(input, result)?; + } + choice.finish(input) + }))?; + seq.elem(OptionalHelper::transform(ChoiceHelper::run( + input, + |mut choice, input| { let result = self .parse_token_with_trivia::( input, - TokenKind::FixedKeyword, + TokenKind::MemoryKeyword, ); choice.consider(input, result)?; let result = self .parse_token_with_trivia::( input, - TokenKind::UfixedKeyword, + TokenKind::StorageKeyword, ); choice.consider(input, result)?; + if self.version_is_at_least_0_5_0 { + let result = self + .parse_token_with_trivia::( + input, + TokenKind::CallDataKeyword, + ); + choice.consider(input, result)?; + } choice.finish(input) - }))?; - seq.finish() - }) - .recover_until_with_nested_delims::<_, LexicalContextType::Default>( + }, + )))?; + seq.elem(self.parse_token_with_trivia::( input, - self, - TokenKind::Semicolon, - RecoverFromNoMatch::No, - ), - )?; - seq.elem(self.parse_token_with_trivia::( + TokenKind::Identifier, + ))?; + seq.elem(OptionalHelper::transform( + self.variable_declaration_value(input), + ))?; + seq.finish() + }) + .recover_until_with_nested_delims::<_, LexicalContextType::Default>( input, + self, TokenKind::Semicolon, - ))?; - seq.finish() - }) - } else { - ParserResult::disabled() - } - .with_kind(RuleKind::UserDefinedValueTypeDefinition) + RecoverFromNoMatch::No, + ), + )?; + seq.elem(self.parse_token_with_trivia::( + input, + TokenKind::Semicolon, + ))?; + seq.finish() + }) + .with_kind(RuleKind::VariableDeclarationStatement) + } + + #[allow(unused_assignments, unused_parens)] + fn variable_declaration_value(&self, input: &mut ParserContext) -> ParserResult { + SequenceHelper::run(|mut seq| { + seq.elem( + self.parse_token_with_trivia::( + input, + TokenKind::Equal, + ), + )?; + seq.elem(self.expression(input))?; + seq.finish() + }) + .with_kind(RuleKind::VariableDeclarationValue) + } + + #[allow(unused_assignments, unused_parens)] + fn version_pragma(&self, input: &mut ParserContext) -> ParserResult { + SequenceHelper::run(|mut seq| { + seq.elem(self.parse_token_with_trivia::( + input, + TokenKind::SolidityKeyword, + ))?; + seq.elem(self.version_pragma_expressions(input))?; + seq.finish() + }) + .with_kind(RuleKind::VersionPragma) } #[allow(unused_assignments, unused_parens)] - fn using_alias(&self, input: &mut ParserContext) -> ParserResult { - if self.version_is_at_least_0_8_19 { - SequenceHelper::run(|mut seq| { - seq.elem(self.parse_token_with_trivia::( + fn version_pragma_expression(&self, input: &mut ParserContext) -> ParserResult { + let parse_version_pragma_or_expression = |input: &mut ParserContext| { + PrecedenceHelper::to_binary_operator( + RuleKind::VersionPragmaBinaryExpression, + 1u8, + 1u8 + 1, + self.parse_token_with_trivia::( input, - TokenKind::AsKeyword, - ))?; - seq.elem(ChoiceHelper::run(input, |mut choice, input| { - let result = self.parse_token_with_trivia::( + TokenKind::BarBar, + ), + ) + }; + let parse_version_pragma_range_expression = |input: &mut ParserContext| { + PrecedenceHelper::to_binary_operator( + RuleKind::VersionPragmaBinaryExpression, + 3u8, + 3u8 + 1, + self.parse_token_with_trivia::(input, TokenKind::Minus), + ) + }; + let parse_version_pragma_prefix_expression = |input: &mut ParserContext| { + PrecedenceHelper::to_prefix_operator( + RuleKind::VersionPragmaUnaryExpression, + 5u8, + ChoiceHelper::run(input, |mut choice, input| { + let result = self.parse_token_with_trivia::( input, - TokenKind::Ampersand, + TokenKind::Caret, ); choice.consider(input, result)?; - let result = self.parse_token_with_trivia::( + let result = self.parse_token_with_trivia::( input, - TokenKind::Asterisk, + TokenKind::Tilde, ); choice.consider(input, result)?; - let result = self.parse_token_with_trivia::( + let result = self.parse_token_with_trivia::( input, - TokenKind::BangEqual, + TokenKind::Equal, ); choice.consider(input, result)?; - let result = self.parse_token_with_trivia::( + let result = self.parse_token_with_trivia::( input, - TokenKind::Bar, + TokenKind::LessThan, ); choice.consider(input, result)?; - let result = self.parse_token_with_trivia::( + let result = self.parse_token_with_trivia::( + input, + TokenKind::GreaterThan, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::LessThanEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::GreaterThanEqual, + ); + choice.consider(input, result)?; + choice.finish(input) + }), + ) + }; + let parse_version_pragma_prefix_expression = |input: &mut ParserContext| { + PrecedenceHelper::to_prefix_operator( + RuleKind::VersionPragmaUnaryExpression, + 7u8, + ChoiceHelper::run(input, |mut choice, input| { + let result = self.parse_token_with_trivia::( input, TokenKind::Caret, ); choice.consider(input, result)?; - let result = self.parse_token_with_trivia::( + let result = self.parse_token_with_trivia::( input, - TokenKind::EqualEqual, + TokenKind::Tilde, ); choice.consider(input, result)?; - let result = self.parse_token_with_trivia::( + let result = self.parse_token_with_trivia::( + input, + TokenKind::Equal, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::LessThan, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( input, TokenKind::GreaterThan, ); choice.consider(input, result)?; - let result = self.parse_token_with_trivia::( + let result = self.parse_token_with_trivia::( + input, + TokenKind::LessThanEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( input, TokenKind::GreaterThanEqual, ); choice.consider(input, result)?; - let result = self.parse_token_with_trivia::( + choice.finish(input) + }), + ) + }; + let parse_version_pragma_prefix_expression = |input: &mut ParserContext| { + PrecedenceHelper::to_prefix_operator( + RuleKind::VersionPragmaUnaryExpression, + 9u8, + ChoiceHelper::run(input, |mut choice, input| { + let result = self.parse_token_with_trivia::( + input, + TokenKind::Caret, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::Tilde, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::Equal, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( input, TokenKind::LessThan, ); choice.consider(input, result)?; - let result = self.parse_token_with_trivia::( + let result = self.parse_token_with_trivia::( + input, + TokenKind::GreaterThan, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( input, TokenKind::LessThanEqual, ); choice.consider(input, result)?; - let result = self.parse_token_with_trivia::( + let result = self.parse_token_with_trivia::( input, - TokenKind::Minus, + TokenKind::GreaterThanEqual, ); choice.consider(input, result)?; - let result = self.parse_token_with_trivia::( + choice.finish(input) + }), + ) + }; + let parse_version_pragma_prefix_expression = |input: &mut ParserContext| { + PrecedenceHelper::to_prefix_operator( + RuleKind::VersionPragmaUnaryExpression, + 11u8, + ChoiceHelper::run(input, |mut choice, input| { + let result = self.parse_token_with_trivia::( input, - TokenKind::Percent, + TokenKind::Caret, ); choice.consider(input, result)?; - let result = self.parse_token_with_trivia::( + let result = self.parse_token_with_trivia::( input, - TokenKind::Plus, + TokenKind::Tilde, ); choice.consider(input, result)?; - let result = self.parse_token_with_trivia::( + let result = self.parse_token_with_trivia::( input, - TokenKind::Slash, + TokenKind::Equal, ); choice.consider(input, result)?; - let result = self.parse_token_with_trivia::( + let result = self.parse_token_with_trivia::( input, - TokenKind::Tilde, + TokenKind::LessThan, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::GreaterThan, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::LessThanEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::GreaterThanEqual, ); choice.consider(input, result)?; choice.finish(input) - }))?; - seq.finish() - }) - } else { - ParserResult::disabled() - } - .with_kind(RuleKind::UsingAlias) - } - - #[allow(unused_assignments, unused_parens)] - fn using_deconstruction(&self, input: &mut ParserContext) -> ParserResult { - if self.version_is_at_least_0_8_13 { - SequenceHelper::run(|mut seq| { - let mut delim_guard = input.open_delim(TokenKind::CloseBrace); - let input = delim_guard.ctx(); - seq.elem(self.parse_token_with_trivia::( - input, - TokenKind::OpenBrace, - ))?; - seq.elem( - self.using_deconstruction_symbols(input) - .recover_until_with_nested_delims::<_, LexicalContextType::Default>( - input, - self, - TokenKind::CloseBrace, - RecoverFromNoMatch::Yes, - ), - )?; - seq.elem(self.parse_token_with_trivia::( - input, - TokenKind::CloseBrace, - ))?; - seq.finish() - }) - } else { - ParserResult::disabled() - } - .with_kind(RuleKind::UsingDeconstruction) - } - - #[allow(unused_assignments, unused_parens)] - fn using_deconstruction_symbol(&self, input: &mut ParserContext) -> ParserResult { - if self.version_is_at_least_0_8_13 { - SequenceHelper::run(|mut seq| { - seq.elem(self.identifier_path(input))?; - if self.version_is_at_least_0_8_19 { - seq.elem(OptionalHelper::transform(self.using_alias(input)))?; - } - seq.finish() - }) - } else { - ParserResult::disabled() - } - .with_kind(RuleKind::UsingDeconstructionSymbol) - } - - #[allow(unused_assignments, unused_parens)] - fn using_deconstruction_symbols(&self, input: &mut ParserContext) -> ParserResult { - if self.version_is_at_least_0_8_13 { - SeparatedHelper::run::<_, LexicalContextType::Default>( - input, - self, - |input| self.using_deconstruction_symbol(input), - TokenKind::Comma, + }), ) - } else { - ParserResult::disabled() - } - .with_kind(RuleKind::UsingDeconstructionSymbols) - } - - #[allow(unused_assignments, unused_parens)] - fn using_directive(&self, input: &mut ParserContext) -> ParserResult { - SequenceHelper::run(|mut seq| { - seq.elem( - SequenceHelper::run(|mut seq| { - seq.elem(self.parse_token_with_trivia::( + }; + let parse_version_pragma_prefix_expression = |input: &mut ParserContext| { + PrecedenceHelper::to_prefix_operator( + RuleKind::VersionPragmaUnaryExpression, + 13u8, + ChoiceHelper::run(input, |mut choice, input| { + let result = self.parse_token_with_trivia::( input, - TokenKind::UsingKeyword, - ))?; - seq.elem(ChoiceHelper::run(input, |mut choice, input| { - let result = self.identifier_path(input); - choice.consider(input, result)?; - if self.version_is_at_least_0_8_13 { - let result = self.using_deconstruction(input); - choice.consider(input, result)?; - } - choice.finish(input) - }))?; - seq.elem(self.parse_token_with_trivia::( + TokenKind::Caret, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( input, - TokenKind::ForKeyword, - ))?; - seq.elem(ChoiceHelper::run(input, |mut choice, input| { - let result = self.type_name(input); - choice.consider(input, result)?; - let result = self.parse_token_with_trivia::( - input, - TokenKind::Asterisk, - ); - choice.consider(input, result)?; - choice.finish(input) - }))?; - if self.version_is_at_least_0_8_13 { - seq.elem(OptionalHelper::transform( - self.parse_token_with_trivia::( - input, - TokenKind::GlobalKeyword, - ), - ))?; - } - seq.finish() - }) - .recover_until_with_nested_delims::<_, LexicalContextType::Default>( - input, - self, - TokenKind::Semicolon, - RecoverFromNoMatch::No, - ), - )?; - seq.elem(self.parse_token_with_trivia::( - input, - TokenKind::Semicolon, - ))?; - seq.finish() - }) - .with_kind(RuleKind::UsingDirective) - } - - #[allow(unused_assignments, unused_parens)] - fn variable_declaration_statement(&self, input: &mut ParserContext) -> ParserResult { - SequenceHelper::run(|mut seq| { - seq.elem( - SequenceHelper::run(|mut seq| { - seq.elem(ChoiceHelper::run(input, |mut choice, input| { - let result = self.type_name(input); - choice.consider(input, result)?; - if !self.version_is_at_least_0_5_0 { - let result = self - .parse_token_with_trivia::( - input, - TokenKind::VarKeyword, - ); - choice.consider(input, result)?; - } - choice.finish(input) - }))?; - seq.elem(OptionalHelper::transform(ChoiceHelper::run( + TokenKind::Tilde, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( input, - |mut choice, input| { - let result = self - .parse_token_with_trivia::( - input, - TokenKind::MemoryKeyword, - ); - choice.consider(input, result)?; - let result = self - .parse_token_with_trivia::( - input, - TokenKind::StorageKeyword, - ); - choice.consider(input, result)?; - if self.version_is_at_least_0_5_0 { - let result = self - .parse_token_with_trivia::( - input, - TokenKind::CallDataKeyword, - ); - choice.consider(input, result)?; - } - choice.finish(input) - }, - )))?; - seq.elem(self.parse_token_with_trivia::( + TokenKind::Equal, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( input, - TokenKind::Identifier, - ))?; - seq.elem(OptionalHelper::transform( - self.variable_declaration_value(input), - ))?; - seq.finish() - }) - .recover_until_with_nested_delims::<_, LexicalContextType::Default>( - input, - self, - TokenKind::Semicolon, - RecoverFromNoMatch::No, - ), - )?; - seq.elem(self.parse_token_with_trivia::( - input, - TokenKind::Semicolon, - ))?; - seq.finish() - }) - .with_kind(RuleKind::VariableDeclarationStatement) - } - - #[allow(unused_assignments, unused_parens)] - fn variable_declaration_value(&self, input: &mut ParserContext) -> ParserResult { - SequenceHelper::run(|mut seq| { - seq.elem( - self.parse_token_with_trivia::( - input, - TokenKind::Equal, - ), - )?; - seq.elem(self.expression(input))?; - seq.finish() - }) - .with_kind(RuleKind::VariableDeclarationValue) - } - - #[allow(unused_assignments, unused_parens)] - fn version_pragma(&self, input: &mut ParserContext) -> ParserResult { - SequenceHelper::run(|mut seq| { - seq.elem(self.parse_token_with_trivia::( - input, - TokenKind::SolidityKeyword, - ))?; - seq.elem(self.version_pragma_expressions(input))?; - seq.finish() - }) - .with_kind(RuleKind::VersionPragma) - } - - #[allow(unused_assignments, unused_parens)] - fn version_pragma_expression(&self, input: &mut ParserContext) -> ParserResult { - let parse_version_pragma_or_expression = |input: &mut ParserContext| { - PrecedenceHelper::to_binary_operator( - RuleKind::VersionPragmaBinaryExpression, - 1u8, - 1u8 + 1, - self.parse_token_with_trivia::( - input, - TokenKind::BarBar, - ), + TokenKind::LessThan, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::GreaterThan, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::LessThanEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::GreaterThanEqual, + ); + choice.consider(input, result)?; + choice.finish(input) + }), ) }; - let parse_version_pragma_range_expression = |input: &mut ParserContext| { - PrecedenceHelper::to_binary_operator( - RuleKind::VersionPragmaBinaryExpression, - 3u8, - 3u8 + 1, - self.parse_token_with_trivia::(input, TokenKind::Minus), + let parse_version_pragma_prefix_expression = |input: &mut ParserContext| { + PrecedenceHelper::to_prefix_operator( + RuleKind::VersionPragmaUnaryExpression, + 15u8, + ChoiceHelper::run(input, |mut choice, input| { + let result = self.parse_token_with_trivia::( + input, + TokenKind::Caret, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::Tilde, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::Equal, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::LessThan, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::GreaterThan, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::LessThanEqual, + ); + choice.consider(input, result)?; + let result = self.parse_token_with_trivia::( + input, + TokenKind::GreaterThanEqual, + ); + choice.consider(input, result)?; + choice.finish(input) + }), ) }; let parse_version_pragma_prefix_expression = |input: &mut ParserContext| { PrecedenceHelper::to_prefix_operator( RuleKind::VersionPragmaUnaryExpression, - 5u8, + 17u8, ChoiceHelper::run(input, |mut choice, input| { let result = self.parse_token_with_trivia::( input, @@ -4954,6 +6403,18 @@ impl Language { }; let prefix_operator_parser = |input: &mut ParserContext| { ChoiceHelper::run(input, |mut choice, input| { + let result = parse_version_pragma_prefix_expression(input); + choice.consider(input, result)?; + let result = parse_version_pragma_prefix_expression(input); + choice.consider(input, result)?; + let result = parse_version_pragma_prefix_expression(input); + choice.consider(input, result)?; + let result = parse_version_pragma_prefix_expression(input); + choice.consider(input, result)?; + let result = parse_version_pragma_prefix_expression(input); + choice.consider(input, result)?; + let result = parse_version_pragma_prefix_expression(input); + choice.consider(input, result)?; let result = parse_version_pragma_prefix_expression(input); choice.consider(input, result)?; choice.finish(input) diff --git a/crates/solidity/testing/snapshots/cst_output/ContractMembers/separated_recovery/generated/0.4.11-failure.yml b/crates/solidity/testing/snapshots/cst_output/ContractMembers/separated_recovery/generated/0.4.11-failure.yml index 0dd29f73c9..661a8a39c0 100644 --- a/crates/solidity/testing/snapshots/cst_output/ContractMembers/separated_recovery/generated/0.4.11-failure.yml +++ b/crates/solidity/testing/snapshots/cst_output/ContractMembers/separated_recovery/generated/0.4.11-failure.yml @@ -64,7 +64,7 @@ Errors: # 10 total │ ╰────────────── Error occurred here. ───╯ - > - Error: Expected AddressKeyword or Identifier. + Error: Expected Identifier. ╭─[crates/solidity/testing/snapshots/cst_output/ContractMembers/separated_recovery/input.sol:11:51] │ 11 │ function nested_lists() override(some.ident, next.do.that, other.while, next.one, final, ultimate); @@ -72,7 +72,7 @@ Errors: # 10 total │ ╰───── Error occurred here. ────╯ - > - Error: Expected AddressKeyword or Identifier. + Error: Expected Identifier. ╭─[crates/solidity/testing/snapshots/cst_output/ContractMembers/separated_recovery/input.sol:11:66] │ 11 │ function nested_lists() override(some.ident, next.do.that, other.while, next.one, final, ultimate); @@ -88,7 +88,7 @@ Errors: # 10 total │ ╰───────── Error occurred here. ────╯ - > - Error: Expected AddressKeyword or Identifier. + Error: Expected Identifier. ╭─[crates/solidity/testing/snapshots/cst_output/ContractMembers/separated_recovery/input.sol:12:39] │ 12 │ function nested_lists() override(some., next.arg, next.one, ultimate);