| Index: net/proxy/dhcp_proxy_script_adapter_fetcher_win.h | 
| diff --git a/net/proxy/dhcp_proxy_script_adapter_fetcher_win.h b/net/proxy/dhcp_proxy_script_adapter_fetcher_win.h | 
| index a8fc43cea0f7899178403d12f4eb49b674fef82b..ffbe9c01643d79530ca28b61553044016bab7d97 100644 | 
| --- a/net/proxy/dhcp_proxy_script_adapter_fetcher_win.h | 
| +++ b/net/proxy/dhcp_proxy_script_adapter_fetcher_win.h | 
| @@ -107,62 +107,42 @@ class NET_EXPORT_PRIVATE DhcpProxyScriptAdapterFetcher | 
|  | 
| State state() const; | 
|  | 
| -  // This inner class is used to encapsulate the worker thread, which has | 
| -  // only a weak reference back to the main object, so that the main object | 
| -  // can be destroyed before the thread ends.  This also keeps the main | 
| -  // object completely thread safe and allows it to be non-refcounted. | 
| -  // | 
| -  // TODO(joi): Replace with PostTaskAndReply once http://crbug.com/86301 | 
| -  // has been implemented. | 
| -  class NET_EXPORT_PRIVATE WorkerThread | 
| -      : public base::RefCountedThreadSafe<WorkerThread> { | 
| +  // This inner class encapsulates work done on a worker pool thread. | 
| +  // By using a separate object, we can keep the main object completely | 
| +  // thread safe and let it be non-refcounted. | 
| +  class NET_EXPORT_PRIVATE DhcpQuery | 
| +      : public base::RefCountedThreadSafe<DhcpQuery> { | 
| public: | 
| -    // Creates and initializes (but does not start) the worker thread. | 
| -    explicit WorkerThread( | 
| -        const base::WeakPtr<DhcpProxyScriptAdapterFetcher>& owner); | 
| -    virtual ~WorkerThread(); | 
| +    DhcpQuery(); | 
| +    virtual ~DhcpQuery(); | 
| + | 
| +    // This method should run on a worker pool thread, via PostTaskAndReply. | 
| +    // After it has run, the |url()| method on this object will return the | 
| +    // URL retrieved. | 
| +    void GetPacURLForAdapter(const std::string& adapter_name); | 
|  | 
| -    // Starts the worker thread, fetching information for |adapter_name| using | 
| -    // |get_pac_from_url_func|. | 
| -    void Start(const std::string& adapter_name); | 
| +    // Returns the URL retrieved for the given adapter, once the task has run. | 
| +    const std::string& url() const; | 
|  | 
| protected: | 
| // Virtual method introduced to allow unit testing. | 
| virtual std::string ImplGetPacURLFromDhcp(const std::string& adapter_name); | 
|  | 
| private: | 
| -    // This is the method that runs on the worker thread. | 
| -    void ThreadFunc(const std::string& adapter_name); | 
| - | 
| -    // Callback for the above; this executes back on the main thread, | 
| -    // not the worker thread. | 
| -    void OnThreadDone(const std::string& url); | 
| - | 
| -    // All work except ThreadFunc and (sometimes) destruction should occur | 
| -    // on the thread that constructs the object. | 
| -    base::ThreadChecker thread_checker_; | 
| +    // The URL retrieved for the given adapter. | 
| +    std::string url_; | 
|  | 
| -    // May only be accessed on the thread that constructs the object. | 
| -    base::WeakPtr<DhcpProxyScriptAdapterFetcher> owner_; | 
| - | 
| -    // Used by worker thread to post a message back to the original | 
| -    // thread.  Fine to use a proxy since in the case where the original | 
| -    // thread has gone away, that would mean the |owner_| object is gone | 
| -    // anyway, so there is nobody to receive the result. | 
| -    scoped_refptr<base::MessageLoopProxy> origin_loop_; | 
| - | 
| -    DISALLOW_COPY_AND_ASSIGN(WorkerThread); | 
| +    DISALLOW_COPY_AND_ASSIGN(DhcpQuery); | 
| }; | 
|  | 
| // Virtual methods introduced to allow unit testing. | 
| virtual ProxyScriptFetcher* ImplCreateScriptFetcher(); | 
| -  virtual WorkerThread* ImplCreateWorkerThread( | 
| -      const base::WeakPtr<DhcpProxyScriptAdapterFetcher>& owner); | 
| +  virtual DhcpQuery* ImplCreateDhcpQuery(); | 
| virtual base::TimeDelta ImplGetTimeout() const; | 
|  | 
| private: | 
| // Event/state transition handlers | 
| -  void OnQueryDhcpDone(const std::string& url); | 
| +  void OnDhcpQueryDone(scoped_refptr<DhcpQuery> dhcp_query); | 
| void OnTimeout(); | 
| void OnFetcherDone(int result); | 
| void TransitionToFinish(); | 
| @@ -183,9 +163,6 @@ class NET_EXPORT_PRIVATE DhcpProxyScriptAdapterFetcher | 
| // START, FINISH and CANCEL. | 
| OldCompletionCallback* callback_; | 
|  | 
| -  // Container for our worker thread. NULL if not currently running. | 
| -  scoped_refptr<WorkerThread> worker_thread_; | 
| - | 
| // Fetcher to retrieve PAC files once URL is known. | 
| scoped_ptr<ProxyScriptFetcher> script_fetcher_; | 
|  | 
|  |