X-Git-Url: http://g0dil.de/git?a=blobdiff_plain;f=senf%2FScheduler%2FTimerEventProxy.ct;h=b851ba11985c43c7294517748f9dba65de8e518d;hb=refs%2Fheads%2Fmaster;hp=0c1899d39afb6e7c8611cd20ec943c620ee8626f;hpb=4adca0eda1b26c8ca84421fd936f8450713ca6fd;p=senf.git diff --git a/senf/Scheduler/TimerEventProxy.ct b/senf/Scheduler/TimerEventProxy.ct index 0c1899d..b851ba1 100644 --- a/senf/Scheduler/TimerEventProxy.ct +++ b/senf/Scheduler/TimerEventProxy.ct @@ -2,61 +2,58 @@ // // Copyright (C) 2010 // Fraunhofer Institute for Open Communication Systems (FOKUS) -// Competence Center NETwork research (NET), St. Augustin, GERMANY -// Mathias Kretschmer -// Jens Moedeker // -// 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 2 of the License, or -// (at your option) any later version. +// The contents of this file are subject to the Fraunhofer FOKUS Public License +// Version 1.0 (the "License"); you may not use this file except in compliance +// with the License. You may obtain a copy of the License at +// http://senf.berlios.de/license.html // -// 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. +// The Fraunhofer FOKUS Public License Version 1.0 is based on, +// but modifies the Mozilla Public License Version 1.1. +// See the full license text for the amendments. // -// You should have received a copy of the GNU General Public License -// along with this program; if not, write to the -// Free Software Foundation, Inc., -// 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. +// Software distributed under the License is distributed on an "AS IS" basis, +// WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License +// for the specific language governing rights and limitations under the License. +// +// The Original Code is Fraunhofer FOKUS code. +// +// The Initial Developer of the Original Code is Fraunhofer-Gesellschaft e.V. +// (registered association), Hansastraße 27 c, 80686 Munich, Germany. +// All Rights Reserved. +// +// Contributor(s): +// Mathias Kretschmer +// Jens Moedeker /** \file \brief TimerEventProxy non-inline template implementation */ // Custom includes +#include #define prefix_ -///////////////////////////////ct.p//////////////////////////////////////// +//-///////////////////////////////////////////////////////////////////////////////////////////////// template -prefix_ senf::scheduler::TimerEventProxy::TimerEventProxy() +prefix_ senf::scheduler::TimerEventProxy::TimerEventProxy(std::string const & description) : entrySetById( entrySet.template get()), entrySetByTimeout( entrySet.template get ()), - timer( "TimerEventProxy", membind(&TimerEventProxy::timerEvent, this), 0, false) + timer( "TimerEventProxy " + description, + membind(&TimerEventProxy::timerEvent, this), ClockService::clock_type(0), false) { } template -prefix_ senf::scheduler::TimerEventProxy::TimerEventProxy(std::string const & name, console::DirectoryNode & node) - : entrySetById( entrySet.template get()), - entrySetByTimeout( entrySet.template get ()), - timer( "TimerEventProxy", membind(&TimerEventProxy::timerEvent, this), 0, false) -{ - node.add(name, console::factory::Command( - &TimerEventProxy::list, this) .doc("List active Timers")); -} - -template prefix_ void senf::scheduler::TimerEventProxy::timerEvent() { - ClockService::clock_type actual = ClockService::now(); + ClockService::clock_type now = senf::scheduler::now(); typename EntrySetByTimeout_t::iterator it = entrySetByTimeout.begin(); - while (it != entrySetByTimeout.end() && it->timeout <= actual) { + while (it != entrySetByTimeout.end() && it->timeout <= now) { Entry item (*it); // remove due entry from set entrySetByTimeout.erase(it); // call callback - item.cb(actual, item.id); + item.cb(now, item.id); it = entrySetByTimeout.begin(); } if (entrySet.size() > 0) @@ -67,8 +64,15 @@ template prefix_ void senf::scheduler::TimerEventProxy::add( ClockService::clock_type timeout, IdType const & id, Callback cb) { - // insert new entry - entrySetByTimeout.insert( Entry(timeout, id, cb)); + // insert new entry or replace the timeout of an entry already indexed + typename EntrySetById_t::iterator i = entrySetById.find(id); + if (i == entrySetById.end()) + entrySetByTimeout.insert( Entry(timeout, id, cb)); + else { + Entry tmp = *i; + tmp.timeout = timeout; + entrySetById.replace(i,tmp); + } // the scheduler time to the first earliest timeout (ordered index) timer.timeout( entrySetByTimeout.begin()->timeout); } @@ -76,7 +80,12 @@ prefix_ void senf::scheduler::TimerEventProxy::add( template prefix_ bool senf::scheduler::TimerEventProxy::remove(IdType const & id) { - return entrySetById.erase( id) > 0; + bool removed (entrySetById.erase( id) > 0); + if (entrySet.size() > 0) + timer.timeout(entrySetByTimeout.begin()->timeout); + else + timer.disable(); + return removed; } template @@ -84,7 +93,7 @@ prefix_ senf::ClockService::clock_type senf::scheduler::TimerEventProxy: const { typename EntrySetById_t::const_iterator i ( entrySetById.find( id)); - return i == entrySetById.end() ? 0 : i->timeout; + return i == entrySetById.end() ? ClockService::clock_type(0) : i->timeout; } @@ -101,7 +110,20 @@ prefix_ std::vector > senf::sc return tmp; } -///////////////////////////////ct.e//////////////////////////////////////// +template +prefix_ unsigned senf::scheduler::TimerEventProxy::numEvents() + const +{ + return entrySetByTimeout.size(); +} + +template +prefix_ void senf::scheduler::TimerEventProxy::clear() +{ + entrySetByTimeout.clear(); +} + +//-///////////////////////////////////////////////////////////////////////////////////////////////// #undef prefix_