Chromium Code Reviews

Side by Side Diff: third_party/WebKit/public/platform/WebSourceBuffer.h

Issue 2076673005: MSE: Plumb ChunkDemuxer appendData failures into append Error algorithm (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Fixed the layout test Created 4 years, 6 months ago
Use n/p to move between diff chunks; N/P to move between comments.
Jump to:
View unified diff |
OLDNEW
1 /* 1 /*
2 * Copyright (C) 2013 Google Inc. All rights reserved. 2 * Copyright (C) 2013 Google Inc. All rights reserved.
3 * 3 *
4 * Redistribution and use in source and binary forms, with or without 4 * Redistribution and use in source and binary forms, with or without
5 * modification, are permitted provided that the following conditions are 5 * modification, are permitted provided that the following conditions are
6 * met: 6 * met:
7 * 7 *
8 * * Redistributions of source code must retain the above copyright 8 * * Redistributions of source code must retain the above copyright
9 * notice, this list of conditions and the following disclaimer. 9 * notice, this list of conditions and the following disclaimer.
10 * * Redistributions in binary form must reproduce the above 10 * * Redistributions in binary form must reproduce the above
(...skipping 19 matching lines...)
30 30
31 #ifndef WebSourceBuffer_h 31 #ifndef WebSourceBuffer_h
32 #define WebSourceBuffer_h 32 #define WebSourceBuffer_h
33 33
34 #include "WebTimeRange.h" 34 #include "WebTimeRange.h"
35 35
36 namespace blink { 36 namespace blink {
37 37
38 class WebSourceBufferClient; 38 class WebSourceBufferClient;
39 39
40 class WebSourceBuffer { 40 class WebSourceBuffer {
dcheng 2016/06/18 06:20:06 This is obviously a preexisting class, but do you
wolenetz 2016/06/21 19:38:09 Done - and I added a small comment to the top of W
41 public: 41 public:
42 enum AppendMode { 42 enum AppendMode {
43 AppendModeSegments, 43 AppendModeSegments,
44 AppendModeSequence 44 AppendModeSequence
45 }; 45 };
46 46
47 virtual ~WebSourceBuffer() { } 47 virtual ~WebSourceBuffer() { }
48 48
49 // This will only be called once and only with a non-null pointer to a 49 // This will only be called once and only with a non-null pointer to a
50 // client whose ownership is not transferred to this WebSourceBuffer. 50 // client whose ownership is not transferred to this WebSourceBuffer.
51 virtual void setClient(WebSourceBufferClient*) = 0; 51 virtual void setClient(WebSourceBufferClient*) = 0;
52 52
53 virtual bool setMode(AppendMode) = 0; 53 virtual bool setMode(AppendMode) = 0;
54 virtual WebTimeRanges buffered() = 0; 54 virtual WebTimeRanges buffered() = 0;
55 55
56 // Run coded frame eviction/garbage collection algorithm. 56 // Run coded frame eviction/garbage collection algorithm.
57 // |currentPlaybackTime| is HTMLMediaElement::currentTime. The algorithm 57 // |currentPlaybackTime| is HTMLMediaElement::currentTime. The algorithm
58 // will try to preserve data around current playback position. 58 // will try to preserve data around current playback position.
59 // |newDataSize| is size of new data about to be appended to SourceBuffer. 59 // |newDataSize| is size of new data about to be appended to SourceBuffer.
60 // Could be zero for appendStream if stream size is unknown in advance. 60 // Could be zero for appendStream if stream size is unknown in advance.
61 // Returns false if buffer is still full after eviction. 61 // Returns false if buffer is still full after eviction.
62 virtual bool evictCodedFrames(double currentPlaybackTime, size_t newDataSize ) = 0; 62 virtual bool evictCodedFrames(double currentPlaybackTime, size_t newDataSize ) = 0;
63 63
64 // Appends data and runs the segment parser loop algorithm. 64 // Appends data and runs the segment parser loop algorithm.
65 // The algorithm may update |*timestampOffset| if |timestampOffset| is not n ull. 65 // The algorithm may update |*timestampOffset| if |timestampOffset| is not n ull.
66 virtual void append(const unsigned char* data, unsigned length, double* time stampOffset) = 0; 66 // Returns true on success, otherwise the append error algorithm needs to
67 // run with the decode error parameter set to true.
68 virtual bool append(const unsigned char* data, unsigned length, double* time stampOffset) = 0;
67 69
68 virtual void resetParserState() = 0; 70 virtual void resetParserState() = 0;
69 virtual void remove(double start, double end) = 0; 71 virtual void remove(double start, double end) = 0;
70 virtual bool setTimestampOffset(double) = 0; 72 virtual bool setTimestampOffset(double) = 0;
71 73
72 // Set presentation timestamp for the start of append window. 74 // Set presentation timestamp for the start of append window.
73 virtual void setAppendWindowStart(double) = 0; 75 virtual void setAppendWindowStart(double) = 0;
74 76
75 // Set presentation timestamp for the end of append window. 77 // Set presentation timestamp for the end of append window.
76 virtual void setAppendWindowEnd(double) = 0; 78 virtual void setAppendWindowEnd(double) = 0;
77 79
78 // After this method is called, this WebSourceBuffer should never use the 80 // After this method is called, this WebSourceBuffer should never use the
79 // client pointer passed to setClient(). 81 // client pointer passed to setClient().
80 virtual void removedFromMediaSource() = 0; 82 virtual void removedFromMediaSource() = 0;
81 }; 83 };
82 84
83 } // namespace blink 85 } // namespace blink
84 86
85 #endif 87 #endif
OLDNEW

Powered by Google App Engine