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 class Reader; | |
17 | |
18 typedef std::shared_ptr<Reader> ReaderPtr; | |
19 | |
20 // 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. |
21 // This model is synchronous, because that's how ffmpeg works. | 17 // This model is synchronous, because that's how ffmpeg works. |
22 class Reader { | 18 class Reader { |
23 public: | 19 public: |
24 // Creates a Reader object for a given url. | 20 // Creates a Reader object for a given url. |
25 static Result Create(const GURL& gurl, ReaderPtr* reader_out); | 21 static Result Create(const GURL& gurl, std::shared_ptr<Reader>* reader_out); |
26 | 22 |
27 virtual ~Reader() {} | 23 virtual ~Reader() {} |
28 | 24 |
29 // Initializes the reader. | 25 // Initializes the reader. |
30 virtual Result Init(const GURL& gurl) = 0; | 26 virtual Result Init(const GURL& gurl) = 0; |
31 | 27 |
32 // 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 |
33 // bytes read. Returns -1 if the operation fails. | 29 // bytes read. Returns -1 if the operation fails. |
34 virtual size_t Read(uint8* buffer, int bytes_to_read) = 0; | 30 virtual size_t Read(uint8* buffer, int bytes_to_read) = 0; |
35 | 31 |
36 // Gets the current position or -1 if the operation fails. | 32 // Gets the current position or -1 if the operation fails. |
37 virtual int64_t GetPosition() const = 0; | 33 virtual int64_t GetPosition() const = 0; |
38 | 34 |
39 // 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 |
40 // fails. | 36 // fails. |
41 virtual int64_t SetPosition(int64 position) = 0; | 37 virtual int64_t SetPosition(int64 position) = 0; |
42 | 38 |
43 // 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 |
44 // known. | 40 // known. |
45 virtual size_t GetSize() const = 0; | 41 virtual size_t GetSize() const = 0; |
46 | 42 |
47 // Returns true if this object supports seeking, false otherwise. | 43 // Returns true if this object supports seeking, false otherwise. |
48 virtual bool CanSeek() const = 0; | 44 virtual bool CanSeek() const = 0; |
49 }; | 45 }; |
50 | 46 |
51 } // namespace media | 47 } // namespace media |
52 } // namespace mojo | 48 } // namespace mojo |
53 | 49 |
54 #endif // MOJO_SERVICES_MEDIA_READER_H_ | 50 #endif // MOJO_SERVICES_MEDIA_READER_H_ |
OLD | NEW |