Chromium Code Reviews| Index: webrtc/base/network.h |
| diff --git a/webrtc/base/network.h b/webrtc/base/network.h |
| index 8e5c8f0fb70e196acb1bab84321f1aa63812bf96..825b6d47535bb4a4c060c1a4f8d69b10fbc4566a 100644 |
| --- a/webrtc/base/network.h |
| +++ b/webrtc/base/network.h |
| @@ -56,6 +56,15 @@ class NetworkManager { |
| public: |
| typedef std::vector<Network*> NetworkList; |
| + // This enum indicates the state of GetNetworks. |
| + enum NetworkPermissionState { |
| + STATE_UNKNOWN, // SignalNetworksChanged is not fired yet. |
| + STATE_ALLOWED, // Adapter enumeration is allowed. Getting 0 network from |
| + // GetNetworks means that there is no network available. |
| + STATE_BLOCKED // Adapter enumeration is disabled. GetAnyAddressNetworks() |
| + // should be used instead. |
|
pthatcher1
2015/08/18 18:34:19
I think a better name might be:
enum EnumerationP
juberti1
2015/08/20 06:31:04
Peter, we (and Chrome) use old-style enum macros e
pthatcher1
2015/08/20 06:43:37
We switched back to old-style enums? I wasn't awa
|
| + }; |
| + |
| NetworkManager(); |
| virtual ~NetworkManager(); |
| @@ -73,12 +82,15 @@ class NetworkManager { |
| virtual void StopUpdating() = 0; |
| // Returns the current list of networks available on this machine. |
| - // UpdateNetworks() must be called before this method is called. |
| + // StartUpdating() must be called before this method is called. |
| // It makes sure that repeated calls return the same object for a |
| // given network, so that quality is tracked appropriately. Does not |
| // include ignored networks. |
| virtual void GetNetworks(NetworkList* networks) const = 0; |
|
pthatcher1
2015/08/18 18:34:20
We might consider calling this EnumerateNetworks.
|
| + // return the current permission state of GetNetworks() |
| + virtual NetworkPermissionState network_permission_state() const = 0; |
|
pthatcher1
2015/08/18 18:34:19
enumeration_permission() would work well here as a
|
| + |
| // "AnyAddressNetwork" is a network which only contains single "any address" |
| // IP address. (i.e. INADDR_ANY for IPv4 or in6addr_any for IPv6). This is |
| // useful as binding to such interfaces allow default routing behavior like |
| @@ -113,6 +125,8 @@ class NetworkManagerBase : public NetworkManager { |
| void set_max_ipv6_networks(int networks) { max_ipv6_networks_ = networks; } |
| int max_ipv6_networks() { return max_ipv6_networks_; } |
| + NetworkPermissionState network_permission_state() const override; |
| + |
| protected: |
| typedef std::map<std::string, Network*> NetworkMap; |
| // Updates |networks_| with the networks listed in |list|. If |
| @@ -127,10 +141,16 @@ class NetworkManagerBase : public NetworkManager { |
| bool* changed, |
| NetworkManager::Stats* stats); |
| + void set_network_permission_state(NetworkPermissionState state) { |
| + network_permission_state_ = state; |
| + } |
| + |
| private: |
| friend class NetworkTest; |
| void DoUpdateNetworks(); |
| + NetworkPermissionState network_permission_state_; |
| + |
| NetworkList networks_; |
| int max_ipv6_networks_; |