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

scalaParser.subscript.ast.UtilNodes.scala Maven / Gradle / Ivy

package scalaParser.subscript.ast

import scalaParser.subscript.util._

trait UtilNodes {this: Ast =>
  import Constants.Key._

  trait AspectNode extends Node {
    val name: String

    def rewriteRaw(implicit context: Context, output: Output): String

    def rewrite(implicit context: Context, output: Output): String = {
      val compiled = rewriteRaw

      def aspect(key: String): String = output.last
        .get(key)
        .map {_.asInstanceOf[List[String]]}
        .getOrElse(Nil)
        .mkString("\n")

      val beforeCode = aspect(before(name))
      val afterCode  = aspect(after (name))

      if (!beforeCode.isEmpty || !afterCode.isEmpty)
        s"""{
            |  $beforeCode
            |  $compiled
            |  $afterCode
            |}""".stripMargin
      else compiled
    }    
  }

  trait Communication {this: Node =>

    private var pushedValue: Option[Map[String, Any]] = None

    def compile(implicit t2b: Context = Map(), b2t: Output = new CommunicationStackImpl): String = {
      val initialSize = b2t.stack.size

      val compiledValue = rewrite

      // If something was pushed by this node, push it, otherwise push an empty map
      pushedValue match {
        case Some(v) => b2t push v
        case None    => b2t push Map()
      }
      pushedValue = None  // A single node shouldn't be compiled twice, but just in case...

      // Reduce, so that all the children's and this node's values get combined into one
      b2t.reduce(b2t.stack.size - initialSize)

      compiledValue
    }

    def push(m: Map[String, Any]): Unit = pushedValue = Some(m)
    def push(p: (String, Any)   ): Unit = push(Map(p))

  }

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy