All Downloads are FREE. Search and download functionalities are using the official Maven repository.

gql.parser.QueryAst.scala Maven / Gradle / Ivy

The newest version!
/*
 * Copyright 2024 Valdemar Grange
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *     http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */
package gql.parser

import cats.data.NonEmptyList
import gql.parser.{Value => V}

object QueryAst {
  sealed trait ExecutableDefinition[C] {
    def map[A](f: C => A): ExecutableDefinition[A]
  }
  object ExecutableDefinition {
    final case class Operation[C](o: OperationDefinition[C], c: C) extends ExecutableDefinition[C] {
      def map[A](f: C => A): ExecutableDefinition[A] = Operation(o.map(f), f(c))
    }
    final case class Fragment[C](f: FragmentDefinition[C], c: C) extends ExecutableDefinition[C] {
      def map[A](g: C => A): ExecutableDefinition[A] = Fragment(f.map(g), g(c))
    }
  }

  sealed trait OperationDefinition[C] {
    def map[A](f: C => A): OperationDefinition[A]
  }
  object OperationDefinition {
    final case class Detailed[C](
        tpe: OperationType,
        name: Option[String],
        variableDefinitions: Option[VariableDefinitions[C]],
        directives: Option[Directives[C, AnyValue]],
        selectionSet: SelectionSet[C]
    ) extends OperationDefinition[C] {
      def map[A](f: C => A): OperationDefinition[A] =
        Detailed(tpe, name, variableDefinitions.map(_.map(f)), directives.map(_.map(f)), selectionSet.map(f))
    }

    final case class Simple[C](selectionSet: SelectionSet[C]) extends OperationDefinition[C] {
      def map[A](f: C => A): OperationDefinition[A] = Simple(selectionSet.map(f))
    }
  }

  sealed trait OperationType
  object OperationType {
    case object Query extends OperationType
    case object Mutation extends OperationType
    case object Subscription extends OperationType
  }

  final case class SelectionSet[C](selections: NonEmptyList[Selection[C]]) {
    def map[A](f: C => A): SelectionSet[A] = SelectionSet(selections.map(_.map(f)))
  }

  sealed trait Selection[C] {
    def map[A](f: C => A): Selection[A]
  }
  object Selection {
    final case class FieldSelection[C](field: Field[C], c: C) extends Selection[C] {
      def map[A](f: C => A): Selection[A] = FieldSelection(field.map(f), f(c))
    }
    final case class FragmentSpreadSelection[C](fragmentSpread: FragmentSpread[C], c: C) extends Selection[C] {
      def map[A](f: C => A): Selection[A] = FragmentSpreadSelection(fragmentSpread.map(f), f(c))
    }
    final case class InlineFragmentSelection[C](inlineFragment: InlineFragment[C], c: C) extends Selection[C] {
      def map[A](f: C => A): Selection[A] = InlineFragmentSelection(inlineFragment.map(f), f(c))
    }
  }

  final case class Field[C](
      alias: Option[String],
      name: String,
      arguments: Option[Arguments[C, AnyValue]],
      directives: Option[Directives[C, AnyValue]],
      selectionSet: Option[SelectionSet[C]],
      caret: C
  ) {
    def map[A](f: C => A): Field[A] =
      Field(
        alias,
        name,
        arguments.map(_.map(f)),
        directives.map(_.map(f)),
        selectionSet.map(_.map(f)),
        f(caret)
      )
  }

  final case class Arguments[C, A >: Const <: AnyValue](nel: NonEmptyList[Argument[C, A]]) {
    def map[B](f: C => B): Arguments[B, A] = Arguments(nel.map(_.map(f)))
  }

  final case class Argument[C, A >: Const <: AnyValue](name: String, value: V[A, C]) {
    def map[B](f: C => B): Argument[B, A] = Argument(name, value.map(f))
  }

  final case class Directives[C, A >: Const <: AnyValue](nel: NonEmptyList[Directive[C, A]]) {
    def map[B](f: C => B): Directives[B, A] = Directives(nel.map(_.map(f)))
  }

  final case class Directive[C, A >: Const <: AnyValue](
      name: String,
      arguments: Option[Arguments[C, A]]
  ) {
    def map[B](f: C => B): Directive[B, A] = Directive(name, arguments.map(_.map(f)))
  }

  final case class FragmentSpread[C](fragmentName: String, directives: Option[Directives[C, AnyValue]]) {
    def map[A](f: C => A): FragmentSpread[A] = FragmentSpread(fragmentName, directives.map(_.map(f)))
  }

  final case class InlineFragment[C](
      typeCondition: Option[String],
      directives: Option[Directives[C, AnyValue]],
      selectionSet: SelectionSet[C]
  ) {
    def map[A](f: C => A): InlineFragment[A] = InlineFragment(typeCondition, directives.map(_.map(f)), selectionSet.map(f))
  }

  final case class FragmentDefinition[C](
      name: String,
      typeCnd: String,
      directives: Option[Directives[C, AnyValue]],
      selectionSet: SelectionSet[C],
      caret: C
  ) {
    def map[A](f: C => A): FragmentDefinition[A] =
      FragmentDefinition(name, typeCnd, directives.map(_.map(f)), selectionSet.map(f), f(caret))
  }

  final case class VariableDefinitions[C](nel: NonEmptyList[VariableDefinition[C]]) {
    def map[A](f: C => A): VariableDefinitions[A] =
      VariableDefinitions(nel.map(_.map(f)))
  }

  final case class VariableDefinition[C](
      name: String,
      tpe: Type,
      defaultValue: Option[V[Const, C]],
      directives: Option[Directives[C, Const]],
      c: C
  ) {
    def map[A](f: C => A): VariableDefinition[A] =
      VariableDefinition(name, tpe, defaultValue.map(_.map(f)), directives.map(_.map(f)), f(c))
  }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy