OLD | NEW |
1 // Copyright 2016 The Chromium Authors. All rights reserved. | 1 // Copyright 2016 The Chromium Authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #ifndef SERVICES_MEDIA_FRAMEWORK_PARTS_READER_H_ | 5 #ifndef SERVICES_MEDIA_FRAMEWORK_PARTS_READER_H_ |
6 #define SERVICES_MEDIA_FRAMEWORK_PARTS_READER_H_ | 6 #define SERVICES_MEDIA_FRAMEWORK_PARTS_READER_H_ |
7 | 7 |
8 #include <memory> | 8 #include <memory> |
9 | 9 |
10 #include "services/media/framework/result.h" | 10 #include "services/media/framework/result.h" |
11 #include "url/gurl.h" | 11 #include "url/gurl.h" |
12 | 12 |
13 namespace mojo { | 13 namespace mojo { |
14 namespace media { | 14 namespace media { |
15 | 15 |
16 // Abstract base class for objects that read raw data on behalf of demuxes. | 16 // Abstract base class for objects that read raw data on behalf of demuxes. |
17 // This model is synchronous, because that's how ffmpeg works. | 17 // This model is synchronous, because that's how ffmpeg works. |
18 class Reader { | 18 class Reader { |
19 public: | 19 public: |
20 // Creates a Reader object for a given url. | 20 // Creates a Reader object for a given url. |
21 static Result Create(const GURL& gurl, std::shared_ptr<Reader>* reader_out); | 21 static Result Create(const GURL& gurl, std::shared_ptr<Reader>* reader_out); |
22 | 22 |
23 virtual ~Reader() {} | 23 virtual ~Reader() {} |
24 | 24 |
25 // Initializes the reader. | 25 // Initializes the reader. |
26 virtual Result Init(const GURL& gurl) = 0; | 26 virtual Result Init(const GURL& gurl) = 0; |
27 | 27 |
28 // Reads the given number of bytes into the buffer and returns the number of | 28 // Reads the given number of bytes into the buffer and returns the number of |
29 // bytes read. Returns -1 if the operation fails. | 29 // bytes read. Returns -1 if the operation fails. |
30 virtual size_t Read(uint8* buffer, int bytes_to_read) = 0; | 30 virtual size_t Read(uint8_t* buffer, size_t bytes_to_read) = 0; |
31 | 31 |
32 // Gets the current position or -1 if the operation fails. | 32 // Gets the current position or -1 if the operation fails. |
33 virtual int64_t GetPosition() const = 0; | 33 virtual int64_t GetPosition() const = 0; |
34 | 34 |
35 // Seeks to the given position and returns it. Returns -1 if the operation | 35 // Seeks to the given position and returns it. Returns -1 if the operation |
36 // fails. | 36 // fails. |
37 virtual int64_t SetPosition(int64 position) = 0; | 37 virtual int64_t SetPosition(int64_t position) = 0; |
38 | 38 |
39 // Returns the file size. Returns -1 if the operation fails or the size isn't | 39 // Returns the file size. Returns -1 if the operation fails or the size isn't |
40 // known. | 40 // known. |
41 virtual size_t GetSize() const = 0; | 41 virtual size_t GetSize() const = 0; |
42 | 42 |
43 // Returns true if this object supports seeking, false otherwise. | 43 // Returns true if this object supports seeking, false otherwise. |
44 virtual bool CanSeek() const = 0; | 44 virtual bool CanSeek() const = 0; |
45 }; | 45 }; |
46 | 46 |
47 } // namespace media | 47 } // namespace media |
48 } // namespace mojo | 48 } // namespace mojo |
49 | 49 |
50 #endif // MOJO_SERVICES_MEDIA_READER_H_ | 50 #endif // MOJO_SERVICES_MEDIA_READER_H_ |
OLD | NEW |