X-Git-Url: http://g0dil.de/git?a=blobdiff_plain;f=PPI%2FIntervalTimer.cc;h=507567edf60e35f4b61c804ecb3939287d1d45cd;hb=d8c2d9d478b8808e5b76e4688aea4f840b6a1df7;hp=ecda76da448020ac815a494e79bf34b1faf4ef0c;hpb=b8a3977542aaf217ac472e5266abd0fcffb4f95f;p=senf.git diff --git a/PPI/IntervalTimer.cc b/PPI/IntervalTimer.cc index ecda76d..507567e 100644 --- a/PPI/IntervalTimer.cc +++ b/PPI/IntervalTimer.cc @@ -1,8 +1,8 @@ // $Id$ // -// Copyright (C) 2007 -// Fraunhofer Institut fuer offene Kommunikationssysteme (FOKUS) -// Kompetenzzentrum fuer Satelitenkommunikation (SatCom) +// Copyright (C) 2007 +// 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 @@ -27,7 +27,8 @@ //#include "IntervalTimer.ih" // Custom includes -#include "Scheduler/Scheduler.hh" +#include "../Scheduler/Scheduler.hh" +#include "EventManager.hh" //#include "IntervalTimer.mpp" #define prefix_ @@ -41,7 +42,7 @@ prefix_ void senf::ppi::IntervalTimer::v_enable() { - info_.intervalStart = ClockService::now(); + info_.intervalStart = manager().now(); info_.number = 0; schedule(); } @@ -49,6 +50,7 @@ prefix_ void senf::ppi::IntervalTimer::v_enable() prefix_ void senf::ppi::IntervalTimer::v_disable() { Scheduler::instance().cancelTimeout(id_); + id_ = 0; } prefix_ void senf::ppi::IntervalTimer::schedule() @@ -60,6 +62,8 @@ prefix_ void senf::ppi::IntervalTimer::schedule() prefix_ void senf::ppi::IntervalTimer::cb() { callback(info_, info_.expected); + if (! enabled()) + return; ++ info_.number; if (info_.number >= eventsPerInterval_) { info_.number = 0;