class LamSemantics[Abs, Addr, Time] extends Semantics[LamExp, Abs, Addr, Time]
This defines the semantics of call-by-value lambda expressions
- Alphabetic
- By Inheritance
- LamSemantics
- Semantics
- AnyRef
- Any
- by any2stringadd
- by StringFormat
- by Ensuring
- by ArrowAssoc
- Hide All
- Show All
- Public
- All
Instance Constructors
- new LamSemantics()(implicit arg0: LamLattice[Abs], arg1: Address[Addr], arg2: Timestamp[Time])
Type Members
-
type
Env = Environment[Addr]
Shortcut for the environment
-
case class
FrameArg(e: LamExp, env: Env) extends LamFrame with Product with Serializable
One frame to remember the operand when we evaluate the operator
-
case class
FrameFun(v: Abs) extends LamFrame with Product with Serializable
And one frame to remember the operator value when we evaluate the operand
-
trait
LamFrame extends Frame
We need some frames
-
type
Sto = Store[Addr, Abs]
Shorcuct for the store
Value Members
-
final
def
!=(arg0: Any): Boolean
- Definition Classes
- AnyRef → Any
-
final
def
##(): Int
- Definition Classes
- AnyRef → Any
-
def
+(other: String): String
- Implicit
- This member is added by an implicit conversion from LamSemantics[Abs, Addr, Time] to any2stringadd[LamSemantics[Abs, Addr, Time]] performed by method any2stringadd in scala.Predef.
- Definition Classes
- any2stringadd
-
def
->[B](y: B): (LamSemantics[Abs, Addr, Time], B)
- Implicit
- This member is added by an implicit conversion from LamSemantics[Abs, Addr, Time] to ArrowAssoc[LamSemantics[Abs, Addr, Time]] performed by method ArrowAssoc in scala.Predef.
- Definition Classes
- ArrowAssoc
- Annotations
- @inline()
-
final
def
==(arg0: Any): Boolean
- Definition Classes
- AnyRef → Any
-
implicit
def
actionToSet(action: Action[LamExp, Abs, Addr]): Set[Action[LamExp, Abs, Addr]]
- Definition Classes
- Semantics
-
final
def
asInstanceOf[T0]: T0
- Definition Classes
- Any
-
def
bindArgs(l: List[(Identifier, Abs)], env: Environment[Addr], store: Store[Addr, Abs], t: Time): (Environment[Addr], Store[Addr, Abs])
Binds arguments in the environment and store.
Binds arguments in the environment and store. Arguments are given as a list of triple, where each triple is made of:
- the name of the argument
- the position of the argument
- the value of the argument
- Attributes
- protected
- Definition Classes
- Semantics
-
def
clone(): AnyRef
- Attributes
- protected[java.lang]
- Definition Classes
- AnyRef
- Annotations
- @native() @HotSpotIntrinsicCandidate() @throws( ... )
-
def
ensuring(cond: (LamSemantics[Abs, Addr, Time]) ⇒ Boolean, msg: ⇒ Any): LamSemantics[Abs, Addr, Time]
- Implicit
- This member is added by an implicit conversion from LamSemantics[Abs, Addr, Time] to Ensuring[LamSemantics[Abs, Addr, Time]] performed by method Ensuring in scala.Predef.
- Definition Classes
- Ensuring
-
def
ensuring(cond: (LamSemantics[Abs, Addr, Time]) ⇒ Boolean): LamSemantics[Abs, Addr, Time]
- Implicit
- This member is added by an implicit conversion from LamSemantics[Abs, Addr, Time] to Ensuring[LamSemantics[Abs, Addr, Time]] performed by method Ensuring in scala.Predef.
- Definition Classes
- Ensuring
-
def
ensuring(cond: Boolean, msg: ⇒ Any): LamSemantics[Abs, Addr, Time]
- Implicit
- This member is added by an implicit conversion from LamSemantics[Abs, Addr, Time] to Ensuring[LamSemantics[Abs, Addr, Time]] performed by method Ensuring in scala.Predef.
- Definition Classes
- Ensuring
-
def
ensuring(cond: Boolean): LamSemantics[Abs, Addr, Time]
- Implicit
- This member is added by an implicit conversion from LamSemantics[Abs, Addr, Time] to Ensuring[LamSemantics[Abs, Addr, Time]] performed by method Ensuring in scala.Predef.
- Definition Classes
- Ensuring
-
final
def
eq(arg0: AnyRef): Boolean
- Definition Classes
- AnyRef
-
def
equals(arg0: Any): Boolean
- Definition Classes
- AnyRef → Any
-
def
formatted(fmtstr: String): String
- Implicit
- This member is added by an implicit conversion from LamSemantics[Abs, Addr, Time] to StringFormat[LamSemantics[Abs, Addr, Time]] performed by method StringFormat in scala.Predef.
- Definition Classes
- StringFormat
- Annotations
- @inline()
-
final
def
getClass(): Class[_]
- Definition Classes
- AnyRef → Any
- Annotations
- @native() @HotSpotIntrinsicCandidate()
-
def
hashCode(): Int
- Definition Classes
- AnyRef → Any
- Annotations
- @native() @HotSpotIntrinsicCandidate()
-
def
initialBindings: Iterable[(String, Addr, Abs)]
Defines the elements in the initial environment/store
Defines the elements in the initial environment/store
- Definition Classes
- Semantics
-
def
initialEnv: Iterable[(String, Addr)]
- Definition Classes
- Semantics
-
def
initialStore: Iterable[(Addr, Abs)]
- Definition Classes
- Semantics
-
final
def
isInstanceOf[T0]: Boolean
- Definition Classes
- Any
-
implicit
def
mfActionToActions(mf: MayFail[Action[LamExp, Abs, Addr]]): Set[Action[LamExp, Abs, Addr]]
- Definition Classes
- Semantics
-
implicit
def
mfToActions(mf: MayFail[Set[Action[LamExp, Abs, Addr]]]): Set[Action[LamExp, Abs, Addr]]
- Definition Classes
- Semantics
-
final
def
ne(arg0: AnyRef): Boolean
- Definition Classes
- AnyRef
-
final
def
notify(): Unit
- Definition Classes
- AnyRef
- Annotations
- @native() @HotSpotIntrinsicCandidate()
-
final
def
notifyAll(): Unit
- Definition Classes
- AnyRef
- Annotations
- @native() @HotSpotIntrinsicCandidate()
-
def
parse(program: String): LamExp
The parse function just parses an expression from a string.
The parse function just parses an expression from a string. We rely on an already-defined s-expression parser, and compile an s-expression in a lambda expression. There is some verbosity due to the fact that every s-expression is associated to a position information.
- Definition Classes
- LamSemantics → Semantics
-
def
stepEval(e: LamExp, env: Env, store: Sto, t: Time): Set[Action[LamExp, Abs, Addr]]
The stepEval function defines how to perform an evaluation step on an expression
The stepEval function defines how to perform an evaluation step on an expression
- Definition Classes
- LamSemantics → Semantics
-
def
stepKont(v: Abs, frame: Frame, store: Sto, t: Time): Set[Action[LamExp, Abs, Addr]]
The stepKont function defines how to behave when we reached a value v and we have frame as the top continuation on the stack
The stepKont function defines how to behave when we reached a value v and we have frame as the top continuation on the stack
- Definition Classes
- LamSemantics → Semantics
-
def
stepReceive(self: Any, mname: String, margsv: List[Abs], d: LamExp, env: Environment[Addr], store: Store[Addr, Abs], t: Time): Set[Action[LamExp, Abs, Addr]]
WIP
WIP
- Definition Classes
- Semantics
-
final
def
synchronized[T0](arg0: ⇒ T0): T0
- Definition Classes
- AnyRef
-
def
toString(): String
- Definition Classes
- AnyRef → Any
-
final
def
wait(arg0: Long, arg1: Int): Unit
- Definition Classes
- AnyRef
- Annotations
- @throws( ... )
-
final
def
wait(arg0: Long): Unit
- Definition Classes
- AnyRef
- Annotations
- @native() @throws( ... )
-
final
def
wait(): Unit
- Definition Classes
- AnyRef
- Annotations
- @throws( ... )
-
def
→[B](y: B): (LamSemantics[Abs, Addr, Time], B)
- Implicit
- This member is added by an implicit conversion from LamSemantics[Abs, Addr, Time] to ArrowAssoc[LamSemantics[Abs, Addr, Time]] performed by method ArrowAssoc in scala.Predef.
- Definition Classes
- ArrowAssoc
-
object
Action extends ActionHelpers[Exp, Abs, Addr]
- Definition Classes
- Semantics