Reviewed By: sblackshear Differential Revision: D2895513 fb-gh-sync-id: 9b4f805master
parent
b1d77e54aa
commit
028ac24d46
@ -0,0 +1,68 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2016 - present Facebook, Inc.
|
||||||
|
* All rights reserved.
|
||||||
|
*
|
||||||
|
* This source code is licensed under the BSD style license found in the
|
||||||
|
* LICENSE file in the root directory of this source tree. An additional grant
|
||||||
|
* of patent rights can be found in the PATENTS file in the same directory.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package java.util.concurrent.locks;
|
||||||
|
import java.util.concurrent.TimeUnit;
|
||||||
|
import com.facebook.infer.models.InferBuiltins;
|
||||||
|
import com.facebook.infer.models.InferUndefined;
|
||||||
|
|
||||||
|
/*
|
||||||
|
Lock is in actuality an interface, but is implemented here as an abstract class for
|
||||||
|
modelling reasons. Note that we don't provide a model here for the newCondition() method.
|
||||||
|
*/
|
||||||
|
|
||||||
|
public abstract class Lock {
|
||||||
|
|
||||||
|
void lock() {
|
||||||
|
InferBuiltins.__set_locked_attribute(this);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
Sometimes doesn't get a lock.
|
||||||
|
*/
|
||||||
|
public void lockInterruptibly() throws InterruptedException {
|
||||||
|
if (InferUndefined.boolean_undefined()) {
|
||||||
|
InferBuiltins.__set_locked_attribute(this);
|
||||||
|
} else {
|
||||||
|
throw new InterruptedException();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
Again, doesn't always succeed
|
||||||
|
*/
|
||||||
|
public boolean tryLock() {
|
||||||
|
if (InferUndefined.boolean_undefined()) {
|
||||||
|
InferBuiltins.__set_locked_attribute(this);
|
||||||
|
return true;
|
||||||
|
} else {
|
||||||
|
return false; /*Could add unlocked, but not for now*/
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public boolean tryLock(long timeout, TimeUnit unit) throws InterruptedException {
|
||||||
|
if (InferUndefined.boolean_undefined()) {throw new InterruptedException();}
|
||||||
|
|
||||||
|
if (InferUndefined.boolean_undefined()) {
|
||||||
|
InferBuiltins.__set_locked_attribute(this);
|
||||||
|
return true;
|
||||||
|
} else {
|
||||||
|
return false; /*Could add unlocked, but not for not*/
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* In some implementations (like ReentrantLock) an exception is thrown if the lock
|
||||||
|
* is not held by the current thread. This model does not consider that possibility.
|
||||||
|
*/
|
||||||
|
public void unlock() {
|
||||||
|
InferBuiltins.__set_unlocked_attribute(this);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
@ -0,0 +1,61 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2016 - present Facebook, Inc.
|
||||||
|
* All rights reserved.
|
||||||
|
*
|
||||||
|
* This source code is licensed under the BSD style license found in the
|
||||||
|
* LICENSE file in the root directory of this source tree. An additional grant
|
||||||
|
* of patent rights can be found in the PATENTS file in the same directory.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* Reentrant Lock model
|
||||||
|
* This is a partial model. Several methods such as getowner(), hasQueueThread(),
|
||||||
|
* getQueueLength() are not modelled.
|
||||||
|
* A reentrant lock is one where if you try to lock() a lock already held by
|
||||||
|
* the current thread, you succeed and continue. In a non-reentrant lock you could deadlock.
|
||||||
|
* This is not reflected. java.util.concurrent ReentrantLocks have some fairness
|
||||||
|
* guarantees and some tings about scheduling
|
||||||
|
* when the lock is held by another thread, not considered here..
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
package java.util.concurrent.locks;
|
||||||
|
import com.facebook.infer.models.InferBuiltins;
|
||||||
|
import com.facebook.infer.models.InferUndefined;
|
||||||
|
|
||||||
|
public abstract class ReentrantLock extends Lock implements java.io.Serializable {
|
||||||
|
|
||||||
|
/* Assuming a lock starts off in this "unlocked" state */
|
||||||
|
public ReentrantLock() {
|
||||||
|
InferBuiltins.__set_unlocked_attribute(this);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
ignoring fairness (hey, this is partial corretness!)
|
||||||
|
*/
|
||||||
|
public ReentrantLock(boolean fair) {
|
||||||
|
InferBuiltins.__set_unlocked_attribute(this);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* We should be able to delete this and inherit from the modle in Lock.java,
|
||||||
|
* when improved treatment of dynamic dispatch lands
|
||||||
|
*/
|
||||||
|
public void lock() {
|
||||||
|
InferBuiltins.__set_locked_attribute(this);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* In some implementations (like ReentrantLock) an exception is thrown if the lock
|
||||||
|
* is not held by the current thread. This model does not consider that possibility.
|
||||||
|
* We should be able to delete this and inherit from the modle in Lock.java,
|
||||||
|
* when improved treatment of dynamic dispatch lands
|
||||||
|
*/
|
||||||
|
public void unlock() {
|
||||||
|
InferBuiltins.__set_unlocked_attribute(this);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* TODO. This requires us to abduce lockedness. Do later.
|
||||||
|
public boolean isLocked() {
|
||||||
|
*/
|
||||||
|
}
|
Loading…
Reference in new issue