X-Git-Url: http://bilbo.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/1fc1cd99f7f9f56c732dcaf07d8c9afed2560e85..6bc04475b4308e91e18d869a5fb665bc35b48508:/src/mc/explo/udpor/UnfoldingEvent.hpp diff --git a/src/mc/explo/udpor/UnfoldingEvent.hpp b/src/mc/explo/udpor/UnfoldingEvent.hpp index d7a03e17a5..bad411cfe2 100644 --- a/src/mc/explo/udpor/UnfoldingEvent.hpp +++ b/src/mc/explo/udpor/UnfoldingEvent.hpp @@ -10,6 +10,7 @@ #include "src/mc/explo/udpor/udpor_forward.hpp" #include "src/mc/transition/Transition.hpp" +#include #include #include @@ -17,23 +18,47 @@ namespace simgrid::mc::udpor { class UnfoldingEvent { public: - UnfoldingEvent(std::shared_ptr transition = std::make_unique(), - EventSet immediate_causes = EventSet(), unsigned long event_id = 0); + explicit UnfoldingEvent(std::initializer_list init_list); + UnfoldingEvent(EventSet immediate_causes = EventSet(), + std::shared_ptr transition = std::make_unique()); UnfoldingEvent(const UnfoldingEvent&) = default; UnfoldingEvent& operator=(UnfoldingEvent const&) = default; UnfoldingEvent(UnfoldingEvent&&) = default; EventSet get_history() const; - bool in_history_of(const UnfoldingEvent* otherEvent) const; + EventSet get_local_config() const; + bool in_history_of(const UnfoldingEvent* other) const; - bool conflicts_with(const UnfoldingEvent* otherEvent) const; - bool conflicts_with(const Configuration& config) const; - bool immediately_conflicts_with(const UnfoldingEvent* otherEvt) const; + /** + * @brief Whether or not the given event is a decendant + * of or an ancestor of the given event + */ + bool related_to(const UnfoldingEvent* other) const; + + /// @brief Whether or not this event is in conflict with + /// the given one (i.e. whether `this # other`) + bool conflicts_with(const UnfoldingEvent* other) const; + + /// @brief Whether or not this event is in conflict with + /// any event in the given set + bool conflicts_with_any(const EventSet& events) const; + /// @brief Computes "this #ⁱ other" + bool immediately_conflicts_with(const UnfoldingEvent* other) const; + bool is_dependent_with(const Transition*) const; + bool is_dependent_with(const UnfoldingEvent* other) const; + + const EventSet& get_immediate_causes() const { return this->immediate_causes; } Transition* get_transition() const { return this->associated_transition.get(); } + aid_t get_actor() const { return get_transition()->aid_; } + + void set_transition(std::shared_ptr t) { this->associated_transition = std::move(t); } + + std::string to_string() const; bool operator==(const UnfoldingEvent&) const; + bool operator!=(const UnfoldingEvent& other) const { return not(*this == other); } private: /** @@ -66,8 +91,6 @@ private: * so on. */ EventSet immediate_causes; - - unsigned long event_id = 0; }; } // namespace simgrid::mc::udpor