cygprofile: increase timeouts to allow showing web contents
[chromium-blink-merge.git] / media / blink / websourcebuffer_impl.cc
blob03a824b8680b2043b4157fb84f00bc4abdad1e46
1 // Copyright 2013 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
5 #include "media/blink/websourcebuffer_impl.h"
7 #include <cmath>
8 #include <limits>
10 #include "base/bind.h"
11 #include "base/callback.h"
12 #include "base/callback_helpers.h"
13 #include "media/base/timestamp_constants.h"
14 #include "media/filters/chunk_demuxer.h"
15 #include "third_party/WebKit/public/platform/WebSourceBufferClient.h"
17 namespace media {
19 static base::TimeDelta DoubleToTimeDelta(double time) {
20 DCHECK(!std::isnan(time));
21 DCHECK_NE(time, -std::numeric_limits<double>::infinity());
23 if (time == std::numeric_limits<double>::infinity())
24 return kInfiniteDuration();
26 // Don't use base::TimeDelta::Max() here, as we want the largest finite time
27 // delta.
28 base::TimeDelta max_time = base::TimeDelta::FromInternalValue(kint64max - 1);
29 double max_time_in_seconds = max_time.InSecondsF();
31 if (time >= max_time_in_seconds)
32 return max_time;
34 return base::TimeDelta::FromMicroseconds(
35 time * base::Time::kMicrosecondsPerSecond);
38 WebSourceBufferImpl::WebSourceBufferImpl(
39 const std::string& id, ChunkDemuxer* demuxer)
40 : id_(id),
41 demuxer_(demuxer),
42 client_(NULL),
43 append_window_end_(kInfiniteDuration()) {
44 DCHECK(demuxer_);
47 WebSourceBufferImpl::~WebSourceBufferImpl() {
48 DCHECK(!demuxer_) << "Object destroyed w/o removedFromMediaSource() call";
49 DCHECK(!client_);
52 void WebSourceBufferImpl::setClient(blink::WebSourceBufferClient* client) {
53 DCHECK(client);
54 DCHECK(!client_);
55 client_ = client;
58 bool WebSourceBufferImpl::setMode(WebSourceBuffer::AppendMode mode) {
59 if (demuxer_->IsParsingMediaSegment(id_))
60 return false;
62 switch (mode) {
63 case WebSourceBuffer::AppendModeSegments:
64 demuxer_->SetSequenceMode(id_, false);
65 return true;
66 case WebSourceBuffer::AppendModeSequence:
67 demuxer_->SetSequenceMode(id_, true);
68 return true;
71 NOTREACHED();
72 return false;
75 blink::WebTimeRanges WebSourceBufferImpl::buffered() {
76 Ranges<base::TimeDelta> ranges = demuxer_->GetBufferedRanges(id_);
77 blink::WebTimeRanges result(ranges.size());
78 for (size_t i = 0; i < ranges.size(); i++) {
79 result[i].start = ranges.start(i).InSecondsF();
80 result[i].end = ranges.end(i).InSecondsF();
82 return result;
85 bool WebSourceBufferImpl::evictCodedFrames(double currentPlaybackTime,
86 size_t newDataSize) {
87 return demuxer_->EvictCodedFrames(
88 id_,
89 base::TimeDelta::FromSecondsD(currentPlaybackTime),
90 newDataSize);
93 void WebSourceBufferImpl::append(
94 const unsigned char* data,
95 unsigned length,
96 double* timestamp_offset) {
97 base::TimeDelta old_offset = timestamp_offset_;
98 demuxer_->AppendData(id_, data, length,
99 append_window_start_, append_window_end_,
100 &timestamp_offset_,
101 base::Bind(&WebSourceBufferImpl::InitSegmentReceived,
102 base::Unretained(this)));
104 // Coded frame processing may update the timestamp offset. If the caller
105 // provides a non-NULL |timestamp_offset| and frame processing changes the
106 // timestamp offset, report the new offset to the caller. Do not update the
107 // caller's offset otherwise, to preserve any pre-existing value that may have
108 // more than microsecond precision.
109 if (timestamp_offset && old_offset != timestamp_offset_)
110 *timestamp_offset = timestamp_offset_.InSecondsF();
113 void WebSourceBufferImpl::abort() {
114 demuxer_->Abort(id_,
115 append_window_start_, append_window_end_,
116 &timestamp_offset_);
118 // TODO(wolenetz): abort should be able to modify the caller timestamp offset
119 // (just like WebSourceBufferImpl::append).
120 // See http://crbug.com/370229 for further details.
123 void WebSourceBufferImpl::remove(double start, double end) {
124 DCHECK_GE(start, 0);
125 DCHECK_GE(end, 0);
126 demuxer_->Remove(id_, DoubleToTimeDelta(start), DoubleToTimeDelta(end));
129 bool WebSourceBufferImpl::setTimestampOffset(double offset) {
130 if (demuxer_->IsParsingMediaSegment(id_))
131 return false;
133 timestamp_offset_ = DoubleToTimeDelta(offset);
135 // http://www.w3.org/TR/media-source/#widl-SourceBuffer-timestampOffset
136 // Step 6: If the mode attribute equals "sequence", then set the group start
137 // timestamp to new timestamp offset.
138 demuxer_->SetGroupStartTimestampIfInSequenceMode(id_, timestamp_offset_);
139 return true;
142 void WebSourceBufferImpl::setAppendWindowStart(double start) {
143 DCHECK_GE(start, 0);
144 append_window_start_ = DoubleToTimeDelta(start);
147 void WebSourceBufferImpl::setAppendWindowEnd(double end) {
148 DCHECK_GE(end, 0);
149 append_window_end_ = DoubleToTimeDelta(end);
152 void WebSourceBufferImpl::removedFromMediaSource() {
153 demuxer_->RemoveId(id_);
154 demuxer_ = NULL;
155 client_ = NULL;
158 void WebSourceBufferImpl::InitSegmentReceived() {
159 DVLOG(1) << __FUNCTION__;
160 client_->initializationSegmentReceived();
163 } // namespace media