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

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

Issue 604283003: Refactor CdmPromise and related classes (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Created 6 years, 2 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
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"
8 #include "base/logging.h" 7 #include "base/logging.h"
9 #include "base/metrics/histogram.h"
10 8
11 namespace media { 9 namespace media {
12 10
13 template <typename T> 11 template <typename T>
14 struct CdmPromiseTraits {}; 12 struct CdmPromiseTraits {};
15 13
16 template <> 14 template <>
17 struct CdmPromiseTraits<void> { 15 struct CdmPromiseTraits<void> {
18 static const CdmPromise::ResolveParameterType kType = CdmPromise::VOID_TYPE; 16 static const CdmPromise::ResolveParameterType kType = CdmPromise::VOID_TYPE;
19 }; 17 };
20 18
21 template <> 19 template <>
22 struct CdmPromiseTraits<std::string> { 20 struct CdmPromiseTraits<std::string> {
23 static const CdmPromise::ResolveParameterType kType = CdmPromise::STRING_TYPE; 21 static const CdmPromise::ResolveParameterType kType = CdmPromise::STRING_TYPE;
24 }; 22 };
25 23
26 template <> 24 template <>
27 struct CdmPromiseTraits<KeyIdsVector> { 25 struct CdmPromiseTraits<KeyIdsVector> {
28 static const CdmPromise::ResolveParameterType kType = 26 static const CdmPromise::ResolveParameterType kType =
29 CdmPromise::KEY_IDS_VECTOR_TYPE; 27 CdmPromise::KEY_IDS_VECTOR_TYPE;
30 }; 28 };
xhwang 2014/09/29 18:32:58 You can put CdmPromiseTraits in an anonymous names
jrummell 2014/09/29 22:08:39 Done.
31 29
32 CdmPromise::CdmPromise(ResolveParameterType parameter_type) 30 CdmPromise::CdmPromise() {
33 : parameter_type_(parameter_type), is_pending_(true) {
34 }
35
36 CdmPromise::CdmPromise(ResolveParameterType parameter_type,
37 PromiseRejectedCB reject_cb)
38 : parameter_type_(parameter_type),
39 reject_cb_(reject_cb),
40 is_pending_(true) {
41 DCHECK(!reject_cb_.is_null());
42 }
43
44 CdmPromise::CdmPromise(ResolveParameterType parameter_type,
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) {
51 DCHECK(!reject_cb_.is_null());
52 DCHECK(!uma_name_.empty());
53 } 31 }
54 32
55 CdmPromise::~CdmPromise() { 33 CdmPromise::~CdmPromise() {
56 DCHECK(!is_pending_);
57 }
58
59 static CdmPromise::ResultCodeForUMA ConvertExceptionToUMAResult(
60 MediaKeys::Exception exception_code) {
61 switch (exception_code) {
62 case MediaKeys::NOT_SUPPORTED_ERROR:
63 return CdmPromise::NOT_SUPPORTED_ERROR;
64 case MediaKeys::INVALID_STATE_ERROR:
65 return CdmPromise::INVALID_STATE_ERROR;
66 case MediaKeys::INVALID_ACCESS_ERROR:
67 return CdmPromise::INVALID_ACCESS_ERROR;
68 case MediaKeys::QUOTA_EXCEEDED_ERROR:
69 return CdmPromise::QUOTA_EXCEEDED_ERROR;
70 case MediaKeys::UNKNOWN_ERROR:
71 return CdmPromise::UNKNOWN_ERROR;
72 case MediaKeys::CLIENT_ERROR:
73 return CdmPromise::CLIENT_ERROR;
74 case MediaKeys::OUTPUT_ERROR:
75 return CdmPromise::OUTPUT_ERROR;
76 }
77 NOTREACHED();
78 return CdmPromise::UNKNOWN_ERROR;
79 }
80
81 void CdmPromise::reject(MediaKeys::Exception exception_code,
82 uint32 system_code,
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) {
89 DCHECK(is_pending_);
90 is_pending_ = false;
91 if (!uma_name_.empty()) {
92 base::LinearHistogram::FactoryGet(
93 uma_name_,
94 1,
95 NUM_RESULT_CODES,
96 NUM_RESULT_CODES + 1,
97 base::HistogramBase::kUmaTargetedHistogramFlag)->Add(result);
98 }
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 } 34 }
119 35
120 template <typename T> 36 template <typename T>
121 CdmPromiseTemplate<T>::CdmPromiseTemplate() 37 CdmPromiseTemplate<T>::CdmPromiseTemplate()
122 : CdmPromise(CdmPromiseTraits<T>::kType) { 38 : CdmPromise() {
39 }
xhwang 2014/09/29 18:32:58 nit: will clang-format make this in one line?
jrummell 2014/09/29 22:08:39 File has been run through clang-format.
40
41 template <typename T>
42 CdmPromiseTemplate<T>::~CdmPromiseTemplate() {
123 } 43 }
124 44
125 template <typename T> 45 template <typename T>
126 void CdmPromiseTemplate<T>::resolve(const T& result) { 46 void CdmPromiseTemplate<T>::resolve(const T& result) {
127 ReportResultToUMA(SUCCESS); 47 // This must be overridden in a subclass.
48 NOTREACHED();
49 }
xhwang 2014/09/29 18:32:58 If resolve is pure virtual we don't need this :)
jrummell 2014/09/29 22:08:39 Done.
50
51 template <typename T>
52 CdmPromise::ResolveParameterType
53 CdmPromiseTemplate<T>::GetResolveParameterType() const {
54 return CdmPromiseTraits<T>::kType;
55 }
56
57 CdmPromiseTemplate<void>::CdmPromiseTemplate() : CdmPromise() {
58 }
59
60 CdmPromiseTemplate<void>::~CdmPromiseTemplate() {
61 }
62
63 void CdmPromiseTemplate<void>::resolve() {
64 // This must be overridden in a subclass.
65 NOTREACHED();
66 }
xhwang 2014/09/29 18:32:58 ditto
jrummell 2014/09/29 22:08:39 Done.
67
68 CdmPromise::ResolveParameterType
69 CdmPromiseTemplate<void>::GetResolveParameterType() const {
70 return CdmPromiseTraits<void>::kType;
71 }
72
73 template <typename T>
74 CdmCallbackPromise<T>::CdmCallbackPromise(
75 base::Callback<void(const T&)> resolve_cb,
76 PromiseRejectedCB reject_cb)
77 : CdmPromiseTemplate<T>(),
78 resolve_cb_(resolve_cb),
79 reject_cb_(reject_cb),
80 is_pending_(true) {
81 DCHECK(!resolve_cb_.is_null());
82 DCHECK(!reject_cb_.is_null());
83 }
84
85 template <typename T>
86 CdmCallbackPromise<T>::~CdmCallbackPromise() {
87 DCHECK(!is_pending_);
88 }
89
90 template <typename T>
91 void CdmCallbackPromise<T>::resolve(const T& result) {
92 DCHECK(is_pending_);
93 is_pending_ = false;
128 resolve_cb_.Run(result); 94 resolve_cb_.Run(result);
129 } 95 }
130 96
131 CdmPromiseTemplate<void>::CdmPromiseTemplate(base::Callback<void()> resolve_cb, 97 template <typename T>
132 PromiseRejectedCB reject_cb) 98 void CdmCallbackPromise<T>::reject(MediaKeys::Exception exception_code,
133 : CdmPromise(CdmPromiseTraits<void>::kType, reject_cb), 99 uint32 system_code,
134 resolve_cb_(resolve_cb) { 100 const std::string& error_message) {
135 DCHECK(!resolve_cb_.is_null()); 101 DCHECK(is_pending_);
102 is_pending_ = false;
103 reject_cb_.Run(exception_code, system_code, error_message);
136 } 104 }
137 105
138 CdmPromiseTemplate<void>::CdmPromiseTemplate(base::Callback<void()> resolve_cb, 106 CdmCallbackPromise<void>::CdmCallbackPromise(
139 PromiseRejectedCB reject_cb, 107 base::Callback<void(void)> resolve_cb,
140 const std::string& uma_name) 108 PromiseRejectedCB reject_cb)
141 : CdmPromise(CdmPromiseTraits<void>::kType, reject_cb, uma_name), 109 : CdmPromiseTemplate<void>(),
142 resolve_cb_(resolve_cb) { 110 resolve_cb_(resolve_cb),
111 reject_cb_(reject_cb),
112 is_pending_(true) {
143 DCHECK(!resolve_cb_.is_null()); 113 DCHECK(!resolve_cb_.is_null());
144 DCHECK(!uma_name_.empty()); 114 DCHECK(!reject_cb_.is_null());
145 } 115 }
146 116
147 CdmPromiseTemplate<void>::CdmPromiseTemplate() 117 CdmCallbackPromise<void>::~CdmCallbackPromise() {
148 : CdmPromise(CdmPromiseTraits<void>::kType) { 118 DCHECK(!is_pending_);
149 } 119 }
150 120
151 void CdmPromiseTemplate<void>::resolve() { 121 void CdmCallbackPromise<void>::resolve() {
152 ReportResultToUMA(SUCCESS); 122 DCHECK(is_pending_);
123 is_pending_ = false;
153 resolve_cb_.Run(); 124 resolve_cb_.Run();
154 } 125 }
155 126
127 void CdmCallbackPromise<void>::reject(MediaKeys::Exception exception_code,
128 uint32 system_code,
129 const std::string& error_message) {
130 DCHECK(is_pending_);
131 is_pending_ = false;
132 reject_cb_.Run(exception_code, system_code, error_message);
133 }
134
156 // Explicit template instantiation for the Promises needed. 135 // Explicit template instantiation for the Promises needed.
157 template class MEDIA_EXPORT CdmPromiseTemplate<std::string>; 136 template class MEDIA_EXPORT CdmPromiseTemplate<std::string>;
158 template class MEDIA_EXPORT CdmPromiseTemplate<KeyIdsVector>; 137 template class MEDIA_EXPORT CdmPromiseTemplate<KeyIdsVector>;
138 template class MEDIA_EXPORT CdmCallbackPromise<std::string>;
139 template class MEDIA_EXPORT CdmCallbackPromise<KeyIdsVector>;
159 140
160 } // namespace media 141 } // namespace media
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698