Commit 882b9a82 authored by Francois Cartegnie's avatar Francois Cartegnie

demux: dash: Update MPD

parent 08bf5c8d
...@@ -28,8 +28,12 @@ ...@@ -28,8 +28,12 @@
#endif #endif
#include "DASHManager.h" #include "DASHManager.h"
#include "mpd/MPDFactory.h"
#include "mpd/SegmentTimeline.h"
#include "xml/DOMParser.h"
#include "adaptationlogic/AdaptationLogicFactory.h" #include "adaptationlogic/AdaptationLogicFactory.h"
#include "SegmentTracker.hpp" #include "SegmentTracker.hpp"
#include <vlc_stream.h>
using namespace dash; using namespace dash;
using namespace dash::http; using namespace dash::http;
...@@ -41,7 +45,8 @@ DASHManager::DASHManager ( MPD *mpd, ...@@ -41,7 +45,8 @@ DASHManager::DASHManager ( MPD *mpd,
conManager ( NULL ), conManager ( NULL ),
logicType ( type ), logicType ( type ),
mpd ( mpd ), mpd ( mpd ),
stream ( stream ) stream ( stream ),
nextMPDupdate ( 0 )
{ {
for(int i=0; i<Streams::count; i++) for(int i=0; i<Streams::count; i++)
streams[i] = NULL; streams[i] = NULL;
...@@ -97,6 +102,7 @@ bool DASHManager::start(demux_t *demux) ...@@ -97,6 +102,7 @@ bool DASHManager::start(demux_t *demux)
return false; return false;
mpd->playbackStart.Set(time(NULL)); mpd->playbackStart.Set(time(NULL));
nextMPDupdate = mpd->playbackStart.Get();
return true; return true;
} }
...@@ -189,3 +195,60 @@ bool DASHManager::seekAble() const ...@@ -189,3 +195,60 @@ bool DASHManager::seekAble() const
} }
return true; return true;
} }
bool DASHManager::updateMPD()
{
if(!mpd->isLive() || !mpd->minUpdatePeriod.Get())
return true;
mtime_t now = time(NULL);
if(nextMPDupdate && now < nextMPDupdate)
return true;
/* do update */
if(nextMPDupdate)
{
std::string url(stream->psz_access);
url.append("://");
url.append(stream->psz_path);
stream_t *mpdstream = stream_UrlNew(stream, url.c_str());
if(!mpdstream)
return false;
xml::DOMParser parser(mpdstream);
if(!parser.parse())
{
stream_Delete(mpdstream);
return false;
}
MPD *newmpd = MPDFactory::create(parser.getRootNode(), mpdstream, parser.getProfile());
if(newmpd)
{
mpd->mergeWith(newmpd);
delete newmpd;
}
stream_Delete(mpdstream);
}
/* Compute new MPD update time */
mtime_t mininterval = 0;
mtime_t maxinterval = 0;
mpd->getTimeLinesBoundaries(&mininterval, &maxinterval);
if(maxinterval > mininterval)
maxinterval = (maxinterval - mininterval) / CLOCK_FREQ;
else
maxinterval = 60;
maxinterval = std::max(maxinterval, (mtime_t)60);
mininterval = std::max(mpd->minUpdatePeriod.Get(),
mpd->maxSegmentDuration.Get());
nextMPDupdate = now + (maxinterval - mininterval) / 2;
msg_Dbg(stream, "Updated MPD, next update in %"PRId64"s (%"PRId64"..%"PRId64")",
nextMPDupdate - now, mininterval, maxinterval );
return true;
}
...@@ -46,6 +46,7 @@ namespace dash ...@@ -46,6 +46,7 @@ namespace dash
int esCount() const; int esCount() const;
bool setPosition(mtime_t); bool setPosition(mtime_t);
bool seekAble() const; bool seekAble() const;
bool updateMPD();
private: private:
http::HTTPConnectionManager *conManager; http::HTTPConnectionManager *conManager;
...@@ -53,6 +54,7 @@ namespace dash ...@@ -53,6 +54,7 @@ namespace dash
mpd::MPD *mpd; mpd::MPD *mpd;
stream_t *stream; stream_t *stream;
Streams::Stream *streams[Streams::count]; Streams::Stream *streams[Streams::count];
mtime_t nextMPDupdate;
}; };
} }
......
...@@ -182,6 +182,10 @@ static int Demux(demux_t *p_demux) ...@@ -182,6 +182,10 @@ static int Demux(demux_t *p_demux)
else else
es_out_Control(p_demux->out, ES_OUT_SET_PCR, pcr); es_out_Control(p_demux->out, ES_OUT_SET_PCR, pcr);
} }
if( !p_sys->p_dashManager->updateMPD() )
return VLC_DEMUXER_EOF;
return VLC_DEMUXER_SUCCESS; return VLC_DEMUXER_SUCCESS;
} }
else else
......
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