projects
/
model-checker.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
execution: convert HashTable to SnapVector
[model-checker.git]
/
promise.cc
diff --git
a/promise.cc
b/promise.cc
index 26a1095f4440a4b65d80dd67917da2f423ab28fe..df86090a2335ff3e17c69d33a98c9d370903f199 100644
(file)
--- a/
promise.cc
+++ b/
promise.cc
@@
-2,17
+2,19
@@
#include <inttypes.h>
#include "promise.h"
#include <inttypes.h>
#include "promise.h"
-#include "
model
.h"
+#include "
execution
.h"
#include "schedule.h"
#include "action.h"
#include "threads-model.h"
/**
* @brief Promise constructor
#include "schedule.h"
#include "action.h"
#include "threads-model.h"
/**
* @brief Promise constructor
+ * @param execution The execution which is creating this Promise
* @param read The read which reads from a promised future value
* @param fv The future value that is promised
*/
* @param read The read which reads from a promised future value
* @param fv The future value that is promised
*/
-Promise::Promise(ModelAction *read, struct future_value fv) :
+Promise::Promise(const ModelExecution *execution, ModelAction *read, struct future_value fv) :
+ execution(execution),
num_available_threads(0),
fv(fv),
readers(1, read),
num_available_threads(0),
fv(fv),
readers(1, read),
@@
-166,3
+168,9
@@
bool Promise::same_location(const ModelAction *act) const
{
return get_reader(0)->same_var(act);
}
{
return get_reader(0)->same_var(act);
}
+
+/** @brief Get this Promise's index within the execution's promise array */
+int Promise::get_index() const
+{
+ return execution->get_promise_number(this);
+}