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) { | 42 MediaLogEvent* MediaLog::CreateLoadEvent(const std::string& url) { |
41 MediaLogEvent* event = CreateEvent(MediaLogEvent::LOAD); | 43 scoped_ptr<MediaLogEvent> event(CreateEvent(MediaLogEvent::LOAD)); |
42 event->params.SetString("url", url); | 44 event->params.SetString("url", url); |
43 AddEvent(event); | 45 return event.release(); |
44 } | 46 } |
45 | 47 |
46 void MediaLog::AddEventOfType(MediaLogEvent::Type type) { | 48 MediaLogEvent* MediaLog::CreateBufferedExtentsChangedEvent( |
47 MediaLogEvent* event = CreateEvent(type); | 49 size_t start, size_t current, size_t end) { |
48 AddEvent(event); | 50 scoped_ptr<MediaLogEvent> event( |
| 51 CreateEvent(MediaLogEvent::BUFFERED_EXTENTS_CHANGED)); |
| 52 event->params.SetInteger("buffer_start", start); |
| 53 event->params.SetInteger("buffer_current", current); |
| 54 event->params.SetInteger("buffer_end", end); |
| 55 return event.release(); |
49 } | 56 } |
50 | 57 |
51 MediaLogEvent* MediaLog::CreateEvent(MediaLogEvent::Type type) { | 58 MediaLogEvent* MediaLog::CreateEvent(MediaLogEvent::Type type) { |
52 MediaLogEvent* event = new MediaLogEvent; | 59 scoped_ptr<MediaLogEvent> event(new MediaLogEvent); |
53 event->id = id_; | 60 event->id = id_; |
54 event->type = type; | 61 event->type = type; |
55 event->time = base::Time::Now(); | 62 event->time = base::Time::Now(); |
56 return event; | 63 return event.release(); |
57 } | 64 } |
58 | 65 |
59 void MediaLog::AddEvent(MediaLogEvent* event) { | 66 void MediaLog::AddEvent(MediaLogEvent* event) { |
60 scoped_ptr<MediaLogEvent> e(event); | 67 scoped_ptr<MediaLogEvent> e(event); |
61 } | 68 } |
62 | 69 |
63 } //namespace media | 70 } //namespace media |
OLD | NEW |