package Lock
import Timer.SimulatedTimer
-//JPF's Verify API
-import gov.nasa.jpf.vm.Verify
-
public class Locks{
int deviceNumbers
List locks
private String currentLock = "locked"
private String lockLatestValue = "locked"
- Locks(Closure sendEvent, int deviceNumbers) {
+ Locks(Closure sendEvent, int deviceNumbers, boolean init) {
this.sendEvent = sendEvent
this.timers = new SimulatedTimer()
this.deviceNumbers = deviceNumbers
this.locks = []
- /*def init = Verify.getBoolean()
if (init) {
this.lockState = "locked"
+ this.currentLock = "locked"
this.lockLatestValue = "locked"
} else {
this.lockState = "unlocked"
+ this.currentLock = "unlocked"
this.lockLatestValue = "unlocked"
- }*/
+ }
locks.add(new Lock(sendEvent,id, label, displayName, this.lockState, this.lockLatestValue))
}
//By Apps
def lock() {
if (lockState != "locked") {
- locks[0].lock()
- lockLatestValue = lockState
+ //lockLatestValue = lockState
+ lockLatestValue = "locked"
lockState = "locked"
currentLock = "locked"
+ locks[0].lock()
}
}
def lock(LinkedHashMap metaData) {
if (lockState != "locked") {
def task = timers.runAfter(metaData["delay"]) {
- locks[0].lock()
- lockLatestValue = lockState
+ //lockLatestValue = lockState
+ lockLatestValue = "locked"
lockState = "locked"
currentLock = "locked"
+ locks[0].lock()
}
}
}
def unlock() {
if (lockState != "unlocked") {
- locks[0].unlock()
- lockLatestValue = lockState
+ //lockLatestValue = lockState
+ lockLatestValue = "unlocked"
lockState = "unlocked"
currentLock = "unlocked"
+ locks[0].unlock()
}
}
def unlock(LinkedHashMap metaData) {
if (lockState != "unlocked") {
def task = timers.runAfter(metaData["delay"]) {
- locks[0].unlock()
- lockLatestValue = lockState
+ //lockLatestValue = lockState
+ lockLatestValue = "unlocked"
lockState = "unlocked"
currentLock = "unlocked"
+ locks[0].unlock()
}
}
}
def find(Closure Input) {
locks.find(Input)
}
+ def sort(Closure Input) {
+ locks.sort(Input)
+ }
def collect(Closure Input) {
locks.collect(Input)
}