/** * @file EventTable.cpp * @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 . */ #include #include #include namespace paradevs { Model* EventTable::get_current_model() { return back().get_model(); } void EventTable::init(Time time, Model* model) { push_back(InternalEvent(time, model)); std::sort(begin(), end()); } void EventTable::put(Time time, Model* model) { remove(model); push_back(InternalEvent(time, model)); std::sort(begin(), end()); } void EventTable::remove(Model* model) { iterator jt = begin(); while (jt != end()) { if (jt->get_model() == model) { jt = erase(jt); } else { ++jt; } } } std::string EventTable::to_string() const { std::stringstream ss; ss << "EventTable = { "; for (const_iterator it = begin(); it != end(); ++it) { ss << "(" << it->get_time() << " -> " << it->get_model()->get_name() << ") "; } ss << "}"; return ss.str(); } } // namespace paradevs