OLD | NEW |
1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2011 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 #include "base/message_loop.h" | 5 #include "base/message_loop.h" |
6 #include "media/filters/ffmpeg_demuxer.h" | 6 #include "media/filters/ffmpeg_demuxer.h" |
7 #include "media/filters/ffmpeg_demuxer_factory.h" | 7 #include "media/filters/ffmpeg_demuxer_factory.h" |
8 | 8 |
9 namespace media { | 9 namespace media { |
10 | 10 |
(...skipping 13 matching lines...) Expand all Loading... |
24 public: | 24 public: |
25 DemuxerCallbackAsPipelineStatusCallback( | 25 DemuxerCallbackAsPipelineStatusCallback( |
26 DemuxerFactory::BuildCallback* cb, | 26 DemuxerFactory::BuildCallback* cb, |
27 Demuxer* demuxer) | 27 Demuxer* demuxer) |
28 : cb_(cb), demuxer_(demuxer) { | 28 : cb_(cb), demuxer_(demuxer) { |
29 DCHECK(cb_.get() && demuxer_); | 29 DCHECK(cb_.get() && demuxer_); |
30 } | 30 } |
31 | 31 |
32 virtual ~DemuxerCallbackAsPipelineStatusCallback() {} | 32 virtual ~DemuxerCallbackAsPipelineStatusCallback() {} |
33 | 33 |
34 virtual void RunWithParams(const Tuple1<PipelineError>& params) { | 34 virtual void RunWithParams(const Tuple1<PipelineStatus>& params) { |
35 cb_->Run(params.a, demuxer_); | 35 cb_->Run(params.a, demuxer_); |
36 } | 36 } |
37 | 37 |
38 private: | 38 private: |
39 scoped_ptr<DemuxerFactory::BuildCallback> cb_; | 39 scoped_ptr<DemuxerFactory::BuildCallback> cb_; |
40 scoped_refptr<Demuxer> demuxer_; | 40 scoped_refptr<Demuxer> demuxer_; |
41 | 41 |
42 DISALLOW_IMPLICIT_CONSTRUCTORS(DemuxerCallbackAsPipelineStatusCallback); | 42 DISALLOW_IMPLICIT_CONSTRUCTORS(DemuxerCallbackAsPipelineStatusCallback); |
43 }; | 43 }; |
44 | 44 |
45 // See comments on DemuxerCallbackAsPipelineStatusCallback above. | 45 // See comments on DemuxerCallbackAsPipelineStatusCallback above. |
46 class DemuxerCallbackAsDataSourceCallback : | 46 class DemuxerCallbackAsDataSourceCallback : |
47 public DataSourceFactory::BuildCallback { | 47 public DataSourceFactory::BuildCallback { |
48 public: | 48 public: |
49 DemuxerCallbackAsDataSourceCallback(DemuxerFactory::BuildCallback* cb, | 49 DemuxerCallbackAsDataSourceCallback(DemuxerFactory::BuildCallback* cb, |
50 MessageLoop* loop) | 50 MessageLoop* loop) |
51 : cb_(cb), loop_(loop) { | 51 : cb_(cb), loop_(loop) { |
52 DCHECK(cb_.get() && loop_); | 52 DCHECK(cb_.get() && loop_); |
53 } | 53 } |
54 | 54 |
55 virtual ~DemuxerCallbackAsDataSourceCallback() {} | 55 virtual ~DemuxerCallbackAsDataSourceCallback() {} |
56 | 56 |
57 virtual void RunWithParams(const Tuple2<PipelineError, DataSource*>& params) { | 57 virtual void RunWithParams( |
58 PipelineError status = params.a; | 58 const Tuple2<PipelineStatus, DataSource*>& params) { |
| 59 PipelineStatus status = params.a; |
59 DataSource* data_source = params.b; | 60 DataSource* data_source = params.b; |
60 if (status != PIPELINE_OK) { | 61 if (status != PIPELINE_OK) { |
61 cb_->Run(status, static_cast<Demuxer*>(NULL)); | 62 cb_->Run(status, static_cast<Demuxer*>(NULL)); |
62 return; | 63 return; |
63 } | 64 } |
64 DCHECK(data_source); | 65 DCHECK(data_source); |
65 scoped_refptr<FFmpegDemuxer> demuxer = new FFmpegDemuxer(loop_); | 66 scoped_refptr<FFmpegDemuxer> demuxer = new FFmpegDemuxer(loop_); |
66 demuxer->Initialize( | 67 demuxer->Initialize( |
67 data_source, | 68 data_source, |
68 new DemuxerCallbackAsPipelineStatusCallback(cb_.release(), demuxer)); | 69 new DemuxerCallbackAsPipelineStatusCallback(cb_.release(), demuxer)); |
69 } | 70 } |
70 | 71 |
71 private: | 72 private: |
72 scoped_ptr<DemuxerFactory::BuildCallback> cb_; | 73 scoped_ptr<DemuxerFactory::BuildCallback> cb_; |
73 MessageLoop* loop_; | 74 MessageLoop* loop_; |
74 | 75 |
75 DISALLOW_IMPLICIT_CONSTRUCTORS(DemuxerCallbackAsDataSourceCallback); | 76 DISALLOW_IMPLICIT_CONSTRUCTORS(DemuxerCallbackAsDataSourceCallback); |
76 }; | 77 }; |
77 | 78 |
78 void FFmpegDemuxerFactory::Build(const std::string& url, BuildCallback* cb) { | 79 void FFmpegDemuxerFactory::Build(const std::string& url, BuildCallback* cb) { |
79 data_source_factory_->Build( | 80 data_source_factory_->Build( |
80 url, new DemuxerCallbackAsDataSourceCallback(cb, loop_)); | 81 url, new DemuxerCallbackAsDataSourceCallback(cb, loop_)); |
81 } | 82 } |
82 | 83 |
83 DemuxerFactory* FFmpegDemuxerFactory::Clone() const { | 84 DemuxerFactory* FFmpegDemuxerFactory::Clone() const { |
84 return new FFmpegDemuxerFactory(data_source_factory_->Clone(), loop_); | 85 return new FFmpegDemuxerFactory(data_source_factory_->Clone(), loop_); |
85 } | 86 } |
86 | 87 |
87 } // namespace media | 88 } // namespace media |
OLD | NEW |