blob: 1cc9d39473ffe82033e6efeee1c35bbd6b47de27 (
plain) (
tree)
|
|
package torimatomeru
package syntax
import org.parboiled2._
trait Basic { self: ScalaSyntax =>
def UnicodeExcape = rule { "\\u" ~ 4.times(HexDigit) }
//Numbers and digits
def HexDigit = rule { Digit | "a" - "f" | "A" - "Z" }
def Digit = rule { "0" | NonZeroDigit }
def NonZeroDigit = rule { "1" - "9" }
def HexNumeral = rule { "0x" ~ oneOrMore(HexDigit) }
def DecimalNumeral = rule(oneOrMore(Digit))
def ExponentPart = rule { anyOf("Ee") ~ optional(anyOf("+-")) ~ oneOrMore(Digit) }
def FloatType = rule { anyOf("FfDd") }
def Parentheses = rule { "(" | ")" | "[" | "]" | "{" | "}" }
def DelimiterChar = rule { "'" | "\"" | "." | ";" | "," }
def WhitespaceChar = rule { "\u0020" | "\u0009" }
def Newline = rule { "\r\n" | "\n" }
def Semi = rule { ';' | oneOrMore(NewlineS) }
def OperatorChar = rule {
anyOf("""!#$%&*+-/:<=>?@\^|~""") |
CharPredicate.from(_.getType match {
case Character.OTHER_SYMBOL | Character.MATH_SYMBOL => true; case _ => false
})
}
def Letter = rule { Upper | Lower | CharPredicate.from(c => c.isLetter | c.isDigit) }
def Lower = rule { "a" - "z" | "$" | "_" | CharPredicate.from(_.isLower) }
def Upper = rule { "A" - "Z" | CharPredicate.from(_.isUpper) }
}
|