Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(539)

Side by Side Diff: media/base/cdm_promise.cc

Issue 567123002: Cleanup template in CdmPromise (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: ReportResultToUMA Created 6 years, 3 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
« media/base/cdm_promise.h ('K') | « media/base/cdm_promise.h ('k') | no next file » | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright 2014 The Chromium Authors. All rights reserved. 1 // Copyright 2014 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/cdm_promise.h" 5 #include "media/base/cdm_promise.h"
6 6
7 #include "base/bind.h" 7 #include "base/bind.h"
8 #include "base/logging.h" 8 #include "base/logging.h"
9 #include "base/metrics/histogram.h" 9 #include "base/metrics/histogram.h"
10 10
11 namespace media { 11 namespace media {
12 12
13 CdmPromise::CdmPromise() : is_pending_(true) { 13 template <typename T>
14 struct CdmPromiseTraits {};
15
16 template <>
17 struct CdmPromiseTraits<void> {
18 static const CdmPromise::ResolveParameterType kType = CdmPromise::VOID_TYPE;
19 };
20
21 template <>
22 struct CdmPromiseTraits<std::string> {
23 static const CdmPromise::ResolveParameterType kType = CdmPromise::STRING_TYPE;
24 };
25
26 template <>
27 struct CdmPromiseTraits<KeyIdsVector> {
28 static const CdmPromise::ResolveParameterType kType =
29 CdmPromise::KEY_IDS_VECTOR_TYPE;
30 };
31
32 CdmPromise::CdmPromise(ResolveParameterType parameter_type)
33 : parameter_type_(parameter_type), is_pending_(true) {
14 } 34 }
15 35
16 CdmPromise::CdmPromise(PromiseRejectedCB reject_cb) 36 CdmPromise::CdmPromise(ResolveParameterType parameter_type,
17 : reject_cb_(reject_cb), is_pending_(true) { 37 PromiseRejectedCB reject_cb)
38 : parameter_type_(parameter_type),
39 reject_cb_(reject_cb),
40 is_pending_(true) {
18 DCHECK(!reject_cb_.is_null()); 41 DCHECK(!reject_cb_.is_null());
19 } 42 }
20 43
21 CdmPromise::CdmPromise(PromiseRejectedCB reject_cb, const std::string& uma_name) 44 CdmPromise::CdmPromise(ResolveParameterType parameter_type,
22 : reject_cb_(reject_cb), is_pending_(true), uma_name_(uma_name) { 45 PromiseRejectedCB reject_cb,
46 const std::string& uma_name)
47 : parameter_type_(parameter_type),
48 reject_cb_(reject_cb),
49 is_pending_(true),
50 uma_name_(uma_name) {
23 DCHECK(!reject_cb_.is_null()); 51 DCHECK(!reject_cb_.is_null());
52 DCHECK(!uma_name_.empty());
24 } 53 }
25 54
26 CdmPromise::~CdmPromise() { 55 CdmPromise::~CdmPromise() {
27 DCHECK(!is_pending_); 56 DCHECK(!is_pending_);
28 } 57 }
29 58
30 static CdmPromise::ResultCodeForUMA ConvertExceptionToUMAResult( 59 static CdmPromise::ResultCodeForUMA ConvertExceptionToUMAResult(
31 MediaKeys::Exception exception_code) { 60 MediaKeys::Exception exception_code) {
32 switch (exception_code) { 61 switch (exception_code) {
33 case MediaKeys::NOT_SUPPORTED_ERROR: 62 case MediaKeys::NOT_SUPPORTED_ERROR:
(...skipping 11 matching lines...) Expand all
45 case MediaKeys::OUTPUT_ERROR: 74 case MediaKeys::OUTPUT_ERROR:
46 return CdmPromise::OUTPUT_ERROR; 75 return CdmPromise::OUTPUT_ERROR;
47 } 76 }
48 NOTREACHED(); 77 NOTREACHED();
49 return CdmPromise::UNKNOWN_ERROR; 78 return CdmPromise::UNKNOWN_ERROR;
50 } 79 }
51 80
52 void CdmPromise::reject(MediaKeys::Exception exception_code, 81 void CdmPromise::reject(MediaKeys::Exception exception_code,
53 uint32 system_code, 82 uint32 system_code,
54 const std::string& error_message) { 83 const std::string& error_message) {
84 ReportResultToUMA(ConvertExceptionToUMAResult(exception_code));
85 reject_cb_.Run(exception_code, system_code, error_message);
86 }
87
88 void CdmPromise::ReportResultToUMA(ResultCodeForUMA result) {
55 DCHECK(is_pending_); 89 DCHECK(is_pending_);
56 is_pending_ = false; 90 is_pending_ = false;
57 if (!uma_name_.empty()) { 91 if (!uma_name_.empty()) {
58 ResultCodeForUMA result_code = ConvertExceptionToUMAResult(exception_code);
59 base::LinearHistogram::FactoryGet( 92 base::LinearHistogram::FactoryGet(
60 uma_name_, 1, NUM_RESULT_CODES, NUM_RESULT_CODES + 1, 93 uma_name_,
61 base::HistogramBase::kUmaTargetedHistogramFlag)->Add(result_code); 94 1,
95 NUM_RESULT_CODES,
96 NUM_RESULT_CODES + 1,
97 base::HistogramBase::kUmaTargetedHistogramFlag)->Add(result);
62 } 98 }
63 reject_cb_.Run(exception_code, system_code, error_message); 99 }
100
101 template <typename T>
102 CdmPromiseTemplate<T>::CdmPromiseTemplate(
103 base::Callback<void(const T&)> resolve_cb,
104 PromiseRejectedCB reject_cb)
105 : CdmPromise(CdmPromiseTraits<T>::kType, reject_cb),
106 resolve_cb_(resolve_cb) {
107 DCHECK(!resolve_cb_.is_null());
108 }
109
110 template <typename T>
111 CdmPromiseTemplate<T>::CdmPromiseTemplate(
112 base::Callback<void(const T&)> resolve_cb,
113 PromiseRejectedCB reject_cb,
114 const std::string& uma_name)
115 : CdmPromise(CdmPromiseTraits<T>::kType, reject_cb, uma_name),
116 resolve_cb_(resolve_cb) {
117 DCHECK(!resolve_cb_.is_null());
118 }
119
120 template <typename T>
121 CdmPromiseTemplate<T>::CdmPromiseTemplate()
122 : CdmPromise(CdmPromiseTraits<T>::kType) {
123 }
124
125 template <typename T>
126 void CdmPromiseTemplate<T>::resolve(const T& result) {
127 ReportResultToUMA(SUCCESS);
128 resolve_cb_.Run(result);
64 } 129 }
65 130
66 CdmPromiseTemplate<void>::CdmPromiseTemplate(base::Callback<void()> resolve_cb, 131 CdmPromiseTemplate<void>::CdmPromiseTemplate(base::Callback<void()> resolve_cb,
67 PromiseRejectedCB reject_cb) 132 PromiseRejectedCB reject_cb)
68 : CdmPromise(reject_cb), resolve_cb_(resolve_cb) { 133 : CdmPromise(CdmPromiseTraits<void>::kType, reject_cb),
134 resolve_cb_(resolve_cb) {
69 DCHECK(!resolve_cb_.is_null()); 135 DCHECK(!resolve_cb_.is_null());
70 } 136 }
71 137
72 CdmPromiseTemplate<void>::CdmPromiseTemplate(base::Callback<void()> resolve_cb, 138 CdmPromiseTemplate<void>::CdmPromiseTemplate(base::Callback<void()> resolve_cb,
73 PromiseRejectedCB reject_cb, 139 PromiseRejectedCB reject_cb,
74 const std::string& uma_name) 140 const std::string& uma_name)
75 : CdmPromise(reject_cb, uma_name), resolve_cb_(resolve_cb) { 141 : CdmPromise(CdmPromiseTraits<void>::kType, reject_cb, uma_name),
142 resolve_cb_(resolve_cb) {
76 DCHECK(!resolve_cb_.is_null()); 143 DCHECK(!resolve_cb_.is_null());
77 DCHECK(!uma_name_.empty()); 144 DCHECK(!uma_name_.empty());
78 } 145 }
79 146
80 CdmPromiseTemplate<void>::CdmPromiseTemplate() { 147 CdmPromiseTemplate<void>::CdmPromiseTemplate()
81 } 148 : CdmPromise(CdmPromiseTraits<void>::kType) {
82
83 CdmPromiseTemplate<void>::~CdmPromiseTemplate() {
84 DCHECK(!is_pending_);
85 } 149 }
86 150
87 void CdmPromiseTemplate<void>::resolve() { 151 void CdmPromiseTemplate<void>::resolve() {
88 DCHECK(is_pending_); 152 ReportResultToUMA(SUCCESS);
89 is_pending_ = false;
90 if (!uma_name_.empty()) {
91 base::LinearHistogram::FactoryGet(
92 uma_name_, 1, NUM_RESULT_CODES, NUM_RESULT_CODES + 1,
93 base::HistogramBase::kUmaTargetedHistogramFlag)->Add(SUCCESS);
94 }
95 resolve_cb_.Run(); 153 resolve_cb_.Run();
96 } 154 }
97 155
98 CdmPromise::ResolveParameterType 156 // Explicit template instantiation for the Promises needed.
99 CdmPromiseTemplate<void>::GetResolveParameterType() const { 157 template class MEDIA_EXPORT CdmPromiseTemplate<std::string>;
100 return VOID_TYPE; 158 template class MEDIA_EXPORT CdmPromiseTemplate<KeyIdsVector>;
101 }
102
103 CdmPromiseTemplate<std::string>::CdmPromiseTemplate(
104 base::Callback<void(const std::string&)> resolve_cb,
105 PromiseRejectedCB reject_cb)
106 : CdmPromise(reject_cb), resolve_cb_(resolve_cb) {
107 DCHECK(!resolve_cb_.is_null());
108 }
109
110 CdmPromiseTemplate<std::string>::CdmPromiseTemplate(
111 base::Callback<void(const std::string&)> resolve_cb,
112 PromiseRejectedCB reject_cb,
113 const std::string& uma_name)
114 : CdmPromise(reject_cb, uma_name), resolve_cb_(resolve_cb) {
115 DCHECK(!resolve_cb_.is_null());
116 }
117
118 CdmPromiseTemplate<std::string>::CdmPromiseTemplate() {
119 }
120
121 CdmPromiseTemplate<std::string>::~CdmPromiseTemplate() {
122 DCHECK(!is_pending_);
123 }
124
125 void CdmPromiseTemplate<std::string>::resolve(const std::string& result) {
126 DCHECK(is_pending_);
127 is_pending_ = false;
128 if (!uma_name_.empty()) {
129 base::LinearHistogram::FactoryGet(
130 uma_name_, 1, NUM_RESULT_CODES, NUM_RESULT_CODES + 1,
131 base::HistogramBase::kUmaTargetedHistogramFlag)->Add(SUCCESS);
132 }
133 resolve_cb_.Run(result);
134 }
135
136 CdmPromise::ResolveParameterType
137 CdmPromiseTemplate<std::string>::GetResolveParameterType() const {
138 return STRING_TYPE;
139 }
140
141 CdmPromiseTemplate<KeyIdsVector>::CdmPromiseTemplate(
142 base::Callback<void(const KeyIdsVector&)> resolve_cb,
143 PromiseRejectedCB reject_cb)
144 : CdmPromise(reject_cb), resolve_cb_(resolve_cb) {
145 DCHECK(!resolve_cb_.is_null());
146 }
147
148 CdmPromiseTemplate<KeyIdsVector>::CdmPromiseTemplate(
149 base::Callback<void(const KeyIdsVector&)> resolve_cb,
150 PromiseRejectedCB reject_cb,
151 const std::string& uma_name)
152 : CdmPromise(reject_cb, uma_name), resolve_cb_(resolve_cb) {
153 DCHECK(!resolve_cb_.is_null());
154 }
155
156 CdmPromiseTemplate<KeyIdsVector>::~CdmPromiseTemplate() {
157 DCHECK(!is_pending_);
158 }
159
160 void CdmPromiseTemplate<KeyIdsVector>::resolve(const KeyIdsVector& result) {
161 DCHECK(is_pending_);
162 is_pending_ = false;
163 if (!uma_name_.empty()) {
164 base::LinearHistogram::FactoryGet(
165 uma_name_, 1, NUM_RESULT_CODES, NUM_RESULT_CODES + 1,
166 base::HistogramBase::kUmaTargetedHistogramFlag)->Add(SUCCESS);
167 }
168 resolve_cb_.Run(result);
169 }
170
171 CdmPromise::ResolveParameterType
172 CdmPromiseTemplate<KeyIdsVector>::GetResolveParameterType() const {
173 return KEY_IDS_VECTOR_TYPE;
174 }
175 159
176 } // namespace media 160 } // namespace media
OLDNEW
« media/base/cdm_promise.h ('K') | « media/base/cdm_promise.h ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698