Index: ppapi/proxy/resource_reply_thread_registrar.h |
diff --git a/ppapi/proxy/resource_reply_thread_registrar.h b/ppapi/proxy/resource_reply_thread_registrar.h |
new file mode 100644 |
index 0000000000000000000000000000000000000000..bcae9d29649b2f843ded8993d113369c01599707 |
--- /dev/null |
+++ b/ppapi/proxy/resource_reply_thread_registrar.h |
@@ -0,0 +1,64 @@ |
+// Copyright (c) 2013 The Chromium Authors. All rights reserved. |
+// Use of this source code is governed by a BSD-style license that can be |
+// found in the LICENSE file. |
+ |
+#ifndef PPAPI_PROXY_RESOURCE_REPLY_THREAD_REGISTRAR_H_ |
+#define PPAPI_PROXY_RESOURCE_REPLY_THREAD_REGISTRAR_H_ |
+ |
+#include <map> |
+ |
+#include "base/basictypes.h" |
+#include "base/memory/ref_counted.h" |
+#include "base/synchronization/lock.h" |
+#include "ppapi/c/pp_resource.h" |
+#include "ppapi/proxy/ppapi_proxy_export.h" |
+ |
+ |
+namespace base { |
+class MessageLoopProxy; |
+} |
+ |
+namespace ppapi { |
+ |
+class TrackedCallback; |
+ |
+namespace proxy { |
+ |
+// ResourceReplyThreadRegistrar records handling thread for |
dmichael (off chromium)
2013/12/10 23:38:01
nit: records +the+ handling
yzshen1
2013/12/11 00:21:49
Done.
|
+// PpapiPluginMsg_ResourceReply messages. |
+// This class is thread safe. |
+class PPAPI_PROXY_EXPORT ResourceReplyThreadRegistrar |
+ : public base::RefCountedThreadSafe<ResourceReplyThreadRegistrar> { |
+ public: |
+ explicit ResourceReplyThreadRegistrar( |
+ scoped_refptr<base::MessageLoopProxy> default_thread); |
+ |
+ void Register(PP_Resource resource, |
+ int32_t sequence_number, |
+ scoped_refptr<TrackedCallback> reply_thread_hint); |
+ void Unregister(PP_Resource resource); |
+ |
+ scoped_refptr<base::MessageLoopProxy> GetTargetThreadAndUnregister( |
dmichael (off chromium)
2013/12/10 23:38:01
As I understand it, Unregister and this method sho
yzshen1
2013/12/11 00:21:49
All methods except Register() don't care about whe
|
+ PP_Resource resource, |
+ int32_t sequence_number); |
+ |
+ private: |
+ friend class base::RefCountedThreadSafe<ResourceReplyThreadRegistrar>; |
+ |
+ typedef std::map<int32_t, scoped_refptr<base::MessageLoopProxy> > |
+ SequenceNumberMap; |
+ typedef std::map<PP_Resource, SequenceNumberMap> ResourceMap; |
+ |
+ ~ResourceReplyThreadRegistrar(); |
+ |
+ base::Lock lock_; |
dmichael (off chromium)
2013/12/10 23:38:01
I find this a little bit scary, like we might mess
yzshen1
2013/12/11 00:21:49
Yeah, GetTargetThreadAndUnregister() will be calle
|
+ ResourceMap map_; |
+ scoped_refptr<base::MessageLoopProxy> default_thread_; |
+ |
+ DISALLOW_COPY_AND_ASSIGN(ResourceReplyThreadRegistrar); |
+}; |
+ |
+} // namespace proxy |
+} // namespace ppapi |
+ |
+#endif // PPAPI_PROXY_RESOURCE_REPLY_THREAD_REGISTRAR_H_ |