X-Git-Url: http://bilbo.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/3203afd846219ef8b41cadda945ea0a98103c46f..6260d187764dc644d699e1a53454f7efdcc682df:/src/mc/explo/udpor/UnfoldingEvent.hpp diff --git a/src/mc/explo/udpor/UnfoldingEvent.hpp b/src/mc/explo/udpor/UnfoldingEvent.hpp index 2bd29e991b..bad411cfe2 100644 --- a/src/mc/explo/udpor/UnfoldingEvent.hpp +++ b/src/mc/explo/udpor/UnfoldingEvent.hpp @@ -18,7 +18,7 @@ namespace simgrid::mc::udpor { class UnfoldingEvent { public: - UnfoldingEvent(std::initializer_list init_list); + explicit UnfoldingEvent(std::initializer_list init_list); UnfoldingEvent(EventSet immediate_causes = EventSet(), std::shared_ptr transition = std::make_unique()); @@ -27,16 +27,38 @@ public: 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: /**