diff options
| author | glenvt18 <glenvt18@gmail.com> | 2016-05-24 02:36:55 +0300 | 
|---|---|---|
| committer | Matti Lehtimäki <matti.lehtimaki@gmail.com> | 2018-01-02 00:22:34 +0200 | 
| commit | 9a6c69dd51255c6a3b64ab02857d67a36d82fff2 (patch) | |
| tree | 3eeff481aec0bfac4c4f9c00e9bb06aed267ed9c | |
| parent | 1ad4aaffdc820af7e0a0f8c45a4beea4f3f10421 (diff) | |
| download | vdr-plugin-epgfixer-9a6c69dd51255c6a3b64ab02857d67a36d82fff2.tar.gz vdr-plugin-epgfixer-9a6c69dd51255c6a3b64ab02857d67a36d82fff2.tar.bz2 | |
Fix compiling against VDR >= 2.3.1
| -rw-r--r-- | epgclone.c | 7 | ||||
| -rw-r--r-- | setup_menu.c | 12 | ||||
| -rw-r--r-- | tools.c | 24 | 
3 files changed, 41 insertions, 2 deletions
| @@ -49,9 +49,16 @@ void cEpgClone::CloneEvent(cEvent *Source, cEvent *Dest) {       Dest->SetSeen();    tChannelID channelID;    if (dest_num) { +#if VDRVERSNUM >= 20301 +     LOCK_CHANNELS_READ; +     const cChannel *dest_chan = Channels->GetByNumber(dest_num); +     if (dest_chan) +        channelID = Channels->GetByNumber(dest_num)->GetChannelID(); +#else       cChannel *dest_chan = Channels.GetByNumber(dest_num);       if (dest_chan)          channelID = Channels.GetByNumber(dest_num)->GetChannelID(); +#endif       else          channelID = tChannelID::InvalidID;       } diff --git a/setup_menu.c b/setup_menu.c index 8b60870..fcba6b1 100644 --- a/setup_menu.c +++ b/setup_menu.c @@ -264,9 +264,21 @@ eOSState cMenuSetupEpgfixer::ProcessKey(eKeys Key)           break;         case kBlue:           Skins.Message(mtInfo, tr("Clearing EPG data...")); +#if VDRVERSNUM >= 20301 +         { +         LOCK_TIMERS_WRITE; +         LOCK_SCHEDULES_WRITE; +         for (cTimer *Timer = Timers->First(); Timer; Timer = Timers->Next(Timer)) +            Timer->SetEvent(NULL); +         for (cSchedule *Schedule = Schedules->First(); Schedule; Schedule = Schedules->Next(Schedule)) +            Schedule->Cleanup(INT_MAX); +         } +         cEitFilter::SetDisableUntil(time(NULL) + 10); +#else           cEitFilter::SetDisableUntil(time(NULL) + 10);           if (cSchedules::ClearAll())              cEitFilter::SetDisableUntil(time(NULL) + 10); +#endif           Skins.Message(mtInfo, NULL);           state = osContinue;           break; @@ -463,14 +463,26 @@ cAddEventThread::~cAddEventThread(void)  void cAddEventThread::Action(void)  {    SetPriority(19); -  while (Running() && !LastHandleEvent.TimedOut()) { +  for (; Running() && !LastHandleEvent.TimedOut(); cCondWait::SleepMs(10)) { +        if (list->First() == NULL) +           continue;          cAddEventListItem *e = NULL; +#if VDRVERSNUM >= 20301 +        cStateKey StateKey; +        cSchedules *schedules = cSchedules::GetSchedulesWrite(StateKey, 10); +        LOCK_CHANNELS_READ; +#else          cSchedulesLock SchedulesLock(true, 10);          cSchedules *schedules = (cSchedules *)cSchedules::Schedules(SchedulesLock); +#endif          Lock();          while (schedules && (e = list->First()) != NULL) {                tChannelID chanid = e->GetChannelID(); +#if VDRVERSNUM >= 20301 +              const cChannel *chan = Channels->GetByChannelID(chanid); +#else                cChannel *chan = Channels.GetByChannelID(chanid); +#endif                if (!chan) {                   error("Destination channel %s not found for cloning!", *chanid.ToString());                   } @@ -485,7 +497,10 @@ void cAddEventThread::Action(void)                list->Del(e);                }          Unlock(); -        cCondWait::SleepMs(10); +#if VDRVERSNUM >= 20301 +        if (schedules) +           StateKey.Remove(); +#endif          }  } @@ -553,7 +568,12 @@ bool cListItem::IsActive(tChannelID ChannelID)    bool active = false;    if (numchannels > 0) {       int i = 0; +#if VDRVERSNUM >= 20301 +     LOCK_CHANNELS_READ; +     int channel_number = Channels->GetByChannelID(ChannelID)->Number(); +#else       int channel_number = Channels.GetByChannelID(ChannelID)->Number(); +#endif       while (i < numchannels) {             if ((channel_number == GetChannelNum(i)) ||                 (GetChannelID(i) && (ChannelID == *GetChannelID(i)))) { | 
