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

miksilo.modularLanguages.deltas.bytecode.constants.Utf8ConstantDelta.scala Maven / Gradle / Ivy

The newest version!
package miksilo.modularLanguages.deltas.bytecode.constants

import miksilo.modularLanguages.core.bigrammar.BiGrammar
import miksilo.modularLanguages.core.deltas.grammars.LanguageGrammars
import miksilo.languageServer.core.language.Compilation
import miksilo.modularLanguages.core.node._
import miksilo.modularLanguages.deltas.bytecode.PrintByteCode
import miksilo.modularLanguages.deltas.javac.classes.skeleton.QualifiedClassName

import scala.collection.immutable.ArraySeq

object Utf8ConstantDelta extends ConstantPoolEntry {
  override def shape = Utf8ConstantKey

  object Utf8ConstantKey extends NodeShape
  object Value extends NodeField
  def create(value: String) = new Node(shape, Value -> value)
  def get(constant: Node): String = constant(Value).asInstanceOf[String]

  implicit class Utf8Constant[T <: NodeLike](val node: T) extends NodeWrapper[T] {
    def value: String = node(Value).asInstanceOf[String]
    def value_=(value: String): Unit = node(Value) = value
  }

  def fromQualifiedClassName(name: QualifiedClassName): Node = create(name.parts.mkString("/"))
  def toQualifiedClassName(node: Node): QualifiedClassName =
    QualifiedClassName(ArraySeq.unsafeWrapArray(node(Value).asInstanceOf[String].split("/")))

  override def getBytes(compilation: Compilation, constant: Node): Seq[Byte] =
    PrintByteCode.toUTF8ConstantEntry(constant(Value).asInstanceOf[String])

  override def getConstantEntryGrammar(grammars: LanguageGrammars): BiGrammar = {
    import grammars._
    regexGrammar("""[^\s,.]+""".r, "utf8 constant string").as(Value)
  }

  override def description: String = "A string constant"

  override val getName = "Utf8"
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy