Index: net/base/host_resolver_proc.h |
=================================================================== |
--- net/base/host_resolver_proc.h (revision 0) |
+++ net/base/host_resolver_proc.h (revision 0) |
@@ -0,0 +1,69 @@ |
+// Copyright (c) 2009 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 NET_BASE_HOST_RESOLVER_PROC_H_ |
+#define NET_BASE_HOST_RESOLVER_PROC_H_ |
+ |
+#include <string> |
+ |
+#include "base/ref_counted.h" |
+ |
+namespace net { |
+ |
+class AddressList; |
+ |
+// Interface for a getaddrinfo()-like procedure. This is used by unit-tests |
+// to control the underlying resolutions in HostResolverImpl. HostResolverProcs |
+// can be chained together; they fallback to the next procedure in the chain |
+// by calling ResolveUsingPrevious(). |
+// |
+// Note that implementations of HostResolverProc *MUST BE THREADSAFE*, since |
+// the HostResolver implementation using them can be multi-threaded. |
+class HostResolverProc : public base::RefCountedThreadSafe<HostResolverProc> { |
+ public: |
+ explicit HostResolverProc(HostResolverProc* previous); |
+ virtual ~HostResolverProc() {} |
+ |
+ // Resolves |host| to an address list. If successful returns OK and fills |
+ // |addrlist| with a list of socket addresses. Otherwise returns a |
+ // network error code. |
+ virtual int Resolve(const std::string& host, AddressList* addrlist) = 0; |
+ |
+ protected: |
+ // Asks the fallback procedure (if set) to do the resolve. |
+ int ResolveUsingPrevious(const std::string& host, AddressList* addrlist); |
+ |
+ private: |
+ friend class HostResolverImpl; |
+ friend class MockHostResolver; |
+ friend class ScopedDefaultHostResolverProc; |
+ |
+ // Sets the previous procedure in the chain. |
+ void set_previous_proc(HostResolverProc* proc) { |
+ previous_proc_ = proc; |
+ } |
+ |
+ // Sets the default host resolver procedure that is used by HostResolverImpl. |
+ // This can be used through ScopedDefaultHostResolverProc to set a catch-all |
+ // DNS block in unit-tests (individual tests should use MockHostResolver to |
+ // prevent hitting the network). |
+ static HostResolverProc* SetDefault(HostResolverProc* proc); |
+ static HostResolverProc* GetDefault(); |
+ |
+ private: |
+ scoped_refptr<HostResolverProc> previous_proc_; |
+ static HostResolverProc* default_proc_; |
+ |
+ DISALLOW_COPY_AND_ASSIGN(HostResolverProc); |
+}; |
+ |
+// Resolves |host| to an address list, using the system's default host resolver. |
+// (i.e. this calls out to getaddrinfo()). If successful returns OK and fills |
+// |addrlist| with a list of socket addresses. Otherwise returns a |
+// network error code. |
+int SystemHostResolverProc(const std::string& host, AddressList* addrlist); |
+ |
+} // namespace net |
+ |
+#endif // NET_BASE_HOST_RESOLVER_PROC_H_ |
Property changes on: net\base\host_resolver_proc.h |
___________________________________________________________________ |
Added: svn:eol-style |
+ LF |