Chromium Code Reviews| 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_ |