diff options
author | Luca Muscariello <lumuscar+fdio@cisco.com> | 2017-06-19 12:30:20 +0000 |
---|---|---|
committer | Gerrit Code Review <gerrit@fd.io> | 2017-06-19 12:30:20 +0000 |
commit | e207b82a2b7e70e2700cf1c4237a2e819c655809 (patch) | |
tree | ad1565a5d9aabb3c699a80404f60aa68ea56d914 /MPD/AbstractRepresentationStream.cpp | |
parent | 0b0fe36cbc95a483d205d3f86fea579f0cdd5f59 (diff) | |
parent | f8907f0a7a84928800adbbfd8e66e500794aa5d5 (diff) |
Merge "Adding handling for different kind of MPDs (previously the front end could only handle MPD with SegmentList) Now can handle: MPD with SegmentTemplate in Representation (VOD) MPD with SegmentTemplate and SegmentTimeline (live)" into viper/master
Diffstat (limited to 'MPD/AbstractRepresentationStream.cpp')
-rw-r--r-- | MPD/AbstractRepresentationStream.cpp | 14 |
1 files changed, 12 insertions, 2 deletions
diff --git a/MPD/AbstractRepresentationStream.cpp b/MPD/AbstractRepresentationStream.cpp index 449c6aa8..346938f4 100644 --- a/MPD/AbstractRepresentationStream.cpp +++ b/MPD/AbstractRepresentationStream.cpp @@ -46,7 +46,8 @@ uint32_t AbstractRepresentationStream::getFirstSegmentNumber() uint32_t availStT = TimeResolver::getUTCDateTimeInSec(this->mpd->GetAvailabilityStarttime()); uint32_t duration = this->getAverageSegmentDuration(); uint32_t timeshift = TimeResolver::getDurationInSec(this->mpd->GetTimeShiftBufferDepth()); - return (currTime - duration - availStT - timeshift ) / duration; + uint32_t timescale = this->getTimescale(); + return (double)((double)currTime - (double)availStT - (double)timeshift ) < 0? 0 : (currTime - availStT - timeshift ); } return 0; } @@ -59,7 +60,8 @@ uint32_t AbstractRepresentationStream::getCurrentSegmentNumber() uint32_t duration = this->getAverageSegmentDuration(); uint32_t availStT = TimeResolver::getUTCDateTimeInSec(this->mpd->GetAvailabilityStarttime()); - return (currTime - duration - availStT) / duration; + return (double)((double)currTime - (double)availStT) < 0 ? 0 : (currTime - availStT); + // return (currTime - duration - availStT) / duration; } return 0; } @@ -82,3 +84,11 @@ uint32_t AbstractRepresentationStream::getAverageSegmentDuration() { return 1; } +uint32_t AbstractRepresentationStream::getTimescale () +{ + return 1; +} +void AbstractRepresentationStream::setSegmentOffset (uint32_t offset) +{ + this->segmentOffset = offset; +} |