12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667 |
- /**
- * @file Model.hpp
- * @author The PARADEVS Development Team
- * See the AUTHORS or Authors.txt file
- */
- /*
- * PARADEVS - the multimodeling and simulation environment
- * This file is a part of the PARADEVS environment
- *
- * Copyright (C) 2013 ULCO http://www.univ-litoral.fr
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU General Public License as published by
- * the Free Software Foundation, either version 3 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- * GNU General Public License for more details.
- *
- * You should have received a copy of the GNU General Public License
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
- */
- #ifndef PDEVS_MODEL
- #define PDEVS_MODEL 1
- #include <pdevs/Dynamics.hpp>
- #include <common/Message.hpp>
- #include <common/Time.hpp>
- #include <iostream>
- #include <vector>
- namespace paradevs { namespace pdevs {
- class Model : public common::Model
- {
- public:
- Model(const std::string& name);
- virtual ~Model();
- virtual common::Time i_message(common::Time /* t */) = 0;
- virtual common::Time s_message(common::Time /* t */) =0;
- virtual bool is_atomic() const = 0;
- virtual void post_message(common::Time /* t */,
- const common::Message& /* message */) = 0;
- };
- class Models : public std::vector < Model* >
- {
- public:
- Models()
- { }
- virtual ~Models()
- { }
- std::string to_string() const;
- };
- } } // namespace paradevs pdevs
- #endif
|