Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2011 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 NET_PROXY_PROXY_RESOLVER_V8_H_ | 5 #ifndef NET_PROXY_PROXY_RESOLVER_V8_H_ |
| 6 #define NET_PROXY_PROXY_RESOLVER_V8_H_ | 6 #define NET_PROXY_PROXY_RESOLVER_V8_H_ |
| 7 | 7 |
| 8 #include "base/compiler_specific.h" | 8 #include "base/compiler_specific.h" |
| 9 #include "base/memory/scoped_ptr.h" | 9 #include "base/memory/scoped_ptr.h" |
| 10 #include "net/base/net_export.h" | 10 #include "net/base/net_export.h" |
| 11 #include "net/proxy/proxy_resolver.h" | 11 #include "net/proxy/proxy_resolver.h" |
| 12 | 12 |
| 13 namespace v8 { | |
| 14 class Isolate; | |
| 15 } // namespace v8 | |
| 16 | |
| 13 namespace net { | 17 namespace net { |
| 14 | 18 |
| 15 class ProxyResolverJSBindings; | 19 class ProxyResolverJSBindings; |
| 16 | 20 |
| 17 // Implementation of ProxyResolver that uses V8 to evaluate PAC scripts. | 21 // Implementation of ProxyResolver that uses V8 to evaluate PAC scripts. |
| 18 // | 22 // |
| 19 // ---------------------------------------------------------------------------- | 23 // ---------------------------------------------------------------------------- |
| 20 // !!! Important note on threading model: | 24 // !!! Important note on threading model: |
|
eroman
2013/01/18 19:21:14
Please update this comment.
Sven Panne
2013/01/21 08:50:06
This comment is still OK. The v8_default_isolate b
| |
| 21 // ---------------------------------------------------------------------------- | 25 // ---------------------------------------------------------------------------- |
| 22 // There can be only one instance of V8 running at a time. To enforce this | 26 // There can be only one instance of V8 running at a time. To enforce this |
| 23 // constraint, ProxyResolverV8 holds a v8::Locker during execution. Therefore | 27 // constraint, ProxyResolverV8 holds a v8::Locker during execution. Therefore |
| 24 // it is OK to run multiple instances of ProxyResolverV8 on different threads, | 28 // it is OK to run multiple instances of ProxyResolverV8 on different threads, |
| 25 // since only one will be running inside V8 at a time. | 29 // since only one will be running inside V8 at a time. |
| 26 // | 30 // |
| 27 // It is important that *ALL* instances of V8 in the process be using | 31 // It is important that *ALL* instances of V8 in the process be using |
| 28 // v8::Locker. If not there can be race conditions between the non-locked V8 | 32 // v8::Locker. If not there can be race conditions between the non-locked V8 |
| 29 // instances and the locked V8 instances used by ProxyResolverV8 (assuming they | 33 // instances and the locked V8 instances used by ProxyResolverV8 (assuming they |
| 30 // run on different threads). | 34 // run on different threads). |
| 31 // | 35 // |
| 32 // This is the case with the V8 instance used by chromium's renderer -- it runs | 36 // This is the case with the V8 instance used by chromium's renderer -- it runs |
| 33 // on a different thread from ProxyResolver (renderer thread vs PAC thread), | 37 // on a different thread from ProxyResolver (renderer thread vs PAC thread), |
| 34 // and does not use locking since it expects to be alone. | 38 // and does not use locking since it expects to be alone. |
| 35 class NET_EXPORT_PRIVATE ProxyResolverV8 : public ProxyResolver { | 39 class NET_EXPORT_PRIVATE ProxyResolverV8 : public ProxyResolver { |
| 36 public: | 40 public: |
| 37 // Constructs a ProxyResolverV8 with custom bindings. ProxyResolverV8 takes | 41 // Constructs a ProxyResolverV8 with custom bindings. ProxyResolverV8 takes |
| 38 // ownership of |custom_js_bindings| and deletes it when ProxyResolverV8 | 42 // ownership of |custom_js_bindings| and deletes it when ProxyResolverV8 |
| 39 // is destroyed. | 43 // is destroyed. |
| 40 explicit ProxyResolverV8(ProxyResolverJSBindings* custom_js_bindings); | 44 ProxyResolverV8(ProxyResolverJSBindings* custom_js_bindings, |
| 45 v8::Isolate* v8_default_isolate); | |
| 41 | 46 |
| 42 virtual ~ProxyResolverV8(); | 47 virtual ~ProxyResolverV8(); |
| 43 | 48 |
| 44 ProxyResolverJSBindings* js_bindings() const { return js_bindings_.get(); } | 49 ProxyResolverJSBindings* js_bindings() const { return js_bindings_.get(); } |
| 45 | 50 |
| 46 // ProxyResolver implementation: | 51 // ProxyResolver implementation: |
| 47 virtual int GetProxyForURL(const GURL& url, | 52 virtual int GetProxyForURL(const GURL& url, |
| 48 ProxyInfo* results, | 53 ProxyInfo* results, |
| 49 const net::CompletionCallback& /*callback*/, | 54 const net::CompletionCallback& /*callback*/, |
| 50 RequestHandle* /*request*/, | 55 RequestHandle* /*request*/, |
| (...skipping 11 matching lines...) Expand all Loading... | |
| 62 | 67 |
| 63 private: | 68 private: |
| 64 // Context holds the Javascript state for the most recently loaded PAC | 69 // Context holds the Javascript state for the most recently loaded PAC |
| 65 // script. It corresponds with the data from the last call to | 70 // script. It corresponds with the data from the last call to |
| 66 // SetPacScript(). | 71 // SetPacScript(). |
| 67 class Context; | 72 class Context; |
| 68 scoped_ptr<Context> context_; | 73 scoped_ptr<Context> context_; |
| 69 | 74 |
| 70 scoped_ptr<ProxyResolverJSBindings> js_bindings_; | 75 scoped_ptr<ProxyResolverJSBindings> js_bindings_; |
| 71 | 76 |
| 77 v8::Isolate* v8_default_isolate_; | |
| 78 | |
| 72 DISALLOW_COPY_AND_ASSIGN(ProxyResolverV8); | 79 DISALLOW_COPY_AND_ASSIGN(ProxyResolverV8); |
| 73 }; | 80 }; |
| 74 | 81 |
| 75 } // namespace net | 82 } // namespace net |
| 76 | 83 |
| 77 #endif // NET_PROXY_PROXY_RESOLVER_V8_H_ | 84 #endif // NET_PROXY_PROXY_RESOLVER_V8_H_ |
| OLD | NEW |