This source file includes following definitions.
- channel
- PrefixLengthToNetmask
- NetmaskToPrefixLength
- ParseCellularScanResults
#include "chromeos/network/network_util.h"
#include "base/strings/string_tokenizer.h"
#include "base/strings/stringprintf.h"
#include "third_party/cros_system_api/dbus/service_constants.h"
namespace chromeos {
WifiAccessPoint::WifiAccessPoint()
: signal_strength(0),
signal_to_noise(0),
channel(0) {
}
WifiAccessPoint::~WifiAccessPoint() {
}
CellularScanResult::CellularScanResult() {
}
CellularScanResult::~CellularScanResult() {
}
namespace network_util {
std::string PrefixLengthToNetmask(int32 prefix_length) {
std::string netmask;
if (prefix_length < 0 || prefix_length > 32)
return netmask;
for (int i = 0; i < 4; i++) {
int remainder = 8;
if (prefix_length >= 8) {
prefix_length -= 8;
} else {
remainder = prefix_length;
prefix_length = 0;
}
if (i > 0)
netmask += ".";
int value = remainder == 0 ? 0 :
((2L << (remainder - 1)) - 1) << (8 - remainder);
netmask += base::StringPrintf("%d", value);
}
return netmask;
}
int32 NetmaskToPrefixLength(const std::string& netmask) {
int count = 0;
int prefix_length = 0;
base::StringTokenizer t(netmask, ".");
while (t.GetNext()) {
if (count == 4)
return -1;
std::string token = t.token();
if (prefix_length / 8 != count) {
if (token != "0")
return -1;
} else if (token == "255") {
prefix_length += 8;
} else if (token == "254") {
prefix_length += 7;
} else if (token == "252") {
prefix_length += 6;
} else if (token == "248") {
prefix_length += 5;
} else if (token == "240") {
prefix_length += 4;
} else if (token == "224") {
prefix_length += 3;
} else if (token == "192") {
prefix_length += 2;
} else if (token == "128") {
prefix_length += 1;
} else if (token == "0") {
prefix_length += 0;
} else {
return -1;
}
count++;
}
if (count < 4)
return -1;
return prefix_length;
}
bool ParseCellularScanResults(const base::ListValue& list,
std::vector<CellularScanResult>* scan_results) {
scan_results->clear();
scan_results->reserve(list.GetSize());
for (base::ListValue::const_iterator it = list.begin();
it != list.end(); ++it) {
if (!(*it)->IsType(base::Value::TYPE_DICTIONARY))
return false;
CellularScanResult scan_result;
const base::DictionaryValue* dict =
static_cast<const base::DictionaryValue*>(*it);
if (!dict->GetStringWithoutPathExpansion(shill::kNetworkIdProperty,
&scan_result.network_id))
continue;
dict->GetStringWithoutPathExpansion(shill::kStatusProperty,
&scan_result.status);
dict->GetStringWithoutPathExpansion(shill::kLongNameProperty,
&scan_result.long_name);
dict->GetStringWithoutPathExpansion(shill::kShortNameProperty,
&scan_result.short_name);
dict->GetStringWithoutPathExpansion(shill::kTechnologyProperty,
&scan_result.technology);
scan_results->push_back(scan_result);
}
return true;
}
}
}