From: Felix Domke Date: Mon, 16 Feb 2009 17:25:23 +0000 (+0100) Subject: Merge branch 'master' of /home/tmbinc/enigma2-git into tmbinc/FixTimingBugs X-Git-Tag: 2.6.0~350^2~2 X-Git-Url: https://git.cweiske.de/enigma2.git/commitdiff_plain/d58ca4cf34b7621aea4e2c1ff07bed6b2cd6b763?hp=-c Merge branch 'master' of /home/tmbinc/enigma2-git into tmbinc/FixTimingBugs --- d58ca4cf34b7621aea4e2c1ff07bed6b2cd6b763 diff --combined lib/python/Components/Converter/StringList.py index d424d39f,213f08bc..226247c4 --- a/lib/python/Components/Converter/StringList.py +++ b/lib/python/Components/Converter/StringList.py @@@ -18,14 -18,18 +18,21 @@@ class StringList(Converter) def selectionChanged(self, index): self.source.selectionChanged(index) + + def setIndex(self, index): # update all non-master targets + print "changed selection in listbox!" for x in self.downstream_elements: + print "downstream element", x if x is not self.master: + print "is not master, so update to index", index x.index = index + def getIndex(self, index): + return None + + index = property(getIndex, setIndex) + @cached def getCurrent(self): if self.source is None or self.index is None or self.index >= len(self.source.list): diff --combined lib/service/servicedvb.cpp index 2f91971a,12b75f80..14c849db --- a/lib/service/servicedvb.cpp +++ b/lib/service/servicedvb.cpp @@@ -506,7 -506,6 +506,7 @@@ RESULT eDVBPVRServiceOfflineOperations: res.push_back(m_ref.path + ".meta"); res.push_back(m_ref.path + ".ap"); + res.push_back(m_ref.path + ".sc"); res.push_back(m_ref.path + ".cuts"); std::string tmp = m_ref.path; tmp.erase(m_ref.path.length()-3); @@@ -525,6 -524,7 +525,7 @@@ eServiceFactoryDVB::eServiceFactoryDVB( { std::list extensions; extensions.push_back("ts"); + extensions.push_back("trp"); sc->addServiceFactory(eServiceFactoryDVB::id, this, extensions); } @@@ -1006,10 -1006,7 +1007,10 @@@ void eDVBServicePlay::serviceEventTimes break; case eDVBServicePMTHandler::eventEOF: if ((!m_is_paused) && (m_skipmode >= 0)) + { + eDebug("timeshift EOF, so let's go live"); switchToLive(); + } break; } } @@@ -1132,9 -1129,6 +1133,9 @@@ RESULT eDVBServicePlay::pause(ePtrsetSlowMotion(ratio); else @@@ -1142,13 -1136,6 +1143,13 @@@ } RESULT eDVBServicePlay::setFastForward(int ratio) +{ + eDebug("eDVBServicePlay::setFastForward(%d)", ratio); + assert(ratio); + return setFastForward_internal(ratio); +} + +RESULT eDVBServicePlay::setFastForward_internal(int ratio) { int skipmode, ffratio; @@@ -1181,13 -1168,8 +1182,13 @@@ if (!m_decoder) return -1; - - return m_decoder->setFastForward(ffratio); + + if (ffratio == 0) + ; /* return m_decoder->play(); is done in caller*/ + else if (ffratio != 1) + return m_decoder->setFastForward(ffratio); + else + return m_decoder->setTrickmode(); } RESULT eDVBServicePlay::seek(ePtr &ptr) @@@ -1215,24 -1197,20 +1216,24 @@@ RESULT eDVBServicePlay::getLength(pts_ RESULT eDVBServicePlay::pause() { - if (!m_is_paused && m_decoder) + eDebug("eDVBServicePlay::pause"); + setFastForward_internal(0); + if (m_decoder) { m_is_paused = 1; - return m_decoder->freeze(0); + return m_decoder->pause(); } else return -1; } RESULT eDVBServicePlay::unpause() { - if (m_is_paused && m_decoder) + eDebug("eDVBServicePlay::unpause"); + setFastForward_internal(0); + if (m_decoder) { m_is_paused = 0; - return m_decoder->unfreeze(); + return m_decoder->play(); } else return -1; } @@@ -1314,8 -1292,9 +1315,8 @@@ RESULT eDVBServicePlay::getPlayPosition RESULT eDVBServicePlay::setTrickmode(int trick) { - if (m_decoder) - m_decoder->setTrickmode(trick); - return 0; + /* currently unimplemented */ + return -1; } RESULT eDVBServicePlay::isCurrentlySeekable() @@@ -1601,7 -1580,7 +1602,7 @@@ RESULT eDVBServicePlay::selectTrack(uns { int ret = selectAudioStream(i); - if (m_decoder->start()) + if (m_decoder->play()) return -5; return ret; @@@ -2133,8 -2112,6 +2134,8 @@@ void eDVBServicePlay::switchToLive( if (!m_timeshift_active) return; + eDebug("SwitchToLive"); + m_cue = 0; m_decoder = 0; m_decode_demux = 0; @@@ -2176,7 -2153,7 +2177,7 @@@ void eDVBServicePlay::switchToTimeshift r.path = m_timeshift_file; m_cue = new eCueSheet(); - m_service_handler_timeshift.tune(r, 1, m_cue); /* use the decoder demux for everything */ + m_service_handler_timeshift.tune(r, 1, m_cue, 0, m_dvb_service); /* use the decoder demux for everything */ eDebug("eDVBServicePlay::switchToTimeshift, in pause mode now."); pause(); @@@ -2305,12 -2282,13 +2306,12 @@@ void eDVBServicePlay::updateDecoder( m_teletext_parser->start(program.textPid); - if (!m_is_primary) - m_decoder->setTrickmode(1); - - if (m_is_paused) - m_decoder->preroll(); +/* if (!m_is_primary) + m_decoder->setTrickmode(); + else */ if (m_is_paused) + m_decoder->pause(); else - m_decoder->start(); + m_decoder->play(); if (vpid > 0 && vpid < 0x2000) ; @@@ -2332,7 -2310,7 +2333,7 @@@ m_dvb_service->setCacheEntry(eDVBService::cPCRPID, pcrpid); m_dvb_service->setCacheEntry(eDVBService::cTPID, tpid); } - } + } m_have_video_pid = (vpid > 0 && vpid < 0x2000); }