summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--channelepg.c5
-rw-r--r--channelepg.h2
-rw-r--r--definitions.h1
-rw-r--r--epgelement.c7
-rw-r--r--gridelement.h4
-rw-r--r--tvguidengosd.c1
6 files changed, 15 insertions, 5 deletions
diff --git a/channelepg.c b/channelepg.c
index b5af13c..2f41294 100644
--- a/channelepg.c
+++ b/channelepg.c
@@ -334,10 +334,10 @@ void cChannelEpg::SetTimers(void) {
SetSwitchTimer();
for (cGridElement *grid = grids.First(); grid; grid = grids.Next(grid)) {
bool gridHadTimer = grid->HasTimer();
+ bool timerWasActive = grid->TimerIsActive();
grid->SetTimer();
- if (gridHadTimer != grid->HasTimer()) {
+ if (gridHadTimer != grid->HasTimer() || timerWasActive != grid->TimerIsActive())
grid->Dirty();
- }
bool gridHadSwitchTimer = grid->HasSwitchTimer();
grid->SetSwitchTimer();
if (gridHadSwitchTimer != grid->HasSwitchTimer())
@@ -402,6 +402,7 @@ void cChannelEpg::DrawGrids(skindesignerapi::cViewGrid *epgGrid) {
epgGrid->AddIntToken((int)eSchedulesGridIT::color, grid->Id() % 2);
epgGrid->AddIntToken((int)eSchedulesGridIT::dummy, grid->IsDummy());
epgGrid->AddIntToken((int)eSchedulesGridIT::timer, grid->HasTimer());
+ epgGrid->AddIntToken((int)eSchedulesGridIT::timerisactive, grid->TimerIsActive());
epgGrid->AddIntToken((int)eSchedulesGridIT::switchtimer, grid->HasSwitchTimer());
epgGrid->AddStringToken((int)eSchedulesGridST::title, grid->Title());
epgGrid->AddStringToken((int)eSchedulesGridST::shorttext, grid->ShortText());
diff --git a/channelepg.h b/channelepg.h
index 177b104..5321881 100644
--- a/channelepg.h
+++ b/channelepg.h
@@ -24,6 +24,7 @@ private:
cList<cGridElement> grids;
set<long> deletedElements;
bool hasTimer;
+ bool timerIsActive;
bool hasSwitchTimer;
cGridElement *AddEpgGrid(const cEvent *event, cGridElement *after = NULL);
void AddDummyGrid(time_t start, time_t end, cGridElement *after = NULL);
@@ -47,6 +48,7 @@ public:
void SetTimers(void);
void SetTimer(void);
bool HasTimer(void) { return hasTimer; };
+ bool TimerIsActive(void) { return timerIsActive; };
void SetSwitchTimer() {hasSwitchTimer = SwitchTimers.ChannelInSwitchList(channel);};
bool HasSwitchTimer() { return hasSwitchTimer; };
void ClearGrids(void);
diff --git a/definitions.h b/definitions.h
index 06518e3..0a895bb 100644
--- a/definitions.h
+++ b/definitions.h
@@ -182,6 +182,7 @@ enum class eSchedulesGridIT {
color = 0,
dummy,
timer,
+ timerisactive,
switchtimer,
count
};
diff --git a/epgelement.c b/epgelement.c
index 8990d60..d0fa0c4 100644
--- a/epgelement.c
+++ b/epgelement.c
@@ -5,6 +5,7 @@
cEpgElement::cEpgElement(const cEvent *event, cChannelEpg *owner) : cGridElement(owner) {
this->event = event;
hasTimer = false;
+ timerIsActive = false;
SetTimer();
hasSwitchTimer = false;
SetSwitchTimer();
@@ -25,9 +26,11 @@ void cEpgElement::SetTimer() {
} else {
eTimerMatch TimerMatch = tmNone;
LOCK_TIMERS_READ;
- const cTimers *timers = Timers;
- if (timers->GetMatch(event, &TimerMatch) && (TimerMatch == tmFull))
+ const cTimer *timer = Timers->GetMatch(event, &TimerMatch);
+ if (TimerMatch == tmFull) {
hasTimer = true;
+ timerIsActive = timer->HasFlags(tfActive);
+ }
#else
} else if (owner->HasTimer()) {
hasTimer = event->HasTimer();
diff --git a/gridelement.h b/gridelement.h
index aa7ccc3..839e31e 100644
--- a/gridelement.h
+++ b/gridelement.h
@@ -13,6 +13,7 @@ protected:
bool init;
bool active;
bool hasTimer;
+ bool timerIsActive;
bool hasSwitchTimer;
cChannelEpg *owner;
bool Intersects(cGridElement *neighbor);
@@ -37,6 +38,7 @@ public:
long Id(void) { return id; };
bool Active(void) { return active; };
bool HasTimer(void) {return hasTimer;};
+ bool TimerIsActive(void) { return timerIsActive; };
bool HasSwitchTimer(void) {return hasSwitchTimer;};
bool IsFirst(void);
bool IsDummy(void) { return dummy; };
@@ -48,4 +50,4 @@ public:
virtual void Debug(void) {};
};
-#endif //__TVGUIDE_GRID_H \ No newline at end of file
+#endif //__TVGUIDE_GRID_H
diff --git a/tvguidengosd.c b/tvguidengosd.c
index 2c41f92..f638faa 100644
--- a/tvguidengosd.c
+++ b/tvguidengosd.c
@@ -674,6 +674,7 @@ void cTVGuideOSD::DefineTokens(eViewGridsRoot vg, skindesignerapi::cTokenContain
tk->DefineIntToken("{color}", (int)eSchedulesGridIT::color);
tk->DefineIntToken("{dummy}", (int)eSchedulesGridIT::dummy);
tk->DefineIntToken("{timer}", (int)eSchedulesGridIT::timer);
+ tk->DefineIntToken("{timerisactive}", (int)eSchedulesGridIT::timerisactive);
tk->DefineIntToken("{switchtimer}", (int)eSchedulesGridIT::switchtimer);
tk->DefineStringToken("{title}", (int)eSchedulesGridST::title);
tk->DefineStringToken("{shorttext}", (int)eSchedulesGridST::shorttext);