From b1e7be661ffc63aaeec9078bf7433b65ffba4b6e Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?V=C3=B5=20Ho=C3=A0ng=20Long?= <78085736+vohoanglong0107@users.noreply.github.com> Date: Fri, 17 May 2024 18:29:15 +0900 Subject: [PATCH] refactor(biome_graphql_parser): remove is_at_*_definition (#2841) --- .../src/parser/definitions/directive.rs | 12 +-- .../src/parser/definitions/enum.rs | 8 -- .../src/parser/definitions/fragment.rs | 9 -- .../src/parser/definitions/input_object.rs | 10 +-- .../src/parser/definitions/interface.rs | 9 -- .../src/parser/definitions/mod.rs | 90 ++++++++++--------- .../src/parser/definitions/object.rs | 10 +-- .../src/parser/definitions/operation.rs | 28 ++---- .../src/parser/definitions/scalar.rs | 10 +-- .../src/parser/definitions/schema.rs | 9 -- .../src/parser/definitions/union.rs | 9 -- 11 files changed, 56 insertions(+), 148 deletions(-) diff --git a/crates/biome_graphql_parser/src/parser/definitions/directive.rs b/crates/biome_graphql_parser/src/parser/definitions/directive.rs index 57bd1a9a7531..d1681e7dda6f 100644 --- a/crates/biome_graphql_parser/src/parser/definitions/directive.rs +++ b/crates/biome_graphql_parser/src/parser/definitions/directive.rs @@ -1,9 +1,7 @@ use crate::parser::{ parse_description, parse_error::{expected_directive_location, expected_name}, - parse_name, - value::is_at_string, - GraphqlParser, + parse_name, GraphqlParser, }; use biome_graphql_syntax::{ GraphqlSyntaxKind::{self, *}, @@ -41,9 +39,6 @@ const DIRECTIVE_LOCATION_SET: TokenSet = token_set!( #[inline] pub(crate) fn parse_directive_definition(p: &mut GraphqlParser) -> ParsedSyntax { - if !is_at_directive_definition(p) { - return Absent; - } let m = p.start(); // description is optional @@ -133,8 +128,3 @@ fn parse_directive_location(p: &mut GraphqlParser) -> ParsedSyntax { p.bump_ts(DIRECTIVE_LOCATION_SET); Present(m.complete(p, GRAPHQL_DIRECTIVE_LOCATION)) } - -#[inline] -pub(crate) fn is_at_directive_definition(p: &mut GraphqlParser) -> bool { - p.at(T![directive]) || (is_at_string(p) && p.nth_at(1, T![directive])) -} diff --git a/crates/biome_graphql_parser/src/parser/definitions/enum.rs b/crates/biome_graphql_parser/src/parser/definitions/enum.rs index 0a465217f59f..905aa515ea27 100644 --- a/crates/biome_graphql_parser/src/parser/definitions/enum.rs +++ b/crates/biome_graphql_parser/src/parser/definitions/enum.rs @@ -17,9 +17,6 @@ use biome_parser::{ #[inline] pub(crate) fn parse_enum_type_definition(p: &mut GraphqlParser) -> ParsedSyntax { - if !is_at_enum_type_definition(p) { - return Absent; - } let m = p.start(); // description is optional @@ -106,11 +103,6 @@ pub(crate) fn parse_enum_value_definition(p: &mut GraphqlParser) -> ParsedSyntax Present(m.complete(p, GRAPHQL_ENUM_VALUE_DEFINITION)) } -#[inline] -pub(crate) fn is_at_enum_type_definition(p: &mut GraphqlParser) -> bool { - p.at(T![enum]) || (is_at_string(p) && p.nth_at(1, T![enum])) -} - /// Either a `{`, `|`, or a non kw name token must be present, else this is /// likely the start of a new type definition #[inline] diff --git a/crates/biome_graphql_parser/src/parser/definitions/fragment.rs b/crates/biome_graphql_parser/src/parser/definitions/fragment.rs index 6aefca525036..a11f494288a6 100644 --- a/crates/biome_graphql_parser/src/parser/definitions/fragment.rs +++ b/crates/biome_graphql_parser/src/parser/definitions/fragment.rs @@ -15,10 +15,6 @@ use super::operation::parse_selection_set; #[inline] pub(crate) fn parse_fragment_definition(p: &mut GraphqlParser) -> ParsedSyntax { - if !is_at_fragment_definition(p) { - return Absent; - } - let m = p.start(); p.bump(T![fragment]); @@ -42,11 +38,6 @@ pub(crate) fn parse_type_condition(p: &mut GraphqlParser) -> CompletedMarker { m.complete(p, GRAPHQL_TYPE_CONDITION) } -#[inline] -pub(crate) fn is_at_fragment_definition(p: &GraphqlParser<'_>) -> bool { - p.at(T![fragment]) -} - #[inline] pub(crate) fn is_at_type_condition(p: &GraphqlParser<'_>) -> bool { p.at(T![on]) diff --git a/crates/biome_graphql_parser/src/parser/definitions/input_object.rs b/crates/biome_graphql_parser/src/parser/definitions/input_object.rs index 6c2bf2383a6c..d4ac9a1fc8b5 100644 --- a/crates/biome_graphql_parser/src/parser/definitions/input_object.rs +++ b/crates/biome_graphql_parser/src/parser/definitions/input_object.rs @@ -1,6 +1,6 @@ use crate::parser::{ directive::DirectiveList, parse_description, parse_error::expected_name, parse_name, - value::is_at_string, GraphqlParser, + GraphqlParser, }; use biome_graphql_syntax::{ GraphqlSyntaxKind::{self, *}, @@ -15,9 +15,6 @@ use super::field::{is_at_input_value_definition, parse_input_value_definition}; #[inline] pub(crate) fn parse_input_object_type_definition(p: &mut GraphqlParser) -> ParsedSyntax { - if !is_at_input_object_type_definition(p) { - return Absent; - } let m = p.start(); // description is optional @@ -87,11 +84,6 @@ impl ParseRecovery for InputFieldListParseRecovery { } } -#[inline] -pub(crate) fn is_at_input_object_type_definition(p: &mut GraphqlParser) -> bool { - p.at(T![input]) || (is_at_string(p) && p.nth_at(1, T![input])) -} - #[inline] fn is_at_input_fields_definition(p: &mut GraphqlParser) -> bool { p.at(T!['{']) diff --git a/crates/biome_graphql_parser/src/parser/definitions/interface.rs b/crates/biome_graphql_parser/src/parser/definitions/interface.rs index b0e9fe618123..84cda64ce682 100644 --- a/crates/biome_graphql_parser/src/parser/definitions/interface.rs +++ b/crates/biome_graphql_parser/src/parser/definitions/interface.rs @@ -4,7 +4,6 @@ use crate::parser::{ parse_error::{expected_name, expected_named_type}, parse_name, r#type::parse_named_type, - value::is_at_string, GraphqlParser, }; use biome_graphql_syntax::{ @@ -23,9 +22,6 @@ use super::{ #[inline] pub(super) fn parse_interface_type_definition(p: &mut GraphqlParser) -> ParsedSyntax { - if !is_at_interface_type_definition(p) { - return Absent; - } let m = p.start(); // description is optional @@ -118,11 +114,6 @@ impl ParseRecovery for ImplementsInterfaceListParseRecovery { } } -#[inline] -pub(super) fn is_at_interface_type_definition(p: &mut GraphqlParser<'_>) -> bool { - p.at(T![interface]) || (is_at_string(p) && p.nth_at(1, T![interface])) -} - #[inline] fn is_at_implements_interface(p: &mut GraphqlParser<'_>) -> bool { p.at(T![implements]) diff --git a/crates/biome_graphql_parser/src/parser/definitions/mod.rs b/crates/biome_graphql_parser/src/parser/definitions/mod.rs index ce2079f5539e..c6fdffb74b06 100644 --- a/crates/biome_graphql_parser/src/parser/definitions/mod.rs +++ b/crates/biome_graphql_parser/src/parser/definitions/mod.rs @@ -11,25 +11,30 @@ mod schema; mod union; use crate::parser::{parse_error::expected_any_definition, GraphqlParser}; -use biome_graphql_syntax::GraphqlSyntaxKind::{self, *}; +use biome_graphql_syntax::{ + GraphqlSyntaxKind::{self, *}, + T, +}; use biome_parser::{ parse_lists::ParseNodeList, parse_recovery::ParseRecovery, parsed_syntax::ParsedSyntax, prelude::ParsedSyntax::*, Parser, }; use self::{ - directive::{is_at_directive_definition, parse_directive_definition}, - fragment::{is_at_fragment_definition, parse_fragment_definition}, - input_object::{is_at_input_object_type_definition, parse_input_object_type_definition}, - interface::{is_at_interface_type_definition, parse_interface_type_definition}, - object::{is_at_object_type_definition, parse_object_type_definition}, - operation::{is_at_operation, parse_operation_definition}, - r#enum::{is_at_enum_type_definition, parse_enum_type_definition}, - scalar::{is_at_scalar_type_definition, parse_scalar_type_definition}, - schema::{is_at_schema_definition, parse_schema_definition}, - union::{is_at_union_type_definition, parse_union_type_definition}, + directive::parse_directive_definition, + fragment::parse_fragment_definition, + input_object::parse_input_object_type_definition, + interface::parse_interface_type_definition, + object::parse_object_type_definition, + operation::{parse_operation_definition, parse_selection_set}, + r#enum::parse_enum_type_definition, + scalar::parse_scalar_type_definition, + schema::parse_schema_definition, + union::parse_union_type_definition, }; +use super::value::is_at_string; + struct DefinitionListParseRecovery; impl ParseRecovery for DefinitionListParseRecovery { @@ -70,41 +75,40 @@ impl ParseNodeList for DefinitionList { #[inline] fn parse_definition(p: &mut GraphqlParser) -> ParsedSyntax { - if is_at_operation(p) { - parse_operation_definition(p) - } else if is_at_fragment_definition(p) { - parse_fragment_definition(p) - } else if is_at_schema_definition(p) { - parse_schema_definition(p) - } else if is_at_scalar_type_definition(p) { - parse_scalar_type_definition(p) - } else if is_at_object_type_definition(p) { - parse_object_type_definition(p) - } else if is_at_interface_type_definition(p) { - parse_interface_type_definition(p) - } else if is_at_union_type_definition(p) { - parse_union_type_definition(p) - } else if is_at_enum_type_definition(p) { - parse_enum_type_definition(p) - } else if is_at_input_object_type_definition(p) { - parse_input_object_type_definition(p) - } else if is_at_directive_definition(p) { - parse_directive_definition(p) - } else { - Absent + let keyword = if is_at_string(p) { p.nth(1) } else { p.cur() }; + match keyword { + T![query] | T![mutation] | T![subscription] => parse_operation_definition(p), + T!['{'] => parse_selection_set(p), + T![fragment] => parse_fragment_definition(p), + T![schema] => parse_schema_definition(p), + T![scalar] => parse_scalar_type_definition(p), + T![type] => parse_object_type_definition(p), + T![interface] => parse_interface_type_definition(p), + T![union] => parse_union_type_definition(p), + T![enum] => parse_enum_type_definition(p), + T![input] => parse_input_object_type_definition(p), + T![directive] => parse_directive_definition(p), + _ => Absent, } } #[inline] fn is_at_definition(p: &mut GraphqlParser<'_>) -> bool { - is_at_operation(p) - || is_at_fragment_definition(p) - || is_at_schema_definition(p) - || is_at_scalar_type_definition(p) - || is_at_object_type_definition(p) - || is_at_interface_type_definition(p) - || is_at_union_type_definition(p) - || is_at_enum_type_definition(p) - || is_at_input_object_type_definition(p) - || is_at_directive_definition(p) + let keyword = if is_at_string(p) { p.nth(1) } else { p.cur() }; + matches!( + keyword, + T![query] + | T![mutation] + | T![subscription] + | T!['{'] + | T![fragment] + | T![schema] + | T![scalar] + | T![type] + | T![interface] + | T![union] + | T![enum] + | T![input] + | T![directive] + ) } diff --git a/crates/biome_graphql_parser/src/parser/definitions/object.rs b/crates/biome_graphql_parser/src/parser/definitions/object.rs index 66e6a8baa09b..a1b485e5cc12 100644 --- a/crates/biome_graphql_parser/src/parser/definitions/object.rs +++ b/crates/biome_graphql_parser/src/parser/definitions/object.rs @@ -1,6 +1,6 @@ use crate::parser::{ directive::DirectiveList, parse_description, parse_error::expected_name, parse_name, - value::is_at_string, GraphqlParser, + GraphqlParser, }; use biome_graphql_syntax::{GraphqlSyntaxKind::*, T}; use biome_parser::{ @@ -11,9 +11,6 @@ use super::{field::parse_fields_definition, interface::parse_implements_interfac #[inline] pub(crate) fn parse_object_type_definition(p: &mut GraphqlParser) -> ParsedSyntax { - if !is_at_object_type_definition(p) { - return Absent; - } let m = p.start(); // description is optional @@ -32,8 +29,3 @@ pub(crate) fn parse_object_type_definition(p: &mut GraphqlParser) -> ParsedSynta Present(m.complete(p, GRAPHQL_OBJECT_TYPE_DEFINITION)) } - -#[inline] -pub(crate) fn is_at_object_type_definition(p: &mut GraphqlParser<'_>) -> bool { - p.at(T![type]) || (is_at_string(p) && p.nth_at(1, T![type])) -} diff --git a/crates/biome_graphql_parser/src/parser/definitions/operation.rs b/crates/biome_graphql_parser/src/parser/definitions/operation.rs index d21678c2ddbe..4c3a8f236f05 100644 --- a/crates/biome_graphql_parser/src/parser/definitions/operation.rs +++ b/crates/biome_graphql_parser/src/parser/definitions/operation.rs @@ -109,14 +109,6 @@ impl ParseRecovery for VariableDefinitionListParseRecovery { /// https://spec.graphql.org/October2021/#sec-Language.Operations.Query-shorthand #[inline] pub(crate) fn parse_operation_definition(p: &mut GraphqlParser) -> ParsedSyntax { - if !is_at_operation(p) { - return Absent; - } - - if is_at_selection_set(p) { - return parse_selection_set(p); - } - let m = p.start(); { let m = p.start(); @@ -187,7 +179,7 @@ fn parse_field(p: &mut GraphqlParser) -> ParsedSyntax { parse_arguments(p).ok(); DirectiveList.parse_list(p); - if is_at_selection_set(p) { + if p.at(T!['{']) { parse_selection_set(p).ok(); } Present(m.complete(p, GRAPHQL_FIELD)) @@ -255,11 +247,6 @@ fn parse_variable_definition(p: &mut GraphqlParser) -> ParsedSyntax { Present(m.complete(p, GRAPHQL_VARIABLE_DEFINITION)) } -#[inline] -pub(crate) fn is_at_operation(p: &GraphqlParser<'_>) -> bool { - p.at_ts(OPERATION_TYPE) || is_at_selection_set(p) -} - #[inline] fn is_at_variable_definitions(p: &mut GraphqlParser) -> bool { p.at(T!['(']) @@ -269,7 +256,10 @@ fn is_at_variable_definitions(p: &mut GraphqlParser) -> bool { #[inline] fn is_at_variable_definitions_end(p: &GraphqlParser) -> bool { - p.at(T![')']) || is_at_directive(p) || is_at_selection_set(p) + p.at(T![')']) + || is_at_directive(p) + // At the start of a selection set + || p.at(T!('{')) } #[inline] @@ -283,14 +273,6 @@ fn is_at_variable_definition(p: &mut GraphqlParser) -> bool { || p.at(T![:]) } -// we must enforce that a selection set starts with a curly brace -// otherwise it would be too complex to determine if we are at a selection set, -// especially when we have nested selections -#[inline] -fn is_at_selection_set(p: &GraphqlParser) -> bool { - p.at(T!['{']) -} - // Since keywords are valid names, we could only be sure that we are at the end // of a selection set if we are at a closing curly brace #[inline] diff --git a/crates/biome_graphql_parser/src/parser/definitions/scalar.rs b/crates/biome_graphql_parser/src/parser/definitions/scalar.rs index d72fc05c6e9d..5bafd25ac811 100644 --- a/crates/biome_graphql_parser/src/parser/definitions/scalar.rs +++ b/crates/biome_graphql_parser/src/parser/definitions/scalar.rs @@ -1,6 +1,6 @@ use crate::parser::{ directive::DirectiveList, parse_description, parse_error::expected_name, parse_name, - value::is_at_string, GraphqlParser, + GraphqlParser, }; use biome_graphql_syntax::{GraphqlSyntaxKind::*, T}; use biome_parser::{ @@ -9,9 +9,6 @@ use biome_parser::{ #[inline] pub(crate) fn parse_scalar_type_definition(p: &mut GraphqlParser) -> ParsedSyntax { - if !is_at_scalar_type_definition(p) { - return Absent; - } let m = p.start(); // description is optional parse_description(p).ok(); @@ -23,8 +20,3 @@ pub(crate) fn parse_scalar_type_definition(p: &mut GraphqlParser) -> ParsedSynta Present(m.complete(p, GRAPHQL_SCALAR_TYPE_DEFINITION)) } - -#[inline] -pub(crate) fn is_at_scalar_type_definition(p: &mut GraphqlParser<'_>) -> bool { - p.at(T![scalar]) || (is_at_string(p) && p.nth_at(1, T![scalar])) -} diff --git a/crates/biome_graphql_parser/src/parser/definitions/schema.rs b/crates/biome_graphql_parser/src/parser/definitions/schema.rs index de0839bdef48..8db72d5a2547 100644 --- a/crates/biome_graphql_parser/src/parser/definitions/schema.rs +++ b/crates/biome_graphql_parser/src/parser/definitions/schema.rs @@ -5,7 +5,6 @@ use crate::parser::{ expected_named_type, expected_operation_type, expected_root_operation_type_definition, }, r#type::parse_named_type, - value::is_at_string, GraphqlParser, }; use biome_graphql_syntax::{ @@ -21,9 +20,6 @@ use super::{is_at_definition, operation::OPERATION_TYPE}; #[inline] pub(crate) fn parse_schema_definition(p: &mut GraphqlParser) -> ParsedSyntax { - if !is_at_schema_definition(p) { - return Absent; - } let m = p.start(); // description is optional parse_description(p).ok(); @@ -106,11 +102,6 @@ fn parse_root_operation_type_definition(p: &mut GraphqlParser) -> ParsedSyntax { Present(m.complete(p, GRAPHQL_ROOT_OPERATION_TYPE_DEFINITION)) } -#[inline] -pub(crate) fn is_at_schema_definition(p: &mut GraphqlParser<'_>) -> bool { - p.at(T![schema]) || (is_at_string(p) && p.nth_at(1, T![schema])) -} - #[inline] fn is_at_root_operation_type_definition(p: &mut GraphqlParser<'_>) -> bool { p.at_ts(OPERATION_TYPE) diff --git a/crates/biome_graphql_parser/src/parser/definitions/union.rs b/crates/biome_graphql_parser/src/parser/definitions/union.rs index 3d16b2d6e729..36a9b32120c1 100644 --- a/crates/biome_graphql_parser/src/parser/definitions/union.rs +++ b/crates/biome_graphql_parser/src/parser/definitions/union.rs @@ -4,7 +4,6 @@ use crate::parser::{ parse_error::{expected_name, expected_named_type}, parse_name, r#type::parse_named_type, - value::is_at_string, GraphqlParser, }; use biome_graphql_syntax::{ @@ -23,9 +22,6 @@ use super::is_at_definition; #[inline] pub(crate) fn parse_union_type_definition(p: &mut GraphqlParser) -> ParsedSyntax { - if !is_at_union_type_definition(p) { - return Absent; - } let m = p.start(); // description is optional @@ -123,11 +119,6 @@ fn parse_union_member(p: &mut GraphqlParser) -> ParsedSyntax { parse_named_type(p) } -#[inline] -pub(crate) fn is_at_union_type_definition(p: &mut GraphqlParser<'_>) -> bool { - p.at(T![union]) || (is_at_string(p) && p.nth_at(1, T![union])) -} - /// We must enforce either a `=`, `|`, or a non kw name token to be present, as /// a union member can be keyword, which could be the start of a new type /// definition