Re-subimission of https://codereview.chromium.org/1041213003/
[chromium-blink-merge.git] / media / base / media_log_event.h
blobdb687fbb176f57d9125277653175c0fb5c29d05e
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
3 // found in the LICENSE file.
5 #ifndef MEDIA_BASE_MEDIA_LOG_EVENT_H_
6 #define MEDIA_BASE_MEDIA_LOG_EVENT_H_
8 #include "base/time/time.h"
9 #include "base/values.h"
11 namespace media {
13 struct MediaLogEvent {
14 MediaLogEvent() {}
16 MediaLogEvent(const MediaLogEvent& event) {
17 *this = event;
20 MediaLogEvent& operator=(const MediaLogEvent& event) {
21 id = event.id;
22 type = event.type;
23 scoped_ptr<base::DictionaryValue> event_copy(event.params.DeepCopy());
24 params.Swap(event_copy.get());
25 time = event.time;
26 return *this;
29 enum Type {
30 // A WebMediaPlayer is being created or destroyed.
31 // params: none.
32 WEBMEDIAPLAYER_CREATED,
33 WEBMEDIAPLAYER_DESTROYED,
35 // A Pipeline is being created or destroyed.
36 // params: none.
37 PIPELINE_CREATED,
38 PIPELINE_DESTROYED,
40 // A media player is loading a resource.
41 // params: "url": <URL of the resource>.
42 LOAD,
44 // A media player has started seeking.
45 // params: "seek_target": <number of seconds to which to seek>.
46 SEEK,
48 // A media player has been told to play or pause.
49 // params: none.
50 PLAY,
51 PAUSE,
53 // The state of Pipeline has changed.
54 // params: "pipeline_state": <string name of the state>.
55 PIPELINE_STATE_CHANGED,
57 // An error has occurred in the pipeline.
58 // params: "pipeline_error": <string name of the error>.
59 PIPELINE_ERROR,
61 // The size of the video has been determined.
62 // params: "width": <integral width of the video>.
63 // "height": <integral height of the video>.
64 VIDEO_SIZE_SET,
66 // A property of the pipeline has been set by a filter.
67 // These take a single parameter based upon the name of the event and of
68 // the appropriate type. e.g. DURATION_SET: "duration" of type TimeDelta.
69 DURATION_SET,
70 TOTAL_BYTES_SET,
71 NETWORK_ACTIVITY_SET,
73 // Audio/Video stream playback has ended.
74 ENDED,
76 // Text stream playback has ended.
77 TEXT_ENDED,
79 // The extents of the sliding buffer have changed.
80 // params: "buffer_start": <first buffered byte>.
81 // "buffer_current": <current offset>.
82 // "buffer_end": <last buffered byte>.
83 BUFFERED_EXTENTS_CHANGED,
85 // Error log reported by media code such as details of an MSE parse error.
86 MEDIA_ERROR_LOG_ENTRY,
87 // params: "error": Error string describing the error detected.
89 // Informative log reported by media code.
90 MEDIA_INFO_LOG_ENTRY,
91 // params: "info": String with details of an informative log entry.
93 // Debug log reported by media code.
94 MEDIA_DEBUG_LOG_ENTRY,
95 // params: "debug": String with details of a debug log entry.
97 // A property has changed without any special event occurring.
98 PROPERTY_CHANGE,
100 TYPE_LAST = PROPERTY_CHANGE
103 int32 id;
104 Type type;
105 base::DictionaryValue params;
106 base::TimeTicks time;
109 } // namespace media
111 #endif // MEDIA_BASE_MEDIA_LOG_EVENT_H_