X-Git-Url: http://bilbo.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/f734ec7475682eb90323e804cbcfddd7e4523992..d89ca681772fdaafdd69049d4d66676a4e98de38:/src/mc/checker/Checker.hpp diff --git a/src/mc/checker/Checker.hpp b/src/mc/checker/Checker.hpp index 3e0cec84bb..e43676ec00 100644 --- a/src/mc/checker/Checker.hpp +++ b/src/mc/checker/Checker.hpp @@ -1,4 +1,4 @@ -/* Copyright (c) 2016-2017. The SimGrid Team. +/* Copyright (c) 2016-2022. The SimGrid Team. * All rights reserved. */ /* This program is free software; you can redistribute it and/or modify it @@ -7,13 +7,7 @@ #ifndef SIMGRID_MC_CHECKER_HPP #define SIMGRID_MC_CHECKER_HPP -#include -#include -#include - -#include "src/mc/mc_forward.hpp" -#include "src/mc/mc_record.hpp" -#include "src/mc/Session.hpp" +#include "src/mc/api.hpp" namespace simgrid { namespace mc { @@ -33,14 +27,15 @@ namespace mc { // abstract class Checker { Session* session_; + public: - explicit Checker(Session& session); + explicit Checker(Session* session) : session_(session) {} // No copy: Checker(Checker const&) = delete; Checker& operator=(Checker const&) = delete; - virtual ~Checker(); + virtual ~Checker() = default; /** Main function of this algorithm */ virtual void run() = 0; @@ -52,23 +47,24 @@ public: /** Show the current trace/stack * * Could this be handled in the Session/ModelChecker instead? */ - virtual RecordTrace getRecordTrace(); + virtual RecordTrace get_record_trace() = 0; /** Generate a textual execution trace of the simulated application */ - virtual std::vector getTextualTrace(); + virtual std::vector get_textual_trace() = 0; /** Log additional information about the state of the model-checker */ - virtual void logState(); + virtual void log_state() = 0; -protected: - Session& getSession() { return *session_; } + Session& get_session() { return *session_; } }; -XBT_PUBLIC() Checker* createLivenessChecker(Session& session); -XBT_PUBLIC() Checker* createSafetyChecker(Session& session); -XBT_PUBLIC() Checker* createCommunicationDeterminismChecker(Session& session); +// External constructors so that the types (and the types of their content) remain hidden +XBT_PUBLIC Checker* create_liveness_checker(Session* session); +XBT_PUBLIC Checker* create_safety_checker(Session* session); +XBT_PUBLIC Checker* create_communication_determinism_checker(Session* session); +XBT_PUBLIC Checker* create_udpor_checker(Session* session); -} -} +} // namespace mc +} // namespace simgrid #endif