summaryrefslogtreecommitdiff
path: root/Chalice/src/Ast.scala
diff options
context:
space:
mode:
authorGravatar kyessenov <unknown>2010-07-21 23:16:09 +0000
committerGravatar kyessenov <unknown>2010-07-21 23:16:09 +0000
commitb756999641e811d3c9cd6453f4b1108a36ca93be (patch)
tree0360e6c8ec613878e1fbab65e8565282213eaca9 /Chalice/src/Ast.scala
parentda0230f37819fd9d67b561015a2b53743efe8f7d (diff)
Chalice: introduced proper AST nodes for permission expressions and permissions. This gets of redundancy in treating acc and rd in many places and should hopefully make permissions code more comprehensible
Diffstat (limited to 'Chalice/src/Ast.scala')
-rw-r--r--Chalice/src/Ast.scala42
1 files changed, 17 insertions, 25 deletions
diff --git a/Chalice/src/Ast.scala b/Chalice/src/Ast.scala
index 2452f0e1..8f617e7d 100644
--- a/Chalice/src/Ast.scala
+++ b/Chalice/src/Ast.scala
@@ -222,8 +222,8 @@ case class Send(ch: Expression, args: List[Expression]) extends Statement {
case class Receive(declaresLocal: List[Boolean], ch: Expression, outs: List[VariableExpr]) extends Statement {
var locals = List[Variable]()
}
-case class Fold(pred: MemberPermission) extends Statement
-case class Unfold(pred: MemberPermission) extends Statement
+case class Fold(pred: Access) extends Statement
+case class Unfold(pred: Access) extends Statement
// expressions
@@ -262,33 +262,25 @@ case class MemberAccess(e: Expression, id: String) extends Expression {
}
case class IfThenElse(con: Expression, then: Expression, els: Expression) extends Expression
-// TODO: perm should really be a separate abstract case class with Write and Read cases; this can simplify resolving/translation
-sealed abstract class PermissionExpr extends Expression
-sealed abstract class MemberPermission extends PermissionExpr {
- def getMemberAccess : MemberAccess
-}
-sealed abstract class WildCardPermission extends PermissionExpr
+sealed abstract class Permission extends Expression
+sealed abstract class Write extends Permission
+object Full extends Write // None
+case class Frac(n: Expression) extends Write // Some(n)
+sealed abstract class Read extends Permission
+object Epsilon extends Read // None
+object Star extends Read // Some(None)
+case class Epsilons(n: Expression) extends Read // Some(Some(n))
-case class Access(e: MemberAccess, perm: Option[Expression]) extends MemberPermission {
+sealed abstract class PermissionExpr(perm: Permission) extends Expression
+sealed abstract class WildCardPermission(perm: Permission) extends PermissionExpr(perm)
+case class Access(e: MemberAccess, perm: Permission) extends PermissionExpr(perm) {
def getMemberAccess = e : MemberAccess;
}
-// perm == Some(None) is the epsilon
-case class RdAccess(e: MemberAccess, perm: Option[Option[Expression]]) extends MemberPermission {
- def getMemberAccess = e : MemberAccess;
+case class AccessAll(obj: Expression, perm: Permission) extends WildCardPermission(perm)
+case class AccessSeq(s: Expression, f: Option[String], perm: Permission) extends WildCardPermission(perm) {
+ var memberAccess: Option[MemberAccess] = None; // resolved (for s[0] to make type checker happy) -- f == Nil is all fields
}
-case class AccessAll(obj: Expression, perm: Option[Expression]) extends WildCardPermission
-case class RdAccessAll(obj: Expression, perm: Option[Option[Expression]]) extends WildCardPermission
-
-// f == Nil is all fields
-case class AccessSeq(s: Expression, f: Option[String], perm: Option[Expression]) extends WildCardPermission {
- var memberAccess: Option[MemberAccess] = None; // resolved (for s[0] to make type checker happy)
-}
-case class RdAccessSeq(s: Expression, f: Option[String], perm: Option[Option[Expression]]) extends WildCardPermission {
- var memberAccess: Option[MemberAccess] = None; // resolved (for s[0] to make type checker happy)
-}
-
-
case class Credit(e: Expression, n: Option[Expression]) extends Expression {
def N = n match { case None => IntLiteral(1) case Some(n) => n }
}
@@ -303,7 +295,7 @@ case class Not(e: Expression) extends Expression
case class FunctionApplication(obj: Expression, id: String, args: List[Expression]) extends Expression {
var f: Function = null
}
-case class Unfolding(pred: MemberPermission, in: Expression) extends Expression
+case class Unfolding(pred: Access, in: Expression) extends Expression
sealed abstract class BinaryExpr(e0: Expression, e1: Expression) extends Expression {
def E0 = e0
def E1 = e1