X-Git-Url: http://g0dil.de/git?a=blobdiff_plain;f=Scheduler%2FScheduler.cci;h=27f463e39f27c57e99761180e41b12548a5a1d53;hb=09010bdcf81888480d4d481a523f9714a89f2625;hp=f752d3e2121bf2fa9adfa58ecf0151e9daa8586c;hpb=ac6a813d9d99f7add4e13aff7a4bcd314d5604a6;p=senf.git diff --git a/Scheduler/Scheduler.cci b/Scheduler/Scheduler.cci index f752d3e..27f463e 100644 --- a/Scheduler/Scheduler.cci +++ b/Scheduler/Scheduler.cci @@ -1,9 +1,9 @@ // $Id$ // -// Copyright (C) 2006 -// Fraunhofer Institut fuer offene Kommunikationssysteme (FOKUS) -// Kompetenzzentrum fuer Satelitenkommunikation (SatCom) -// Stefan Bund +// Copyright (C) 2006 +// Fraunhofer Institute for Open Communication Systems (FOKUS) +// Competence Center NETwork research (NET), St. Augustin, GERMANY +// Stefan Bund // // 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 @@ -20,18 +20,46 @@ // Free Software Foundation, Inc., // 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. -// Definition of inline non-template functions +/** \file + \brief Scheduler inline non-template implementation + */ //#include "Scheduler.ih" // Custom includes +#include #define prefix_ inline ///////////////////////////////cci.p/////////////////////////////////////// -prefix_ void senf::Scheduler::terminate() +// private members + +prefix_ void senf::Scheduler::do_add(int fd, FdCallback const & cb, int eventMask) { - terminate_ = true; + do_add((boost::format("") % fd).str(), fd, cb, eventMask); +} + +prefix_ void senf::Scheduler::do_add(std::string const & name, int fd, FdCallback const & cb, + int eventMask) +{ + if (! fdDispatcher_.add(name, fd, cb, eventMask)) + fileDispatcher_.add(name, fd, cb, eventMask); +} + +prefix_ void senf::Scheduler::do_remove(int fd, int eventMask) +{ + // We don't know, where the descriptor is registered. However, this is no problem since removing + // a non-registered fd is a no-opp + fdDispatcher_.remove(fd, eventMask); + fileDispatcher_.remove(fd, eventMask); +} + +// public members + +prefix_ senf::Scheduler::Scheduler & senf::Scheduler::instance() +{ + static Scheduler instance; + return instance; } prefix_ int senf::retrieve_filehandle(int fd) @@ -39,11 +67,50 @@ prefix_ int senf::retrieve_filehandle(int fd) return fd; } +prefix_ void senf::Scheduler::terminate() +{ + terminate_ = true; +} + +prefix_ senf::ClockService::clock_type senf::Scheduler::eventTime() + const +{ + return scheduler::FdManager::instance().eventTime(); +} + +prefix_ void senf::Scheduler::taskTimeout(unsigned ms) +{ + scheduler::FIFORunner::instance().taskTimeout(ms); +} + +prefix_ unsigned senf::Scheduler::taskTimeout() + const +{ + return scheduler::FIFORunner::instance().taskTimeout(); +} + +prefix_ unsigned senf::Scheduler::hangCount() + const +{ + return scheduler::FIFORunner::instance().hangCount(); +} + +prefix_ senf::Scheduler::Scheduler() + : terminate_ (false), + fdDispatcher_ (scheduler::FdManager::instance(), scheduler::FIFORunner::instance()), + fileDispatcher_ (scheduler::FdManager::instance(), scheduler::FIFORunner::instance()) +{} + ///////////////////////////////cci.e/////////////////////////////////////// #undef prefix_ // Local Variables: // mode: c++ +// fill-column: 100 // c-file-style: "senf" +// indent-tabs-mode: nil +// ispell-local-dictionary: "american" +// compile-command: "scons -u test" +// comment-column: 40 // End: