resolve merge conflicts of a4398c1 to stage-aosp-master

Change-Id: I550d5716bd5879f779d11509366090bf508731e4
This commit is contained in:
Elliott Hughes 2016-10-13 19:04:07 -07:00
commit 195669febc
9 changed files with 94 additions and 51 deletions

View File

@ -21,13 +21,15 @@
#include <stdlib.h> #include <stdlib.h>
#include <limits> #include <limits>
#include <string>
namespace android { namespace android {
namespace base { namespace base {
// Parses the unsigned decimal integer in the string 's' and sets 'out' to // Parses the unsigned decimal integer in the string 's' and sets 'out' to
// that value. Optionally allows the caller to define a 'max' beyond which // that value. Optionally allows the caller to define a 'max' beyond which
// otherwise valid values will be rejected. Returns boolean success. // otherwise valid values will be rejected. Returns boolean success; 'out'
// is untouched if parsing fails.
template <typename T> template <typename T>
bool ParseUint(const char* s, T* out, bool ParseUint(const char* s, T* out,
T max = std::numeric_limits<T>::max()) { T max = std::numeric_limits<T>::max()) {
@ -45,10 +47,17 @@ bool ParseUint(const char* s, T* out,
return true; return true;
} }
// TODO: string_view
template <typename T>
bool ParseUint(const std::string& s, T* out,
T max = std::numeric_limits<T>::max()) {
return ParseUint(s.c_str(), out, max);
}
// Parses the signed decimal integer in the string 's' and sets 'out' to // Parses the signed decimal integer in the string 's' and sets 'out' to
// that value. Optionally allows the caller to define a 'min' and 'max // that value. Optionally allows the caller to define a 'min' and 'max
// beyond which otherwise valid values will be rejected. Returns boolean // beyond which otherwise valid values will be rejected. Returns boolean
// success. // success; 'out' is untouched if parsing fails.
template <typename T> template <typename T>
bool ParseInt(const char* s, T* out, bool ParseInt(const char* s, T* out,
T min = std::numeric_limits<T>::min(), T min = std::numeric_limits<T>::min(),
@ -67,6 +76,14 @@ bool ParseInt(const char* s, T* out,
return true; return true;
} }
// TODO: string_view
template <typename T>
bool ParseInt(const std::string& s, T* out,
T min = std::numeric_limits<T>::min(),
T max = std::numeric_limits<T>::max()) {
return ParseInt(s.c_str(), out, min, max);
}
} // namespace base } // namespace base
} // namespace android } // namespace android

View File

@ -19,7 +19,7 @@
#include <gtest/gtest.h> #include <gtest/gtest.h>
TEST(parseint, signed_smoke) { TEST(parseint, signed_smoke) {
int i; int i = 0;
ASSERT_FALSE(android::base::ParseInt("x", &i)); ASSERT_FALSE(android::base::ParseInt("x", &i));
ASSERT_FALSE(android::base::ParseInt("123x", &i)); ASSERT_FALSE(android::base::ParseInt("123x", &i));
@ -28,7 +28,7 @@ TEST(parseint, signed_smoke) {
ASSERT_TRUE(android::base::ParseInt("-123", &i)); ASSERT_TRUE(android::base::ParseInt("-123", &i));
ASSERT_EQ(-123, i); ASSERT_EQ(-123, i);
short s; short s = 0;
ASSERT_TRUE(android::base::ParseInt("1234", &s)); ASSERT_TRUE(android::base::ParseInt("1234", &s));
ASSERT_EQ(1234, s); ASSERT_EQ(1234, s);
@ -39,7 +39,7 @@ TEST(parseint, signed_smoke) {
} }
TEST(parseint, unsigned_smoke) { TEST(parseint, unsigned_smoke) {
unsigned int i; unsigned int i = 0u;
ASSERT_FALSE(android::base::ParseUint("x", &i)); ASSERT_FALSE(android::base::ParseUint("x", &i));
ASSERT_FALSE(android::base::ParseUint("123x", &i)); ASSERT_FALSE(android::base::ParseUint("123x", &i));
@ -47,7 +47,7 @@ TEST(parseint, unsigned_smoke) {
ASSERT_EQ(123u, i); ASSERT_EQ(123u, i);
ASSERT_FALSE(android::base::ParseUint("-123", &i)); ASSERT_FALSE(android::base::ParseUint("-123", &i));
unsigned short s; unsigned short s = 0u;
ASSERT_TRUE(android::base::ParseUint("1234", &s)); ASSERT_TRUE(android::base::ParseUint("1234", &s));
ASSERT_EQ(1234u, s); ASSERT_EQ(1234u, s);
@ -58,21 +58,41 @@ TEST(parseint, unsigned_smoke) {
} }
TEST(parseint, no_implicit_octal) { TEST(parseint, no_implicit_octal) {
int i; int i = 0;
ASSERT_TRUE(android::base::ParseInt("0123", &i)); ASSERT_TRUE(android::base::ParseInt("0123", &i));
ASSERT_EQ(123, i); ASSERT_EQ(123, i);
unsigned int u; unsigned int u = 0u;
ASSERT_TRUE(android::base::ParseUint("0123", &u)); ASSERT_TRUE(android::base::ParseUint("0123", &u));
ASSERT_EQ(123u, u); ASSERT_EQ(123u, u);
} }
TEST(parseint, explicit_hex) { TEST(parseint, explicit_hex) {
int i; int i = 0;
ASSERT_TRUE(android::base::ParseInt("0x123", &i)); ASSERT_TRUE(android::base::ParseInt("0x123", &i));
ASSERT_EQ(0x123, i); ASSERT_EQ(0x123, i);
unsigned int u; unsigned int u = 0u;
ASSERT_TRUE(android::base::ParseUint("0x123", &u)); ASSERT_TRUE(android::base::ParseUint("0x123", &u));
ASSERT_EQ(0x123u, u); ASSERT_EQ(0x123u, u);
} }
TEST(parseint, string) {
int i = 0;
ASSERT_TRUE(android::base::ParseInt(std::string("123"), &i));
ASSERT_EQ(123, i);
unsigned int u = 0u;
ASSERT_TRUE(android::base::ParseUint(std::string("123"), &u));
ASSERT_EQ(123u, u);
}
TEST(parseint, untouched_on_failure) {
int i = 123;
ASSERT_FALSE(android::base::ParseInt("456x", &i));
ASSERT_EQ(123, i);
unsigned int u = 123u;
ASSERT_FALSE(android::base::ParseInt("456x", &u));
ASSERT_EQ(123u, u);
}

View File

@ -52,7 +52,7 @@ template <typename T>
T GetIntProperty(const std::string& key, T default_value, T min, T max) { T GetIntProperty(const std::string& key, T default_value, T min, T max) {
T result; T result;
std::string value = GetProperty(key, ""); std::string value = GetProperty(key, "");
if (!value.empty() && android::base::ParseInt(value.c_str(), &result, min, max)) return result; if (!value.empty() && android::base::ParseInt(value, &result, min, max)) return result;
return default_value; return default_value;
} }
@ -60,7 +60,7 @@ template <typename T>
T GetUintProperty(const std::string& key, T default_value, T max) { T GetUintProperty(const std::string& key, T default_value, T max) {
T result; T result;
std::string value = GetProperty(key, ""); std::string value = GetProperty(key, "");
if (!value.empty() && android::base::ParseUint(value.c_str(), &result, max)) return result; if (!value.empty() && android::base::ParseUint(value, &result, max)) return result;
return default_value; return default_value;
} }

View File

@ -59,7 +59,7 @@ bool ParseRecordEventTime(const std::string& path, int32_t* uptime) {
// Ignore existing bootstat records (which do not contain file content). // Ignore existing bootstat records (which do not contain file content).
if (!content.empty()) { if (!content.empty()) {
int32_t value; int32_t value;
if (android::base::ParseInt(content.c_str(), &value)) { if (android::base::ParseInt(content, &value)) {
bootstat::LogHistogram("bootstat_mtime_matches_content", value == *uptime); bootstat::LogHistogram("bootstat_mtime_matches_content", value == *uptime);
} }
} }

View File

@ -60,7 +60,7 @@ void RecordBootEventFromCommandLine(
BootEventRecordStore boot_event_store; BootEventRecordStore boot_event_store;
if (!value_str.empty()) { if (!value_str.empty()) {
int32_t value = 0; int32_t value = 0;
if (android::base::ParseInt(value_str.c_str(), &value)) { if (android::base::ParseInt(value_str, &value)) {
boot_event_store.AddBootEventWithValue(event, value); boot_event_store.AddBootEventWithValue(event, value);
} }
} else { } else {
@ -193,7 +193,7 @@ std::string CalculateBootCompletePrefix() {
std::string build_date_str = GetProperty("ro.build.date.utc"); std::string build_date_str = GetProperty("ro.build.date.utc");
int32_t build_date; int32_t build_date;
if (!android::base::ParseInt(build_date_str.c_str(), &build_date)) { if (!android::base::ParseInt(build_date_str, &build_date)) {
return std::string(); return std::string();
} }

View File

@ -755,7 +755,7 @@ static int64_t get_target_sparse_limit(Transport* transport) {
max_download_size = android::base::Trim(max_download_size); max_download_size = android::base::Trim(max_download_size);
uint64_t limit; uint64_t limit;
if (!android::base::ParseUint(max_download_size.c_str(), &limit)) { if (!android::base::ParseUint(max_download_size, &limit)) {
fprintf(stderr, "couldn't parse max-download-size '%s'\n", max_download_size.c_str()); fprintf(stderr, "couldn't parse max-download-size '%s'\n", max_download_size.c_str());
return 0; return 0;
} }
@ -903,7 +903,7 @@ static int get_slot_count(Transport* transport) {
if (!fb_getvar(transport, "slot-count", &var)) { if (!fb_getvar(transport, "slot-count", &var)) {
if (supports_AB_obsolete(transport)) return 2; // Legacy support if (supports_AB_obsolete(transport)) return 2; // Legacy support
} }
if (!android::base::ParseInt(var.c_str(), &count)) return 0; if (!android::base::ParseInt(var, &count)) return 0;
return count; return count;
} }
@ -1362,7 +1362,7 @@ static void fb_perform_format(Transport* transport,
} }
int64_t size; int64_t size;
if (!android::base::ParseInt(partition_size.c_str(), &size)) { if (!android::base::ParseInt(partition_size, &size)) {
fprintf(stderr, "Couldn't parse partition size '%s'.\n", partition_size.c_str()); fprintf(stderr, "Couldn't parse partition size '%s'.\n", partition_size.c_str());
return; return;
} }

View File

@ -29,6 +29,7 @@
#include <memory> #include <memory>
#include <android-base/file.h> #include <android-base/file.h>
#include <android-base/parseint.h>
#include <android-base/strings.h> #include <android-base/strings.h>
#include <batteryservice/BatteryService.h> #include <batteryservice/BatteryService.h>
#include <cutils/klog.h> #include <cutils/klog.h>
@ -182,7 +183,7 @@ int BatteryMonitor::getIntField(const String8& path) {
int value = 0; int value = 0;
if (readFromFile(path, &buf) > 0) if (readFromFile(path, &buf) > 0)
value = std::stoi(buf.c_str(), NULL, 0); android::base::ParseInt(buf, &value);
return value; return value;
} }

View File

@ -304,7 +304,7 @@ static int do_mkdir(const std::vector<std::string>& args) {
/* mkdir <path> [mode] [owner] [group] */ /* mkdir <path> [mode] [owner] [group] */
if (args.size() >= 3) { if (args.size() >= 3) {
mode = std::stoul(args[2], 0, 8); mode = std::strtoul(args[2].c_str(), 0, 8);
} }
ret = make_dir(args[1].c_str(), mode); ret = make_dir(args[1].c_str(), mode);
@ -637,10 +637,13 @@ static int do_setprop(const std::vector<std::string>& args) {
static int do_setrlimit(const std::vector<std::string>& args) { static int do_setrlimit(const std::vector<std::string>& args) {
struct rlimit limit; struct rlimit limit;
int resource; int resource;
resource = std::stoi(args[1]); if (android::base::ParseInt(args[1], &resource) &&
limit.rlim_cur = std::stoi(args[2]); android::base::ParseUint(args[2], &limit.rlim_cur) &&
limit.rlim_max = std::stoi(args[3]); android::base::ParseUint(args[3], &limit.rlim_max)) {
return setrlimit(resource, &limit); return setrlimit(resource, &limit);
}
LOG(WARNING) << "ignoring setrlimit " << args[1] << " " << args[2] << " " << args[3];
return -1;
} }
static int do_start(const std::vector<std::string>& args) { static int do_start(const std::vector<std::string>& args) {
@ -709,7 +712,7 @@ static int do_powerctl(const std::vector<std::string>& args) {
std::string timeout = property_get("ro.build.shutdown_timeout"); std::string timeout = property_get("ro.build.shutdown_timeout");
unsigned int delay = 0; unsigned int delay = 0;
if (android::base::ParseUint(timeout.c_str(), &delay) && delay > 0) { if (android::base::ParseUint(timeout, &delay) && delay > 0) {
Timer t; Timer t;
// Ask all services to terminate. // Ask all services to terminate.
ServiceManager::GetInstance().ForEachService( ServiceManager::GetInstance().ForEachService(
@ -764,13 +767,11 @@ static int do_rmdir(const std::vector<std::string>& args) {
} }
static int do_sysclktz(const std::vector<std::string>& args) { static int do_sysclktz(const std::vector<std::string>& args) {
struct timezone tz; struct timezone tz = {};
if (android::base::ParseInt(args[1], &tz.tz_minuteswest) && settimeofday(NULL, &tz) != -1) {
memset(&tz, 0, sizeof(tz)); return 0;
tz.tz_minuteswest = std::stoi(args[1]); }
if (settimeofday(NULL, &tz)) return -1;
return -1;
return 0;
} }
static int do_verity_load_state(const std::vector<std::string>& args) { static int do_verity_load_state(const std::vector<std::string>& args) {
@ -914,7 +915,8 @@ static int do_restorecon_recursive(const std::vector<std::string>& args) {
static int do_loglevel(const std::vector<std::string>& args) { static int do_loglevel(const std::vector<std::string>& args) {
// TODO: support names instead/as well? // TODO: support names instead/as well?
int log_level = std::stoi(args[1]); int log_level = -1;
android::base::ParseInt(args[1], &log_level);
android::base::LogSeverity severity; android::base::LogSeverity severity;
switch (log_level) { switch (log_level) {
case 7: severity = android::base::DEBUG; break; case 7: severity = android::base::DEBUG; break;
@ -947,9 +949,12 @@ static int do_wait(const std::vector<std::string>& args) {
if (args.size() == 2) { if (args.size() == 2) {
return wait_for_file(args[1].c_str(), COMMAND_RETRY_TIMEOUT); return wait_for_file(args[1].c_str(), COMMAND_RETRY_TIMEOUT);
} else if (args.size() == 3) { } else if (args.size() == 3) {
return wait_for_file(args[1].c_str(), std::stoi(args[2])); int timeout;
} else if (android::base::ParseInt(args[2], &timeout)) {
return -1; return wait_for_file(args[1].c_str(), timeout);
}
}
return -1;
} }
/* /*

View File

@ -31,6 +31,7 @@
#include <selinux/selinux.h> #include <selinux/selinux.h>
#include <android-base/file.h> #include <android-base/file.h>
#include <android-base/parseint.h>
#include <android-base/stringprintf.h> #include <android-base/stringprintf.h>
#include <android-base/strings.h> #include <android-base/strings.h>
#include <cutils/android_reboot.h> #include <cutils/android_reboot.h>
@ -46,6 +47,7 @@
#include "property_service.h" #include "property_service.h"
#include "util.h" #include "util.h"
using android::base::ParseInt;
using android::base::StringPrintf; using android::base::StringPrintf;
using android::base::WriteStringToFile; using android::base::WriteStringToFile;
@ -351,22 +353,19 @@ bool Service::ParseGroup(const std::vector<std::string>& args, std::string* err)
} }
bool Service::ParsePriority(const std::vector<std::string>& args, std::string* err) { bool Service::ParsePriority(const std::vector<std::string>& args, std::string* err) {
priority_ = std::stoi(args[1]); priority_ = 0;
if (!ParseInt(args[1], &priority_,
if (priority_ < ANDROID_PRIORITY_HIGHEST || priority_ > ANDROID_PRIORITY_LOWEST) { static_cast<int>(ANDROID_PRIORITY_LOWEST),
priority_ = 0; static_cast<int>(ANDROID_PRIORITY_HIGHEST))) {
*err = StringPrintf("process priority value must be range %d - %d", *err = StringPrintf("process priority value must be range %d - %d",
ANDROID_PRIORITY_HIGHEST, ANDROID_PRIORITY_LOWEST); ANDROID_PRIORITY_HIGHEST, ANDROID_PRIORITY_LOWEST);
return false; return false;
} }
return true; return true;
} }
bool Service::ParseIoprio(const std::vector<std::string>& args, std::string* err) { bool Service::ParseIoprio(const std::vector<std::string>& args, std::string* err) {
ioprio_pri_ = std::stoul(args[2], 0, 8); if (!ParseInt(args[2], &ioprio_pri_, 0, 7)) {
if (ioprio_pri_ < 0 || ioprio_pri_ > 7) {
*err = "priority value must be range 0 - 7"; *err = "priority value must be range 0 - 7";
return false; return false;
} }
@ -387,7 +386,12 @@ bool Service::ParseIoprio(const std::vector<std::string>& args, std::string* err
bool Service::ParseKeycodes(const std::vector<std::string>& args, std::string* err) { bool Service::ParseKeycodes(const std::vector<std::string>& args, std::string* err) {
for (std::size_t i = 1; i < args.size(); i++) { for (std::size_t i = 1; i < args.size(); i++) {
keycodes_.emplace_back(std::stoi(args[i])); int code;
if (ParseInt(args[i], &code)) {
keycodes_.emplace_back(code);
} else {
LOG(WARNING) << "ignoring invalid keycode: " << args[i];
}
} }
return true; return true;
} }
@ -420,17 +424,13 @@ bool Service::ParseNamespace(const std::vector<std::string>& args, std::string*
} }
bool Service::ParseOomScoreAdjust(const std::vector<std::string>& args, std::string* err) { bool Service::ParseOomScoreAdjust(const std::vector<std::string>& args, std::string* err) {
oom_score_adjust_ = std::stol(args[1], 0, 10); if (!ParseInt(args[1], &oom_score_adjust_, -1000, 1000)) {
if (oom_score_adjust_ < -1000 || oom_score_adjust_ > 1000) {
*err = "oom_score_adjust value must be in range -1000 - +1000"; *err = "oom_score_adjust value must be in range -1000 - +1000";
return false; return false;
} }
return true; return true;
} }
bool Service::ParseSeclabel(const std::vector<std::string>& args, std::string* err) { bool Service::ParseSeclabel(const std::vector<std::string>& args, std::string* err) {
seclabel_ = args[1]; seclabel_ = args[1];
return true; return true;
@ -448,7 +448,7 @@ bool Service::ParseSocket(const std::vector<std::string>& args, std::string* err
return false; return false;
} }
int perm = std::stoul(args[3], 0, 8); int perm = std::strtoul(args[3].c_str(), 0, 8);
uid_t uid = args.size() > 4 ? decode_uid(args[4].c_str()) : 0; uid_t uid = args.size() > 4 ? decode_uid(args[4].c_str()) : 0;
gid_t gid = args.size() > 5 ? decode_uid(args[5].c_str()) : 0; gid_t gid = args.size() > 5 ? decode_uid(args[5].c_str()) : 0;
std::string socketcon = args.size() > 6 ? args[6] : ""; std::string socketcon = args.size() > 6 ? args[6] : "";