General.antiquote.scala Maven / Gradle / Ivy
/* Title: Pure/General/antiquote.scala
Author: Makarius
Antiquotations within plain text.
*/
package isabelle
import scala.util.parsing.input.CharSequenceReader
object Antiquote
{
sealed abstract class Antiquote
case class Text(source: String) extends Antiquote
case class Antiq(source: String) extends Antiquote
/* parsers */
object Parsers extends Parsers
trait Parsers extends Scan.Parsers
{
private val txt: Parser[String] =
rep1("@" ~ guard(one(s => s != "{")) | many1(s => s != "@")) ^^ (x => x.mkString)
val antiq_other: Parser[String] =
many1(s => s != "\"" && s != "`" && s != "}" && !Symbol.is_open(s) && !Symbol.is_close(s))
private val antiq_body: Parser[String] =
quoted("\"") | (quoted("`") | (cartouche | antiq_other))
val antiq: Parser[String] =
"@{" ~ rep(antiq_body) ~ "}" ^^ { case x ~ y ~ z => x + y.mkString + z }
val antiquote: Parser[Antiquote] =
antiq ^^ (x => Antiq(x)) | txt ^^ (x => Text(x))
}
/* read */
def read(input: CharSequence): List[Antiquote] =
{
Parsers.parseAll(Parsers.rep(Parsers.antiquote), new CharSequenceReader(input)) match {
case Parsers.Success(xs, _) => xs
case Parsers.NoSuccess(_, next) =>
error("Malformed quotation/antiquotation source" +
Position.here(Position.Line(next.pos.line)))
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy