Home | History | Annotate | Download | only in proxy
      1 // Copyright 2013 The Chromium Authors. All rights reserved.
      2 // Use of this source code is governed by a BSD-style license that can be
      3 // found in the LICENSE file.
      4 
      5 #include "ppapi/proxy/resource_reply_thread_registrar.h"
      6 
      7 #include "base/logging.h"
      8 #include "base/message_loop/message_loop_proxy.h"
      9 #include "ppapi/shared_impl/proxy_lock.h"
     10 #include "ppapi/shared_impl/tracked_callback.h"
     11 
     12 namespace ppapi {
     13 namespace proxy {
     14 
     15 ResourceReplyThreadRegistrar::ResourceReplyThreadRegistrar(
     16     scoped_refptr<base::MessageLoopProxy> default_thread)
     17     : default_thread_(default_thread) {
     18 }
     19 
     20 ResourceReplyThreadRegistrar::~ResourceReplyThreadRegistrar() {
     21 }
     22 
     23 void ResourceReplyThreadRegistrar::Register(
     24     PP_Resource resource,
     25     int32_t sequence_number,
     26     scoped_refptr<TrackedCallback> reply_thread_hint) {
     27   ProxyLock::AssertAcquiredDebugOnly();
     28 
     29   // Use the default thread if |reply_thread_hint| is NULL or blocking.
     30   if (!reply_thread_hint || reply_thread_hint->is_blocking())
     31     return;
     32 
     33   DCHECK(reply_thread_hint->target_loop());
     34   scoped_refptr<base::MessageLoopProxy> reply_thread(
     35       reply_thread_hint->target_loop()->GetMessageLoopProxy());
     36   {
     37     base::AutoLock auto_lock(lock_);
     38 
     39     if (reply_thread == default_thread_)
     40       return;
     41 
     42     map_[resource][sequence_number] = reply_thread;
     43   }
     44 }
     45 
     46 void ResourceReplyThreadRegistrar::Unregister(PP_Resource resource) {
     47   base::AutoLock auto_lock(lock_);
     48   map_.erase(resource);
     49 }
     50 
     51 scoped_refptr<base::MessageLoopProxy>
     52 ResourceReplyThreadRegistrar::GetTargetThreadAndUnregister(
     53     PP_Resource resource,
     54     int32_t sequence_number) {
     55   base::AutoLock auto_lock(lock_);
     56   ResourceMap::iterator resource_iter = map_.find(resource);
     57   if (resource_iter == map_.end())
     58     return default_thread_;
     59 
     60   SequenceNumberMap::iterator sequence_number_iter =
     61       resource_iter->second.find(sequence_number);
     62   if (sequence_number_iter == resource_iter->second.end())
     63     return default_thread_;
     64 
     65   scoped_refptr<base::MessageLoopProxy> target = sequence_number_iter->second;
     66   resource_iter->second.erase(sequence_number_iter);
     67   return target;
     68 }
     69 
     70 }  // namespace proxy
     71 }  // namespace ppapi
     72