diff options
author | Dimitar Petrovski <dimeptr@gmail.com> | 2012-06-03 22:24:00 +0200 |
---|---|---|
committer | Dimitar Petrovski <dimeptr@gmail.com> | 2012-06-03 22:24:00 +0200 |
commit | f99c11b6335c28204d0e3dbf8ebfd287279d2939 (patch) | |
tree | 5230d6afd73b2357af3bac0d6b288d161bba0859 /epghandler.c | |
parent | 1e5c78ae3b461343f87d49210116c20d5203ca7a (diff) | |
download | vdr-plugin-eepg-f99c11b6335c28204d0e3dbf8ebfd287279d2939.tar.gz vdr-plugin-eepg-f99c11b6335c28204d0e3dbf8ebfd287279d2939.tar.bz2 |
fix wrong conflict resolution
modify the long events dispose logic
Diffstat (limited to 'epghandler.c')
-rw-r--r-- | epghandler.c | 11 |
1 files changed, 7 insertions, 4 deletions
diff --git a/epghandler.c b/epghandler.c index e323ed1..44ee909 100644 --- a/epghandler.c +++ b/epghandler.c @@ -34,13 +34,16 @@ bool cEEpgHandler::HandleEitEvent(cSchedule* Schedule, if (EitEvent->getDurationHour() > _LONG_EVENT_HOURS) { LogD(4, prep("Event longer than 10h Duration:%d DurationHour:%d StartTimeHour:%d"), EitEvent->getDuration(), EitEvent->getDurationHour(), EitEvent->getStartTimeHour()); const cEvent* exEvent = Schedule->GetEventAround(EitEvent->getStartTime()+EitEvent->getDuration()/3); - const cEvent* exEvent2 = (const cEvent*)exEvent->Next(); - if (exEvent && exEvent2 && difftime (exEvent2->EndTime(),EitEvent->getStartTime()+EitEvent->getDuration()) <= 0 ) { - LogD(3, prep("EitEvent overrides existing events '%s', '%s' ... Skipping"), exEvent->Title(), exEvent2->Title()); - return true; + if (exEvent) { + const cEvent* exEvent2 = Schedule->GetEventAround(EitEvent->getStartTime()+EitEvent->getDuration()/3*2); + if (exEvent2 && exEvent != exEvent2) { + LogD(2, prep("EitEvent overrides existing events '%s', '%s' ... Skipping"), *exEvent->Title(), *exEvent2->Title()); + return true; + } } } + return false; // return true; } |