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

scalaParser.syntax.Literals.scala Maven / Gradle / Ivy

package scalaParser
package syntax
import acyclic.file
import org.parboiled2._

trait Literals { self: Parser with Basic with Identifiers with RulesOps =>
  type R1 = Rule1[String]

  def Block: R1
  def WL: R1
  object Literals{
    import Basic._
    def Float: R1 = {
      def Thing = rule( Digit.+ ~ Exp.? ~ FloatType.? )
      def Thing2 = rule( "." ~ Thing | Exp ~ FloatType.? | Exp.? ~ FloatType )
      rule( capture("." ~ Thing | Digit.+ ~ Thing2) )
    } 

    def Int: R1 = rule( capture((HexNum | DecNum) ~ anyOf("Ll").?) )

    def Bool: R1 = rule( capture(Key.W("true") | Key.W("false"))  )

    def MultilineCommentR0: Rule0 = rule( "/*" ~ (MultilineCommentR0 | !"*/" ~ ANY).* ~ "*/" )
    // def MultilineComment  : R1 = rule( capture("/*") ~ ((MultilineComment | capture(!"*/" ~ ANY)).* ~> ConcatSeqNoDelim) ~ capture("*/") ~> Concat3 )
    def MultilineComment: R1 = rule ( capture(MultilineCommentR0) )

    def CommentR0: Rule0 = rule(
      MultilineCommentR0 | "//" ~ (!Basic.Newline ~ ANY).* ~ &(Basic.Newline | EOI)
    ) 
    // def Comment: R1 = rule(
    //   MultilineComment | capture("//" ~ (!Basic.Newline ~ ANY).* ~ &(Basic.Newline | EOI))
    // )
    def Comment: R1 = rule ( capture(CommentR0) )


    def Null: R1 = rule( capture(Key.W("null")) )
    def Literal: R1 = rule( (capture("-".?) ~ (Float | Int) ~> Concat) | Bool | Char | String | Symbol | Null )

    def EscapedChars: R1 = rule( capture('\\' ~ anyOf("btnfr'\\\"")) )

    // Note that symbols can take on the same values as keywords!
    def Symbol: R1 = rule( capture(''' ~ (Identifiers.PlainId | Identifiers.Keywords)) )

    def Char: R1 = {
      // scalac 2.10 crashes if PrintableChar below is substituted by its body
      def PrintableChar = CharPredicate.from(isPrintableChar)

      rule {
        capture("'") ~ (capture(UnicodeEscape) | EscapedChars | capture(!'\\' ~ PrintableChar)) ~ capture("'") ~> Concat3
      }
    }


    def pr(s: String): Rule0 = rule( run(println(s"LOGGING $cursor: $s")) )
    def Interp: R1 = rule{
      capture("$" ~ Identifiers.PlainIdNoDollar) | capture("${") ~ Block ~ WL ~ capture("}") ~> Concat4 | capture("$$")
    }
    def String: R1 = {
      import Identifiers.Id
      def InterpIf(b: Boolean): R1 = if(b) rule(Interp) else rule(capture(MISMATCH0))
      def TQ: Rule0 = rule( "\"\"\"" )
      def TripleChars(b: Boolean) = rule( (InterpIf(b) | capture('"'.? ~ '"'.? ~ noneOf("\"")) ).* ~> ConcatSeqNoDelim )
      def TripleTail: R1 = rule( capture(TQ ~ (zeroOrMore('"'))) )
      def SingleChars(b: Boolean): R1 = rule( ( InterpIf(b) | capture("\\\"") | capture("\\\\") | capture(noneOf("\n\"")) ).* ~> ConcatSeqNoDelim )
      rule {
        (capture(Id ~ TQ ) ~ TripleChars(b = true ) ~ TripleTail   ~> Concat3) |
        (capture(Id ~ '"') ~ SingleChars(b = true ) ~ capture('"') ~> Concat3) |
        (capture(TQ )      ~ TripleChars(b = false) ~ TripleTail   ~> Concat3) |
        (capture('"')      ~ SingleChars(b = false) ~ capture('"') ~> Concat3)
      }
    }

    def isPrintableChar(c: Char): Boolean = {
      val block = Character.UnicodeBlock.of(c)
      !Character.isISOControl(c) && !Character.isSurrogate(c) && block != null && block != Character.UnicodeBlock.SPECIALS
    }
  }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy