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

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

Issue 567123002: Cleanup template in CdmPromise (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: back to promise 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
« no previous file with comments | « no previous file | media/base/cdm_promise.cc » ('j') | media/base/cdm_promise.cc » ('J')
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 #ifndef MEDIA_BASE_CDM_PROMISE_H_ 5 #ifndef MEDIA_BASE_CDM_PROMISE_H_
6 #define MEDIA_BASE_CDM_PROMISE_H_ 6 #define MEDIA_BASE_CDM_PROMISE_H_
7 7
8 #include <string> 8 #include <string>
9 9
10 #include "base/basictypes.h" 10 #include "base/basictypes.h"
(...skipping 49 matching lines...) Expand 10 before | Expand all | Expand 10 after
60 60
61 protected: 61 protected:
62 CdmPromise(); 62 CdmPromise();
63 CdmPromise(PromiseRejectedCB reject_cb); 63 CdmPromise(PromiseRejectedCB reject_cb);
64 64
65 // If constructed with a |uma_name| (which must be the name of a 65 // If constructed with a |uma_name| (which must be the name of a
66 // CdmPromiseResult UMA), CdmPromise will report the promise result (success 66 // CdmPromiseResult UMA), CdmPromise will report the promise result (success
67 // or rejection code). 67 // or rejection code).
68 CdmPromise(PromiseRejectedCB reject_cb, const std::string& uma_name); 68 CdmPromise(PromiseRejectedCB reject_cb, const std::string& uma_name);
69 69
70 // Called by all resolve() methods to do the check on |is_pending_|
ddorwin 2014/09/19 20:56:46 ... to report UMA, if applicable, and update |is_p
jrummell 2014/09/22 19:21:10 Done.
71 // and call the UMA success if required.
72 void ReportResolution();
ddorwin 2014/09/19 20:56:46 nit: "Resolution" has many meanings. How about Rep
xhwang 2014/09/20 00:34:50 ReportXxxToUMA() to be explicit?
jrummell 2014/09/22 19:21:10 Done.
jrummell 2014/09/22 19:21:10 Done.
73
70 PromiseRejectedCB reject_cb_; 74 PromiseRejectedCB reject_cb_;
71 75
72 // Keep track of whether the promise hasn't been resolved or rejected yet. 76 // Keep track of whether the promise hasn't been resolved or rejected yet.
73 bool is_pending_; 77 bool is_pending_;
74 78
75 // UMA to report result to. 79 // UMA to report result to.
xhwang 2014/09/20 00:34:50 s/UMA/UMA name/ Can you give an example here? Som
jrummell 2014/09/22 19:21:10 Comment changed. As for an example, the names are
76 std::string uma_name_; 80 std::string uma_name_;
77 81
78 DISALLOW_COPY_AND_ASSIGN(CdmPromise); 82 DISALLOW_COPY_AND_ASSIGN(CdmPromise);
79 }; 83 };
80 84
81 // Specialization for no parameter to resolve(). 85 template <typename T>
82 template <> 86 class MEDIA_EXPORT CdmPromiseTemplate : public CdmPromise {
83 class MEDIA_EXPORT CdmPromiseTemplate<void> : public CdmPromise {
84 public: 87 public:
85 CdmPromiseTemplate(base::Callback<void(void)> resolve_cb, 88 CdmPromiseTemplate(base::Callback<void(const T&)> resolve_cb,
86 PromiseRejectedCB rejected_cb); 89 PromiseRejectedCB rejected_cb);
87 CdmPromiseTemplate(base::Callback<void(void)> resolve_cb, 90 CdmPromiseTemplate(base::Callback<void(const T&)> resolve_cb,
88 PromiseRejectedCB rejected_cb, 91 PromiseRejectedCB rejected_cb,
89 const std::string& uma_name); 92 const std::string& uma_name);
90 virtual ~CdmPromiseTemplate(); 93 virtual ~CdmPromiseTemplate();
91 virtual void resolve(); 94 virtual void resolve(const T& result);
92 virtual ResolveParameterType GetResolveParameterType() const OVERRIDE; 95 virtual ResolveParameterType GetResolveParameterType() const OVERRIDE;
ddorwin 2014/09/19 20:56:46 Rather than overriding this, can we make the base
jrummell 2014/09/22 19:21:10 Done.
93 96
94 protected: 97 protected:
95 // Allow subclasses to completely override the implementation. 98 // Allow subclasses to completely override the implementation.
ddorwin 2014/09/19 20:56:46 Is this still appropriate? I don't think it was us
jrummell 2014/09/22 19:21:10 It is used by SessionUpdatedPromise and SessionLoa
ddorwin 2014/09/22 20:46:30 Maybe a TODO to consider removing these in October
jrummell 2014/09/22 23:57:32 I'll wait until the new overrides are implemented.
96 CdmPromiseTemplate(); 99 CdmPromiseTemplate();
97 100
98 private: 101 private:
102 base::Callback<void(const T&)> resolve_cb_;
103
104 DISALLOW_COPY_AND_ASSIGN(CdmPromiseTemplate);
105 };
106
107 // Specialization for no parameter to resolve().
108 template <>
109 class MEDIA_EXPORT CdmPromiseTemplate<void> : public CdmPromise {
110 public:
111 CdmPromiseTemplate(base::Callback<void(void)> resolve_cb,
112 PromiseRejectedCB rejected_cb);
113 CdmPromiseTemplate(base::Callback<void(void)> resolve_cb,
114 PromiseRejectedCB rejected_cb,
115 const std::string& uma_name);
116 virtual ~CdmPromiseTemplate();
117 virtual void resolve();
118 virtual ResolveParameterType GetResolveParameterType() const OVERRIDE;
119
120 protected:
121 // Allow subclasses to completely override the implementation.
122 CdmPromiseTemplate();
123
124 private:
99 base::Callback<void(void)> resolve_cb_; 125 base::Callback<void(void)> resolve_cb_;
100 126
101 DISALLOW_COPY_AND_ASSIGN(CdmPromiseTemplate); 127 DISALLOW_COPY_AND_ASSIGN(CdmPromiseTemplate);
102 }; 128 };
103
104 template <>
105 class MEDIA_EXPORT CdmPromiseTemplate<std::string> : public CdmPromise {
106 public:
107 CdmPromiseTemplate(base::Callback<void(const std::string&)> resolve_cb,
108 PromiseRejectedCB rejected_cb);
109 CdmPromiseTemplate(base::Callback<void(const std::string&)> resolve_cb,
110 PromiseRejectedCB rejected_cb,
111 const std::string& uma_name);
112 virtual ~CdmPromiseTemplate();
113 virtual void resolve(const std::string& result);
114 virtual ResolveParameterType GetResolveParameterType() const OVERRIDE;
115
116 protected:
117 // Allow subclasses to completely override the implementation.
118 // TODO(jrummell): Remove when derived class SessionLoadedPromise
119 // (in ppapi_decryptor.cc) is no longer needed.
120 CdmPromiseTemplate();
121
122 private:
123 base::Callback<void(const std::string&)> resolve_cb_;
124
125 DISALLOW_COPY_AND_ASSIGN(CdmPromiseTemplate);
126 };
127
128 template <>
129 class MEDIA_EXPORT CdmPromiseTemplate<KeyIdsVector> : public CdmPromise {
130 public:
131 CdmPromiseTemplate(base::Callback<void(const KeyIdsVector&)> resolve_cb,
132 PromiseRejectedCB rejected_cb);
133 CdmPromiseTemplate(base::Callback<void(const KeyIdsVector&)> resolve_cb,
134 PromiseRejectedCB rejected_cb,
135 const std::string& uma_name);
136 virtual ~CdmPromiseTemplate();
137 virtual void resolve(const KeyIdsVector& result);
138 virtual ResolveParameterType GetResolveParameterType() const OVERRIDE;
139
140 private:
141 base::Callback<void(const KeyIdsVector&)> resolve_cb_;
142
143 DISALLOW_COPY_AND_ASSIGN(CdmPromiseTemplate);
144 };
145 129
146 } // namespace media 130 } // namespace media
147 131
148 #endif // MEDIA_BASE_CDM_PROMISE_H_ 132 #endif // MEDIA_BASE_CDM_PROMISE_H_
OLDNEW
« no previous file with comments | « no previous file | media/base/cdm_promise.cc » ('j') | media/base/cdm_promise.cc » ('J')

Powered by Google App Engine
This is Rietveld 408576698