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 "media/base/media_log.h" | 5 #include "media/base/media_log.h" |
6 | 6 |
7 #include "base/atomic_sequence_num.h" | 7 #include "base/atomic_sequence_num.h" |
8 #include "base/logging.h" | 8 #include "base/logging.h" |
9 #include "base/scoped_ptr.h" | 9 #include "base/scoped_ptr.h" |
10 | 10 |
11 namespace media { | 11 namespace media { |
12 | 12 |
13 // A count of all MediaLogs created on this render process. | 13 // A count of all MediaLogs created on this render process. |
14 // Used to generate unique ids. | 14 // Used to generate unique ids. |
15 static base::AtomicSequenceNumber media_log_count(base::LINKER_INITIALIZED); | 15 static base::AtomicSequenceNumber media_log_count(base::LINKER_INITIALIZED); |
16 | 16 |
17 const char* MediaLog::EventTypeToString(MediaLogEvent::Type type) { | 17 const char* MediaLog::EventTypeToString(MediaLogEvent::Type type) { |
18 switch (type) { | 18 switch (type) { |
19 case MediaLogEvent::CREATING: | 19 case MediaLogEvent::CREATING: |
20 return "CREATING"; | 20 return "CREATING"; |
21 case MediaLogEvent::DESTROYING: | 21 case MediaLogEvent::DESTROYING: |
22 return "DESTROYING"; | 22 return "DESTROYING"; |
23 case MediaLogEvent::LOAD: | 23 case MediaLogEvent::LOAD: |
24 return "LOAD"; | 24 return "LOAD"; |
25 case MediaLogEvent::PLAY: | 25 case MediaLogEvent::PLAY: |
26 return "PLAY"; | 26 return "PLAY"; |
27 case MediaLogEvent::PAUSE: | 27 case MediaLogEvent::PAUSE: |
28 return "PAUSE"; | 28 return "PAUSE"; |
| 29 case MediaLogEvent::BUFFERED_EXTENTS_CHANGED: |
| 30 return "BUFFERED_EXTENTS_CHANGED"; |
29 } | 31 } |
30 NOTREACHED(); | 32 NOTREACHED(); |
31 return NULL; | 33 return NULL; |
32 } | 34 } |
33 | 35 |
34 MediaLog::MediaLog() { | 36 MediaLog::MediaLog() { |
35 id_ = media_log_count.GetNext(); | 37 id_ = media_log_count.GetNext(); |
36 } | 38 } |
37 | 39 |
38 MediaLog::~MediaLog() {} | 40 MediaLog::~MediaLog() {} |
39 | 41 |
40 void MediaLog::Load(const std::string& url) { | |
41 MediaLogEvent* event = CreateEvent(MediaLogEvent::LOAD); | |
42 event->params.SetString("url", url); | |
43 AddEvent(event); | |
44 } | |
45 | |
46 void MediaLog::AddEventOfType(MediaLogEvent::Type type) { | |
47 MediaLogEvent* event = CreateEvent(type); | |
48 AddEvent(event); | |
49 } | |
50 | |
51 MediaLogEvent* MediaLog::CreateEvent(MediaLogEvent::Type type) { | |
52 MediaLogEvent* event = new MediaLogEvent; | |
53 event->id = id_; | |
54 event->type = type; | |
55 event->time = base::Time::Now(); | |
56 return event; | |
57 } | |
58 | |
59 void MediaLog::AddEvent(MediaLogEvent* event) { | 42 void MediaLog::AddEvent(MediaLogEvent* event) { |
60 scoped_ptr<MediaLogEvent> e(event); | 43 scoped_ptr<MediaLogEvent> e(event); |
61 } | 44 } |
62 | 45 |
| 46 MediaLogEvent* MediaLog::CreateEvent(MediaLogEvent::Type type) { |
| 47 scoped_ptr<MediaLogEvent> event(new MediaLogEvent); |
| 48 event->id = id_; |
| 49 event->type = type; |
| 50 event->time = base::Time::Now(); |
| 51 return event.release(); |
| 52 } |
| 53 |
| 54 MediaLogEvent* MediaLog::CreateLoadEvent(const std::string& url) { |
| 55 scoped_ptr<MediaLogEvent> event(CreateEvent(MediaLogEvent::LOAD)); |
| 56 event->params.SetString("url", url); |
| 57 return event.release(); |
| 58 } |
| 59 |
| 60 MediaLogEvent* MediaLog::CreateBufferedExtentsChangedEvent( |
| 61 size_t start, size_t current, size_t end) { |
| 62 scoped_ptr<MediaLogEvent> event( |
| 63 CreateEvent(MediaLogEvent::BUFFERED_EXTENTS_CHANGED)); |
| 64 event->params.SetInteger("buffer_start", start); |
| 65 event->params.SetInteger("buffer_current", current); |
| 66 event->params.SetInteger("buffer_end", end); |
| 67 return event.release(); |
| 68 } |
| 69 |
63 } //namespace media | 70 } //namespace media |
OLD | NEW |