1 /* Copyright (c) 2015-2022. The SimGrid Team. All rights reserved. */
3 /* This program is free software; you can redistribute it and/or modify it
4 * under the terms of the license (GNU LGPL) which comes with this package. */
6 #include "src/mc/transition/TransitionAny.hpp"
7 #include "xbt/asserts.h"
8 #include <simgrid/config.h>
10 #include "src/mc/ModelChecker.hpp"
11 #include "src/mc/Session.hpp"
12 #include "src/mc/api/State.hpp"
17 XBT_LOG_NEW_DEFAULT_SUBCATEGORY(mc_trans_any, mc_transition, "Logging specific to MC WaitAny / TestAny transitions");
19 namespace simgrid::mc {
21 TestAnyTransition::TestAnyTransition(aid_t issuer, int times_considered, std::stringstream& stream)
22 : Transition(Type::TESTANY, issuer, times_considered)
25 xbt_assert(stream >> size);
26 for (int i = 0; i < size; i++) {
27 Transition* t = deserialize_transition(issuer, 0, stream);
28 XBT_DEBUG("TestAny received a transition %s", t->to_string(true).c_str());
29 transitions_.push_back(t);
32 std::string TestAnyTransition::to_string(bool verbose) const
34 auto res = xbt::string_printf("TestAny{ ");
35 for (auto const* t : transitions_)
36 res += t->to_string(verbose);
40 bool TestAnyTransition::depends(const Transition* other) const
42 return transitions_[times_considered_]->depends(other);
44 WaitAnyTransition::WaitAnyTransition(aid_t issuer, int times_considered, std::stringstream& stream)
45 : Transition(Type::WAITANY, issuer, times_considered)
48 xbt_assert(stream >> size);
49 for (int i = 0; i < size; i++) {
50 Transition* t = deserialize_transition(issuer, 0, stream);
51 transitions_.push_back(t);
54 std::string WaitAnyTransition::to_string(bool verbose) const
56 auto res = xbt::string_printf("WaitAny{ ");
57 for (auto const* t : transitions_)
58 res += t->to_string(verbose);
62 bool WaitAnyTransition::depends(const Transition* other) const
64 return transitions_[times_considered_]->depends(other);
67 } // namespace simgrid::mc