A
lgorithmique
N
umérique
D
istribuée
Public GIT Repository
projects
/
simgrid.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
[s4u] Allocate ConditionVariable on the heap and return ConditionVariablePtr
[simgrid.git]
/
src
/
s4u
/
s4u_conditionVariable.cpp
diff --git
a/src/s4u/s4u_conditionVariable.cpp
b/src/s4u/s4u_conditionVariable.cpp
index
ae29352
..
3200255
100644
(file)
--- a/
src/s4u/s4u_conditionVariable.cpp
+++ b/
src/s4u/s4u_conditionVariable.cpp
@@
-4,18
+4,17
@@
#include <xbt/ex.hpp>
#include <xbt/log.hpp>
#include <xbt/ex.hpp>
#include <xbt/log.hpp>
+#include "src/simix/smx_synchro_private.h"
#include "simgrid/s4u/conditionVariable.hpp"
#include "simgrid/simix.h"
namespace simgrid {
namespace s4u {
#include "simgrid/s4u/conditionVariable.hpp"
#include "simgrid/simix.h"
namespace simgrid {
namespace s4u {
-ConditionVariable::ConditionVariable() : cond_(simcall_cond_init()){
-
-}
-
-ConditionVariable::~ConditionVariable() {
- SIMIX_cond_unref(cond_);
+ConditionVariablePtr ConditionVariable::createConditionVariable()
+{
+ smx_cond_t cond = simcall_cond_init();
+ return ConditionVariablePtr(&cond->cond_, false);
}
/**
}
/**
@@
-73,5
+72,15
@@
void ConditionVariable::notify_all() {
simcall_cond_broadcast(cond_);
}
simcall_cond_broadcast(cond_);
}
+void intrusive_ptr_add_ref(ConditionVariable* cond)
+{
+ intrusive_ptr_add_ref(cond->cond_);
+}
+
+void intrusive_ptr_release(ConditionVariable* cond)
+{
+ intrusive_ptr_release(cond->cond_);
+}
+
}
}
}
}