X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/7a1d9713c8dd8a96686f75acb428b2e4dcb08c1f..5f5a10db6fc4552782638abb4817041223e17775:/src/mc/explo/simgrid_mc.cpp diff --git a/src/mc/explo/simgrid_mc.cpp b/src/mc/explo/simgrid_mc.cpp index 4e3fc12eae..51871357ee 100644 --- a/src/mc/explo/simgrid_mc.cpp +++ b/src/mc/explo/simgrid_mc.cpp @@ -21,7 +21,7 @@ int main(int argc, char** argv) xbt_assert(argc >= 2, "Missing arguments"); // Currently, we need this before sg_config_init: - simgrid::mc::model_checking_mode = simgrid::mc::ModelCheckingMode::CHECKER_SIDE; + simgrid::mc::set_model_checking_mode(simgrid::mc::ModelCheckingMode::CHECKER_SIDE); // The initialization function can touch argv. // We make a copy of argv before modifying it in order to pass the original value to the model-checked application: @@ -35,25 +35,20 @@ int main(int argc, char** argv) std::unique_ptr explo; -#if SIMGRID_HAVE_MC if (_sg_mc_comms_determinism || _sg_mc_send_determinism) - explo = std::unique_ptr(create_communication_determinism_checker(argv_copy, cfg_use_DPOR())); + explo = std::unique_ptr( + create_communication_determinism_checker(argv_copy, get_model_checking_reduction())); else if (_sg_mc_unfolding_checker) explo = std::unique_ptr(create_udpor_checker(argv_copy)); - else if (not _sg_mc_property_file.get().empty()) - explo = std::unique_ptr(create_liveness_checker(argv_copy)); else -#endif - explo = std::unique_ptr(create_dfs_exploration(argv_copy, cfg_use_DPOR())); + explo = std::unique_ptr(create_dfs_exploration(argv_copy, get_model_checking_reduction())); + ExitStatus status; try { explo->run(); - } catch (const DeadlockError&) { - return SIMGRID_MC_EXIT_DEADLOCK; - } catch (const TerminationError&) { - return SIMGRID_MC_EXIT_NON_TERMINATION; - } catch (const LivenessError&) { - return SIMGRID_MC_EXIT_LIVENESS; + status = ExitStatus::SUCCESS; + } catch (const McError& e) { + status = e.value; } - return SIMGRID_MC_EXIT_SUCCESS; + return static_cast(status); }