summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--epggrid.c4
-rw-r--r--recmanager.c78
-rw-r--r--tvguidengosd.c4
3 files changed, 46 insertions, 40 deletions
diff --git a/epggrid.c b/epggrid.c
index baf469b..05b3520 100644
--- a/epggrid.c
+++ b/epggrid.c
@@ -90,14 +90,14 @@ void cEpgGrid::CreateChannels(const cChannel *startChannel, int activeChannel) {
if (!startChannel)
return;
- const cChannels* chls;
#if defined (APIVERSNUM) && (APIVERSNUM >= 20301)
+ const cChannels* chls;
{
LOCK_CHANNELS_READ;
chls = Channels;
}
#else
- chls = &Channels;
+ cChannels* chls = &Channels;
#endif
for (const cChannel *channel = startChannel; channel; channel = chls->Next(channel)) {
diff --git a/recmanager.c b/recmanager.c
index 092f942..387ac31 100644
--- a/recmanager.c
+++ b/recmanager.c
@@ -175,16 +175,15 @@ void cRecManager::SetTimerPath(cTimer *timer, const cEvent *event, std::string p
}
void cRecManager::DeleteTimer(int timerID) {
+ const cTimer *t;
#if defined (APIVERSNUM) && (APIVERSNUM >= 20301)
- const cTimer *t;
- {
- LOCK_TIMERS_READ;
- t = Timers->Get(timerID);
- }
+ {
+ LOCK_TIMERS_READ;
+ t = Timers->Get(timerID);
+ }
#else
- t = Timers.Get(timerID);
+ t = Timers.Get(timerID);
#endif
-
if (!t)
return;
DeleteTimer(t);
@@ -201,8 +200,8 @@ void cRecManager::DeleteTimer(const cEvent *event) {
}
void cRecManager::DeleteLocalTimer(const cEvent *event) {
-#if defined (APIVERSNUM) && (APIVERSNUM >= 20301)
const cTimer *t;
+#if defined (APIVERSNUM) && (APIVERSNUM >= 20301)
{
LOCK_TIMERS_READ;
t = Timers->GetMatch(event);
@@ -221,12 +220,13 @@ void cRecManager::DeleteTimer(const cTimer *timer) {
#if defined (APIVERSNUM) && (APIVERSNUM >= 20301)
LOCK_TIMERS_WRITE;
cTimers* timers = Timers;
+ cTimer* t = timers->GetTimer(timer);
#else
cTimers* timers = &Timers;
+ cTimer* t = timers->GetTimer((cTimer*)timer);
#endif
-
- cTimer* t = timers->GetTimer((cTimer*)timer); // #TODO dirty cast
-
+ if (!t)
+ return;
if (t->Recording()) {
t->Skip();
#if defined (APIVERSNUM) && (APIVERSNUM >= 20301)
@@ -254,10 +254,17 @@ void cRecManager::DeleteRemoteTimer(const cEvent *event) {
}
}
-void cRecManager::SaveTimer(const cTimer *timer, cTimer newTimerSettings) {
- if (!timer)
+void cRecManager::SaveTimer(const cTimer *t, cTimer newTimerSettings) {
+ if (!t)
return;
-
+
+#if VDRVERSNUM >= 20301
+ LOCK_TIMERS_WRITE;
+ cTimer *timer = Timers->GetTimer(t);
+#else
+ cTimer *timer = Timers.GetTimer((cTimer*)t);
+#endif
+
bool active = newTimerSettings.HasFlags(tfActive);
int prio = newTimerSettings.Priority();
int lifetime = newTimerSettings.Lifetime();
@@ -266,37 +273,36 @@ void cRecManager::SaveTimer(const cTimer *timer, cTimer newTimerSettings) {
int stop = newTimerSettings.Stop();
std::string fileName = newTimerSettings.File();
- // #TODO - very dirty cast from const !!
- ((cTimer*)timer)->SetDay(day);
- ((cTimer*)timer)->SetStart(start);
- ((cTimer*)timer)->SetStop(stop);
- ((cTimer*)timer)->SetPriority(prio);
- ((cTimer*)timer)->SetLifetime(lifetime);
- ((cTimer*)timer)->SetFile(fileName.c_str());
+ timer->SetDay(day);
+ timer->SetStart(start);
+ timer->SetStop(stop);
+ timer->SetPriority(prio);
+ timer->SetLifetime(lifetime);
+ timer->SetFile(fileName.c_str());
if (timer->HasFlags(tfActive) && !active)
- ((cTimer*)timer)->ClrFlags(tfActive);
+ timer->ClrFlags(tfActive);
else if (!timer->HasFlags(tfActive) && active)
- ((cTimer*)timer)->SetFlags(tfActive);
-
-// #TODO to be implemented timer->SetEventFromSchedule();
+ timer->SetFlags(tfActive);
+
+#if VDRVERSNUM < 20300
+ timer->SetEventFromSchedule();
+#endif
if (config.useRemoteTimers && pRemoteTimers) {
RemoteTimers_Timer_v1_0 rt;
- rt.timer = (cTimer*)timer; // #TODO - dirty cast
+ rt.timer = timer;
if (!pRemoteTimers->Service("RemoteTimers::ModTimer-v1.0", &rt))
rt.timer = NULL;
RefreshRemoteTimers();
} else {
#if defined (APIVERSNUM) && (APIVERSNUM >= 20301)
- LOCK_TIMERS_WRITE;
- Timers->SetModified();
+ Timers->SetModified();
#else
- Timers.SetModified();
+ Timers.SetModified();
#endif
}
}
-
bool cRecManager::IsRecorded(const cEvent *event) {
#if defined (APIVERSNUM) && (APIVERSNUM >= 20301)
LOCK_TIMERS_WRITE;
@@ -330,7 +336,9 @@ cTVGuideTimerConflicts *cRecManager::CheckTimerConflict(void) {
}
void cRecManager::CreateSeriesTimer(cTimer *seriesTimer) {
-// #TOSO seriesTimer->SetEventFromSchedule();
+#if VDRVERSNUM < 20300
+ seriesTimer->SetEventFromSchedule();
+#endif
if (config.useRemoteTimers && pRemoteTimers) {
RemoteTimers_Timer_v1_0 rt;
rt.timer = seriesTimer;
@@ -411,17 +419,15 @@ const cEvent **cRecManager::PerformSearchTimerSearch(std::string epgSearchString
int eventID = atoi(flds[1].c_str());
std::string channelID = flds[7];
tChannelID chanID = tChannelID::FromString(channelID.c_str());
- const cChannels* channels;
+ const cChannel *channel;
#if defined (APIVERSNUM) && (APIVERSNUM >= 20301)
{
LOCK_CHANNELS_READ;
- channels = Channels;
+ channel = Channels->GetByChannelID(chanID);
}
#else
- channels = &Channels;
+ channel = Channels.GetByChannelID(chanID);
#endif
-
- const cChannel *channel = channels->GetByChannelID(chanID);
if (channel) {
const cSchedule *Schedule = NULL;
Schedule = schedules->GetSchedule(channel);
diff --git a/tvguidengosd.c b/tvguidengosd.c
index 2f635bf..2c41f92 100644
--- a/tvguidengosd.c
+++ b/tvguidengosd.c
@@ -345,14 +345,14 @@ void cTVGuideOSD::CheckTimeout(void) {
int newChannelNum = channelJumper->GetChannel();
delete channelJumper;
channelJumper = NULL;
- const cChannels* channels;
#if defined (APIVERSNUM) && (APIVERSNUM >= 20301)
+ const cChannels* channels;
{
LOCK_CHANNELS_READ;
channels = Channels;
}
#else
- channels = &Channels;
+ cChannels* channels = &Channels;
#endif
const cChannel *newChannel = channels->GetByNumber(newChannelNum);
if (!newChannel) {