Commit b6704005 authored by Francois Cartegnie's avatar Francois Cartegnie

demux: dash: add Timeline merging

parent bba54210
...@@ -128,6 +128,54 @@ size_t SegmentTimeline::prune(mtime_t scaled) ...@@ -128,6 +128,54 @@ size_t SegmentTimeline::prune(mtime_t scaled)
return prunednow; return prunednow;
} }
void SegmentTimeline::mergeWith(SegmentTimeline &other)
{
if(elements.empty())
{
while(other.elements.size())
{
elements.push_back(other.elements.front());
other.elements.pop_front();
}
return;
}
Element *last = elements.back();
while(other.elements.size())
{
Element *el = other.elements.front();
other.elements.pop_front();
if(el->t == last->t) /* Same element, but prev could have been middle of repeat */
{
last->r = std::max(last->r, el->r);
delete el;
}
else if(el->t > last->t) /* Did not exist in previous list */
{
if( el->t - last->t >= last->d * (mtime_t)(last->r + 1) )
{
elements.push_back(el);
last = el;
}
else if(last->d == el->d) /* should always be in that case */
{
last->r = ((el->t - last->t) / last->d) - 1;
elements.push_back(el);
last = el;
}
else
{
/* borked: skip */
delete el;
}
}
else
{
delete el;
}
}
}
SegmentTimeline::Element::Element(mtime_t d_, uint64_t r_, mtime_t t_) SegmentTimeline::Element::Element(mtime_t d_, uint64_t r_, mtime_t t_)
{ {
d = d_; d = d_;
......
...@@ -42,6 +42,7 @@ namespace dash ...@@ -42,6 +42,7 @@ namespace dash
uint64_t getElementNumberByScaledPlaybackTime(time_t) const; uint64_t getElementNumberByScaledPlaybackTime(time_t) const;
mtime_t getScaledPlaybackTimeByElementNumber(uint64_t) const; mtime_t getScaledPlaybackTimeByElementNumber(uint64_t) const;
size_t prune(mtime_t); size_t prune(mtime_t);
void mergeWith(SegmentTimeline &);
private: private:
std::list<Element *> elements; std::list<Element *> elements;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment