aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorFelix Domke <tmbinc@elitedvb.net>2006-03-01 14:18:31 +0000
committerFelix Domke <tmbinc@elitedvb.net>2006-03-01 14:18:31 +0000
commitfbefcdd764d2b41d6f80f1e17e64bd72c79fa31d (patch)
tree8ba284211ec1f8bb849f9a786049aa64d68a686b
parent8d8279d975474b1cb8befad8d67df26de4104f20 (diff)
downloadenigma2-fbefcdd764d2b41d6f80f1e17e64bd72c79fa31d.tar.gz
enigma2-fbefcdd764d2b41d6f80f1e17e64bd72c79fa31d.zip
add missing
-rw-r--r--lib/dvb/dvb.cpp29
1 files changed, 22 insertions, 7 deletions
diff --git a/lib/dvb/dvb.cpp b/lib/dvb/dvb.cpp
index 5bd8fe6a..3bceebb0 100644
--- a/lib/dvb/dvb.cpp
+++ b/lib/dvb/dvb.cpp
@@ -767,9 +767,9 @@ void eDVBChannel::getNextSourceSpan(off_t current_offset, size_t bytes_read, off
int relative = seek.first;
pts_t pts = seek.second;
+ pts_t now = 0;
if (relative)
{
- pts_t now;
if (!m_cue->m_decoder)
{
eDebug("no decoder - can't seek relative");
@@ -785,11 +785,29 @@ void eDVBChannel::getNextSourceSpan(off_t current_offset, size_t bytes_read, off
eDebug("seekTo: getCurrentPosition failed!");
continue;
}
- pts += now;
}
+
+ if (relative == 1) /* pts relative */
+ pts += now;
- if (pts < 0)
- pts = 0;
+ if (relative != 2)
+ if (pts < 0)
+ pts = 0;
+
+ if (relative == 2) /* AP relative */
+ {
+ eDebug("AP relative seeking: %lld, at %lld", pts, now);
+ pts_t nextap;
+ if (m_tstools.getNextAccessPoint(nextap, now, pts))
+ {
+ pts = now;
+ eDebug("AP relative seeking failed!");
+ } else
+ {
+ eDebug("next ap is %llx\n", pts);
+ pts = nextap;
+ }
+ }
off_t offset = 0;
if (m_tstools.getOffset(offset, pts))
@@ -854,9 +872,6 @@ void eDVBChannel::getNextSourceSpan(off_t current_offset, size_t bytes_read, off
start = current_offset;
size = max;
eDebug("END OF CUESHEET. (%08llx, %d)", start, size);
-
- if (size < 4096)
- eFatal("blub");
return;
}