summaryrefslogtreecommitdiff
path: root/scalaParser/src/main/scala/scalaParser/syntax/Identifiers.scala
diff options
context:
space:
mode:
authorLi Haoyi <haoyi@dropbox.com>2014-11-28 00:45:21 -0800
committerLi Haoyi <haoyi@dropbox.com>2014-11-28 00:45:21 -0800
commiteb384564fae6282d46a251fe8e91034e88c8dda4 (patch)
tree201aa9edb5e629fd6827150f16f973069fbc04cd /scalaParser/src/main/scala/scalaParser/syntax/Identifiers.scala
parenta4f1bb1d021109cce5d0f5ba5e37592b9c66a7cf (diff)
downloadhands-on-scala-js-eb384564fae6282d46a251fe8e91034e88c8dda4.tar.gz
hands-on-scala-js-eb384564fae6282d46a251fe8e91034e88c8dda4.tar.bz2
hands-on-scala-js-eb384564fae6282d46a251fe8e91034e88c8dda4.zip
More refactorings to standardize identifier/keyword "make sure it can't continue" behavior"
Diffstat (limited to 'scalaParser/src/main/scala/scalaParser/syntax/Identifiers.scala')
-rw-r--r--scalaParser/src/main/scala/scalaParser/syntax/Identifiers.scala28
1 files changed, 13 insertions, 15 deletions
diff --git a/scalaParser/src/main/scala/scalaParser/syntax/Identifiers.scala b/scalaParser/src/main/scala/scalaParser/syntax/Identifiers.scala
index 78fdba4..dc12e46 100644
--- a/scalaParser/src/main/scala/scalaParser/syntax/Identifiers.scala
+++ b/scalaParser/src/main/scala/scalaParser/syntax/Identifiers.scala
@@ -6,17 +6,11 @@ import org.parboiled2._
trait Identifiers { self: Parser with Basic =>
object Identifiers{
import Basic._
- def Operator = rule(oneOrMore(OperatorChar))
+ def Operator = rule{!Keywords ~ oneOrMore(OperatorChar)}
- def VarId = rule {
- !(Keywords | WhitespaceChar | Newline | "//" | "/*") ~ Lower ~ IdRest
- }
- def PlainId = rule {
- Upper ~ IdRest |
- VarId |
- !(Keywords | WhitespaceChar | Newline | "//" | "/*") ~ !Keywords ~ Operator
- }
- def Id = rule { PlainId | ("`" ~ oneOrMore(noneOf("`")) ~ "`") }
+ def VarId = rule { !Keywords ~ Lower ~ IdRest }
+ def PlainId = rule { !Keywords ~ Upper ~ IdRest | VarId | Operator }
+ def Id = rule { !Keywords ~ PlainId | ("`" ~ oneOrMore(noneOf("`")) ~ "`") }
def IdRest = rule {
zeroOrMore(zeroOrMore("_") ~ oneOrMore(!"_" ~ Letter | Digit)) ~
optional(oneOrMore("_") ~ optional(Operator))
@@ -24,15 +18,19 @@ trait Identifiers { self: Parser with Basic =>
def AlphabetKeywords = rule {
- "abstract" | "case" | "catch" | "class" | "def" | "do" | "else" | "extends" | "false" | "finally" | "final" | "finally" | "forSome" | "for" | "if" |
- "implicit" | "import" | "lazy" | "match" | "new" | "null" | "object" | "override" | "package" | "private" | "protected" | "return" |
- "sealed" | "super" | "this" | "throw" | "trait" | "try" | "true" | "type" | "val" | "var" | "while" | "with" | "yield" | "_"
+ (
+ "abstract" | "case" | "catch" | "class" | "def" | "do" | "else" | "extends" | "false" | "finally" | "final" | "finally" | "forSome" | "for" | "if" |
+ "implicit" | "import" | "lazy" | "match" | "new" | "null" | "object" | "override" | "package" | "private" | "protected" | "return" |
+ "sealed" | "super" | "this" | "throw" | "trait" | "try" | "true" | "type" | "val" | "var" | "while" | "with" | "yield" | "_"
+ ) ~ !Letter
}
def SymbolicKeywords = rule{
- ":" | ";" | "=>" | "=" | "<-" | "<:" | "<%" | ">:" | "#" | "@" | "\u21d2" | "\u2190"
+ (
+ ":" | ";" | "=>" | "=" | "<-" | "<:" | "<%" | ">:" | "#" | "@" | "\u21d2" | "\u2190"
+ ) ~ !OperatorChar
}
def Keywords = rule {
- AlphabetKeywords ~ !Letter | SymbolicKeywords ~ !OperatorChar
+ AlphabetKeywords | SymbolicKeywords
}
}