m_first_program_info = 1;
eServiceReferenceDVB &service = (eServiceReferenceDVB&)m_reference;
r = m_service_handler.tune(service, m_is_pvr, m_cue);
-
+
+ // get back correct service reference (after parsing of recording meta files)
+ m_service_handler.getServiceReference(service);
+
/* inject EIT if there is a stored one */
if (m_is_pvr)
{
RESULT eDVBServicePlay::selectChannel(int i)
{
- if (i < LEFT || i > RIGHT)
+ if (i < LEFT || i > RIGHT || i == STEREO)
i = -1; // Stereo
if (m_dvb_service)
m_dvb_service->setCacheEntry(eDVBService::cACHANNEL, i);
ac3_delay = m_dvb_service->getCacheEntry(eDVBService::cAC3DELAY);
pcm_delay = m_dvb_service->getCacheEntry(eDVBService::cPCMDELAY);
}
-/*
- else if (m_reference.path.length()) // workaround for recordings
+ else // subservice or recording
{
- eDebug("playback %s", m_reference.toString().c_str());
-
- ePtr<eDVBResourceManager> res_mgr;
- if (!eDVBResourceManager::getInstance(res_mgr))
+ eServiceReferenceDVB parent = ((eServiceReferenceDVB&)m_reference).getParentServiceReference();
+ if (!parent && !m_reference.path.empty()) // is recording
+ {
+ parent = (eServiceReferenceDVB&)m_reference;
+ parent.path="";
+ }
+ if (parent)
{
- ePtr<iDVBChannelList> db;
- if (!res_mgr->getChannelList(db))
+ ePtr<eDVBResourceManager> res_mgr;
+ if (!eDVBResourceManager::getInstance(res_mgr))
{
- ePtr<eDVBService> origService;
- eServiceReference tmp = m_reference;
- tmp.path="";
- if (!db->getService((eServiceReferenceDVB&)tmp, origService))
+ ePtr<iDVBChannelList> db;
+ if (!res_mgr->getChannelList(db))
{
- ac3_delay = origService->getCacheEntry(eDVBService::cAC3DELAY);
- pcm_delay = origService->getCacheEntry(eDVBService::cPCMDELAY);
+ ePtr<eDVBService> origService;
+ if (!db->getService(parent, origService))
+ {
+ ac3_delay = origService->getCacheEntry(eDVBService::cAC3DELAY);
+ pcm_delay = origService->getCacheEntry(eDVBService::cPCMDELAY);
+ }
}
}
}
}
-*/
m_decoder->setAC3Delay(ac3_delay == -1 ? 0 : ac3_delay);
m_decoder->setPCMDelay(pcm_delay == -1 ? 0 : pcm_delay);
m_decoder->start();
+ if (vpid > 0 && vpid < 0x2000)
+ ;
+ else
+ {
+ std::string radio_pic;
+ if (!ePythonConfigQuery::getConfigValue("config.misc.radiopic", radio_pic))
+ m_decoder->setRadioPic(radio_pic);
+ }
+
m_decoder->setAudioChannel(achannel);
// how we can do this better?
void eDVBServicePlay::setAC3Delay(int delay)
{
if (m_dvb_service)
- m_dvb_service->setCacheEntry(eDVBService::cAC3DELAY, delay);
+ m_dvb_service->setCacheEntry(eDVBService::cAC3DELAY, delay ? delay : -1);
if (m_decoder)
m_decoder->setAC3Delay(delay);
}
void eDVBServicePlay::setPCMDelay(int delay)
{
if (m_dvb_service)
- m_dvb_service->setCacheEntry(eDVBService::cPCMDELAY, delay);
+ m_dvb_service->setCacheEntry(eDVBService::cPCMDELAY, delay ? delay : -1);
if (m_decoder)
m_decoder->setPCMDelay(delay);
}