summaryrefslogtreecommitdiff
path: root/src/library/scala/xml/dtd/impl/WordExp.scala
diff options
context:
space:
mode:
Diffstat (limited to 'src/library/scala/xml/dtd/impl/WordExp.scala')
-rw-r--r--src/library/scala/xml/dtd/impl/WordExp.scala59
1 files changed, 59 insertions, 0 deletions
diff --git a/src/library/scala/xml/dtd/impl/WordExp.scala b/src/library/scala/xml/dtd/impl/WordExp.scala
new file mode 100644
index 0000000000..a4bb54c1ea
--- /dev/null
+++ b/src/library/scala/xml/dtd/impl/WordExp.scala
@@ -0,0 +1,59 @@
+/* __ *\
+** ________ ___ / / ___ Scala API **
+** / __/ __// _ | / / / _ | (c) 2003-2013, LAMP/EPFL **
+** __\ \/ /__/ __ |/ /__/ __ | http://scala-lang.org/ **
+** /____/\___/_/ |_/____/_/ | | **
+** |/ **
+\* */
+
+
+
+package scala
+package xml.dtd.impl
+
+/**
+ * The class `WordExp` provides regular word expressions.
+ *
+ * Users have to instantiate type member `_regexpT <;: RegExp`
+ * (from class `Base`) and a type member `_labelT <;: Label`.
+ *
+ * Here is a short example:
+ * {{{
+ * import scala.util.regexp._
+ * import scala.util.automata._
+ * object MyLang extends WordExp {
+ * type _regexpT = RegExp
+ * type _labelT = MyChar
+ *
+ * case class MyChar(c:Char) extends Label
+ * }
+ * import MyLang._
+ * // (a* | b)*
+ * val rex = Star(Alt(Star(Letter(MyChar('a'))),Letter(MyChar('b'))))
+ * object MyBerriSethi extends WordBerrySethi {
+ * override val lang = MyLang
+ * }
+ * val nfa = MyBerriSethi.automatonFrom(Sequ(rex), 1)
+ * }}}
+ *
+ * @author Burak Emir
+ * @version 1.0
+ */
+@deprecated("This class will be removed", "2.10.0")
+private[dtd] abstract class WordExp extends Base {
+
+ abstract class Label
+
+ type _regexpT <: RegExp
+ type _labelT <: Label
+
+ case class Letter(a: _labelT) extends RegExp {
+ final lazy val isNullable = false
+ var pos = -1
+ }
+
+ case class Wildcard() extends RegExp {
+ final lazy val isNullable = false
+ var pos = -1
+ }
+}