| OLD | NEW |
| 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 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 // This standalone binary is a helper for diagnosing seek behavior of the | 5 // This standalone binary is a helper for diagnosing seek behavior of the |
| 6 // demuxer setup in media/ code. It answers the question: "if I ask the demuxer | 6 // demuxer setup in media/ code. It answers the question: "if I ask the demuxer |
| 7 // to Seek to X ms, where will it actually seek to? (necessitating | 7 // to Seek to X ms, where will it actually seek to? (necessitating |
| 8 // frame-dropping until the original seek target is reached)". Sample run: | 8 // frame-dropping until the original seek target is reached)". Sample run: |
| 9 // | 9 // |
| 10 // $ ./out/Debug/seek_tester .../LayoutTests/media/content/test.ogv 6300 | 10 // $ ./out/Debug/seek_tester .../LayoutTests/media/content/test.ogv 6300 |
| (...skipping 23 matching lines...) Expand all Loading... |
| 34 virtual void OnDemuxerError(media::PipelineStatus error) OVERRIDE {} | 34 virtual void OnDemuxerError(media::PipelineStatus error) OVERRIDE {} |
| 35 }; | 35 }; |
| 36 | 36 |
| 37 void QuitMessageLoop(MessageLoop* loop, media::PipelineStatus status) { | 37 void QuitMessageLoop(MessageLoop* loop, media::PipelineStatus status) { |
| 38 CHECK_EQ(status, media::PIPELINE_OK); | 38 CHECK_EQ(status, media::PIPELINE_OK); |
| 39 loop->PostTask(FROM_HERE, MessageLoop::QuitClosure()); | 39 loop->PostTask(FROM_HERE, MessageLoop::QuitClosure()); |
| 40 } | 40 } |
| 41 | 41 |
| 42 void TimestampExtractor(uint64* timestamp_ms, | 42 void TimestampExtractor(uint64* timestamp_ms, |
| 43 MessageLoop* loop, | 43 MessageLoop* loop, |
| 44 const scoped_refptr<media::Buffer>& buffer) { | 44 const scoped_refptr<media::DecoderBuffer>& buffer) { |
| 45 if (buffer->GetTimestamp() == media::kNoTimestamp()) | 45 if (buffer->GetTimestamp() == media::kNoTimestamp()) |
| 46 *timestamp_ms = -1; | 46 *timestamp_ms = -1; |
| 47 else | 47 else |
| 48 *timestamp_ms = buffer->GetTimestamp().InMillisecondsF(); | 48 *timestamp_ms = buffer->GetTimestamp().InMillisecondsF(); |
| 49 loop->PostTask(FROM_HERE, MessageLoop::QuitClosure()); | 49 loop->PostTask(FROM_HERE, MessageLoop::QuitClosure()); |
| 50 } | 50 } |
| 51 | 51 |
| 52 int main(int argc, char** argv) { | 52 int main(int argc, char** argv) { |
| 53 base::AtExitManager at_exit; | 53 base::AtExitManager at_exit; |
| 54 media::InitializeMediaLibraryForTesting(); | 54 media::InitializeMediaLibraryForTesting(); |
| (...skipping 34 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 89 base::Bind(&TimestampExtractor, &video_seeked_to_ms, &loop)); | 89 base::Bind(&TimestampExtractor, &video_seeked_to_ms, &loop)); |
| 90 loop.Run(); | 90 loop.Run(); |
| 91 LOG(INFO) << " video seeked to: " << video_seeked_to_ms << "ms"; | 91 LOG(INFO) << " video seeked to: " << video_seeked_to_ms << "ms"; |
| 92 } | 92 } |
| 93 | 93 |
| 94 demuxer->Stop(base::Bind(&MessageLoop::Quit, base::Unretained(&loop))); | 94 demuxer->Stop(base::Bind(&MessageLoop::Quit, base::Unretained(&loop))); |
| 95 loop.Run(); | 95 loop.Run(); |
| 96 | 96 |
| 97 return 0; | 97 return 0; |
| 98 } | 98 } |
| OLD | NEW |