From 5f7e788ae8bf187760bbc122bac1221d7e62af6a Mon Sep 17 00:00:00 2001 From: Klaus Schmidinger Date: Sun, 26 Mar 2006 14:38:46 +0200 Subject: [PATCH] Improved deleting expired single shot timers --- HISTORY | 3 +++ timers.c | 15 +++++++++++++-- timers.h | 3 ++- 3 files changed, 18 insertions(+), 3 deletions(-) diff --git a/HISTORY b/HISTORY index f36bce37..ad85a22c 100644 --- a/HISTORY +++ b/HISTORY @@ -4452,3 +4452,6 @@ Video Disk Recorder Revision History - The 'running status' of EPG events is now only set to SI::RunningStatusNotRunning for events before the present event. - Fixed some #include sequences. +- Single shot VPS timers are now only considered 'expired' if their associated + EPG event has been explicitly set to SI::RunningStatusNotRunning. +- The check for timers to be deleted is now done only every 30 seconds. diff --git a/timers.c b/timers.c index 6190c15a..c7107231 100644 --- a/timers.c +++ b/timers.c @@ -4,7 +4,7 @@ * See the main source file 'vdr.c' for copyright information and * how to reach the author. * - * $Id: timers.c 1.54 2006/03/25 12:43:59 kls Exp $ + * $Id: timers.c 1.55 2006/03/26 14:38:46 kls Exp $ */ #include "timers.h" @@ -12,6 +12,7 @@ #include "channels.h" #include "device.h" #include "i18n.h" +#include "libsi/si.h" #include "remote.h" // IMPORTANT NOTE: in the 'sscanf()' calls there is a blank after the '%d' @@ -409,7 +410,13 @@ int cTimer::Matches(const cEvent *Event, int *Overlap) const bool cTimer::Expired(void) const { - return IsSingleEvent() && !Recording() && StopTime() + EXPIRELATENCY <= time(NULL); + if (IsSingleEvent() && !Recording() && StopTime() + EXPIRELATENCY <= time(NULL)) { + if (HasFlags(tfVps) && event && event->Vps()) + return event->RunningStatus() == SI::RunningStatusNotRunning; + else + return true; + } + return false; } time_t cTimer::StartTime(void) const @@ -578,6 +585,7 @@ cTimers::cTimers(void) state = 0; beingEdited = 0;; lastSetEvents = 0; + lastDeleteExpired = 0; } cTimer *cTimers::GetTimer(cTimer *Timer) @@ -673,6 +681,8 @@ void cTimers::SetEvents(void) void cTimers::DeleteExpired(void) { + if (time(NULL) - lastDeleteExpired < 30) + return; cTimer *ti = First(); while (ti) { cTimer *next = Next(ti); @@ -683,4 +693,5 @@ void cTimers::DeleteExpired(void) } ti = next; } + lastDeleteExpired = time(NULL); } diff --git a/timers.h b/timers.h index f49b48dd..8b86cc3a 100644 --- a/timers.h +++ b/timers.h @@ -4,7 +4,7 @@ * See the main source file 'vdr.c' for copyright information and * how to reach the author. * - * $Id: timers.h 1.26 2006/02/25 15:05:09 kls Exp $ + * $Id: timers.h 1.27 2006/03/26 14:38:46 kls Exp $ */ #ifndef __TIMERS_H @@ -101,6 +101,7 @@ private: int state; int beingEdited; time_t lastSetEvents; + time_t lastDeleteExpired; public: cTimers(void); cTimer *GetTimer(cTimer *Timer);