Skip to content

Commit

Permalink
Sort definitions
Browse files Browse the repository at this point in the history
  • Loading branch information
kamilkisiela committed Aug 23, 2022
1 parent 9403ede commit e133a26
Showing 1 changed file with 32 additions and 6 deletions.
38 changes: 32 additions & 6 deletions packages/libraries/router/src/graphql.rs
Original file line number Diff line number Diff line change
Expand Up @@ -270,6 +270,19 @@ impl<'s, T: Text<'s> + Clone> SortSelectionsTransform<'s, T> {
}

impl<'s, T: Text<'s> + Clone> OperationTransformer<'s, T> for SortSelectionsTransform<'s, T> {
fn transform_document(
&mut self,
document: &Document<'s, T>,
) -> TransformedValue<Document<'s, T>> {
let mut next_definitions = self
.transform_list(&document.definitions, Self::transform_definition)
.replace_or_else(|| document.definitions.to_vec());
next_definitions.sort_unstable_by(|a, b| self.compare_definitions(a, b));
TransformedValue::Replace(Document {
definitions: next_definitions,
})
}

fn transform_selection_set(
&mut self,
selections: &SelectionSet<'s, T>,
Expand Down Expand Up @@ -364,6 +377,17 @@ impl<'s, T: Text<'s> + Clone> OperationTransformer<'s, T> for SortSelectionsTran
}

impl<'s, T: Text<'s> + Clone> SortSelectionsTransform<'s, T> {
fn compare_definitions(&self, a: &Definition<'s, T>, b: &Definition<'s, T>) -> Ordering {
match (a, b) {
// Keep operations as they are
(Definition::Operation(_), Definition::Operation(_)) => Ordering::Equal,
// Sort fragments by name
(Definition::Fragment(a), Definition::Fragment(b)) => a.name.cmp(&b.name),
// Operation -> Fragment
_ => definition_kind_ordering(a).cmp(&definition_kind_ordering(b)),
}
}

fn compare_selections(&self, a: &Selection<'s, T>, b: &Selection<'s, T>) -> Ordering {
match (a, b) {
(Selection::Field(a), Selection::Field(b)) => a.name.cmp(&b.name),
Expand All @@ -373,12 +397,6 @@ impl<'s, T: Text<'s> + Clone> SortSelectionsTransform<'s, T> {
_ => {
let a_ordering = selection_kind_ordering(a);
let b_ordering = selection_kind_ordering(b);
assert!(
a_ordering != b_ordering,
"expected different ordering, got {} == {}",
a_ordering,
b_ordering
);
a_ordering.cmp(&b_ordering)
}
}
Expand Down Expand Up @@ -411,6 +429,14 @@ fn selection_kind_ordering<'s, T: Text<'s>>(selection: &Selection<'s, T>) -> u8
}
}

/// Assigns an order to different variants of Definition
fn definition_kind_ordering<'a, T: Text<'a>>(definition: &Definition<'a, T>) -> u8 {
match definition {
Definition::Operation(_) => 1,
Definition::Fragment(_) => 2,
}
}

#[derive(Clone)]
pub struct ProcessedOperation {
pub operation: String,
Expand Down

0 comments on commit e133a26

Please sign in to comment.