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

miksilo.modularLanguages.deltas.FileWithMembersDelta.scala Maven / Gradle / Ivy

The newest version!
package miksilo.modularLanguages.deltas

import miksilo.modularLanguages.core.deltas.grammars.{BodyGrammar, LanguageGrammars}
import miksilo.modularLanguages.core.deltas.path.{NodePath, PathRoot}
import miksilo.modularLanguages.core.deltas.{Contract, DeltaWithGrammar}
import miksilo.editorParser.document.BlankLine
import miksilo.languageServer.core.language.{Compilation, Language}
import miksilo.modularLanguages.core.node.{NodeField, NodeLike, NodeShape, NodeWrapper}
import miksilo.languageServer.core.smarts.ConstraintBuilder
import miksilo.languageServer.core.smarts.scopes.objects.Scope
import miksilo.modularLanguages.core.SolveConstraintsDelta
import miksilo.modularLanguages.deltas.classes.HasConstraintsDelta

object FileWithMembersDelta extends DeltaWithGrammar with HasConstraintsDelta {
  override def description: String = "Defines a file with members"

  object Shape extends NodeShape
  object Members extends NodeField

  implicit class FileWithMembers[T <: NodeLike](val node: T) extends NodeWrapper[T] {
    def members: Seq[T] = node(Members).asInstanceOf[Seq[T]]
  }

  override def transformGrammars(grammars: LanguageGrammars, language: Language): Unit = {
    import grammars._
    val member = create(Members)
    val file = member.someSeparatedVertical(BlankLine).as(Members).asNode(Shape)
    find(BodyGrammar).inner = file
  }

  override def dependencies: Set[Contract] = Set.empty

  override def inject(language: Language): Unit = {
    super.inject(language)

    SolveConstraintsDelta.constraintCollector.add(language, (compilation, builder) => {
      val fileScope = builder.newScope(debugName = "fileScope")
      ConstraintSkeleton.constraints(compilation, builder, compilation.program.asInstanceOf[PathRoot], fileScope)
    })
  }

  override def shape = Shape

  override def collectConstraints(compilation: Compilation, builder: ConstraintBuilder, path: NodePath, parentScope: Scope): Unit = {
    val members: Seq[NodePath] = path(Members).asInstanceOf[Seq[NodePath]]
    for(member <- members) {
      ConstraintSkeleton.constraints(compilation, builder, member, parentScope)
    }
  }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy