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

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: NewSessionCdmResultPromise 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 namespace {
12
13 template <typename... T>
14 struct CdmPromiseTraits {}; 14 struct CdmPromiseTraits {};
15 15
16 template <> 16 template <>
17 struct CdmPromiseTraits<void> { 17 struct CdmPromiseTraits<> {
18 static const CdmPromise::ResolveParameterType kType = CdmPromise::VOID_TYPE; 18 static const CdmPromise::ResolveParameterType kType = CdmPromise::VOID_TYPE;
19 }; 19 };
20 20
21 template <> 21 template <>
22 struct CdmPromiseTraits<std::string> { 22 struct CdmPromiseTraits<std::string> {
23 static const CdmPromise::ResolveParameterType kType = CdmPromise::STRING_TYPE; 23 static const CdmPromise::ResolveParameterType kType = CdmPromise::STRING_TYPE;
24 }; 24 };
25 25
26 template <> 26 template <>
27 struct CdmPromiseTraits<KeyIdsVector> { 27 struct CdmPromiseTraits<KeyIdsVector> {
28 static const CdmPromise::ResolveParameterType kType = 28 static const CdmPromise::ResolveParameterType kType =
29 CdmPromise::KEY_IDS_VECTOR_TYPE; 29 CdmPromise::KEY_IDS_VECTOR_TYPE;
30 }; 30 };
31 31
32 CdmPromise::CdmPromise(ResolveParameterType parameter_type) 32 } // namespace
33 : parameter_type_(parameter_type), is_pending_(true) {
34 }
35 33
36 CdmPromise::CdmPromise(ResolveParameterType parameter_type, 34 CdmPromise::CdmPromise() {
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 } 35 }
54 36
55 CdmPromise::~CdmPromise() { 37 CdmPromise::~CdmPromise() {
56 DCHECK(!is_pending_);
57 } 38 }
58 39
59 static CdmPromise::ResultCodeForUMA ConvertExceptionToUMAResult( 40 template <typename... T>
60 MediaKeys::Exception exception_code) { 41 CdmPromiseTemplate<T...>::CdmPromiseTemplate()
61 switch (exception_code) { 42 : is_settled_(false) {
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 } 43 }
80 44
81 void CdmPromise::reject(MediaKeys::Exception exception_code, 45 template <typename... T>
82 uint32 system_code, 46 CdmPromiseTemplate<T...>::~CdmPromiseTemplate() {
83 const std::string& error_message) { 47 DCHECK(is_settled_);
84 ReportResultToUMA(ConvertExceptionToUMAResult(exception_code));
85 reject_cb_.Run(exception_code, system_code, error_message);
86 } 48 }
87 49
88 void CdmPromise::ReportResultToUMA(ResultCodeForUMA result) { 50 template <typename... T>
89 DCHECK(is_pending_); 51 CdmPromise::ResolveParameterType
90 is_pending_ = false; 52 CdmPromiseTemplate<T...>::GetResolveParameterType() const {
91 if (!uma_name_.empty()) { 53 return CdmPromiseTraits<T...>::kType;
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 } 54 }
100 55
101 template <typename T> 56 template <typename... T>
102 CdmPromiseTemplate<T>::CdmPromiseTemplate( 57 void CdmPromiseTemplate<T...>::MarkPromiseSettled() {
103 base::Callback<void(const T&)> resolve_cb, 58 // Promise can only be settled once.
104 PromiseRejectedCB reject_cb) 59 DCHECK(!is_settled_);
105 : CdmPromise(CdmPromiseTraits<T>::kType, reject_cb), 60 is_settled_ = true;
106 resolve_cb_(resolve_cb) {
107 DCHECK(!resolve_cb_.is_null());
108 } 61 }
109 62
110 template <typename T> 63 // Explicit template instantiation for the template Promises needed.
111 CdmPromiseTemplate<T>::CdmPromiseTemplate( 64 template class MEDIA_EXPORT 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);
129 }
130
131 CdmPromiseTemplate<void>::CdmPromiseTemplate(base::Callback<void()> resolve_cb,
132 PromiseRejectedCB reject_cb)
133 : CdmPromise(CdmPromiseTraits<void>::kType, reject_cb),
134 resolve_cb_(resolve_cb) {
135 DCHECK(!resolve_cb_.is_null());
136 }
137
138 CdmPromiseTemplate<void>::CdmPromiseTemplate(base::Callback<void()> resolve_cb,
139 PromiseRejectedCB reject_cb,
140 const std::string& uma_name)
141 : CdmPromise(CdmPromiseTraits<void>::kType, reject_cb, uma_name),
142 resolve_cb_(resolve_cb) {
143 DCHECK(!resolve_cb_.is_null());
144 DCHECK(!uma_name_.empty());
145 }
146
147 CdmPromiseTemplate<void>::CdmPromiseTemplate()
148 : CdmPromise(CdmPromiseTraits<void>::kType) {
149 }
150
151 void CdmPromiseTemplate<void>::resolve() {
152 ReportResultToUMA(SUCCESS);
153 resolve_cb_.Run();
154 }
155
156 // Explicit template instantiation for the Promises needed.
157 template class MEDIA_EXPORT CdmPromiseTemplate<std::string>; 65 template class MEDIA_EXPORT CdmPromiseTemplate<std::string>;
158 template class MEDIA_EXPORT CdmPromiseTemplate<KeyIdsVector>; 66 template class MEDIA_EXPORT CdmPromiseTemplate<KeyIdsVector>;
159 67
160 } // namespace media 68 } // namespace media
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698