diff options
author | Tao Bao <tbao@google.com> | 2019-10-07 17:37:00 +0200 |
---|---|---|
committer | android-build-merger <android-build-merger@google.com> | 2019-10-07 17:37:00 +0200 |
commit | 58b5a5a5500fe9cd6f5ca2bced59fc19885269fa (patch) | |
tree | 3a9222aa6884312558b4d88f3f3814613f208134 | |
parent | Merge "Moving recovery resources from /system to /vendor" (diff) | |
parent | Merge "minadbd: Return battery level via getprop." (diff) | |
download | android_bootable_recovery-58b5a5a5500fe9cd6f5ca2bced59fc19885269fa.tar android_bootable_recovery-58b5a5a5500fe9cd6f5ca2bced59fc19885269fa.tar.gz android_bootable_recovery-58b5a5a5500fe9cd6f5ca2bced59fc19885269fa.tar.bz2 android_bootable_recovery-58b5a5a5500fe9cd6f5ca2bced59fc19885269fa.tar.lz android_bootable_recovery-58b5a5a5500fe9cd6f5ca2bced59fc19885269fa.tar.xz android_bootable_recovery-58b5a5a5500fe9cd6f5ca2bced59fc19885269fa.tar.zst android_bootable_recovery-58b5a5a5500fe9cd6f5ca2bced59fc19885269fa.zip |
-rw-r--r-- | minadbd/Android.bp | 4 | ||||
-rw-r--r-- | minadbd/minadbd_services.cpp | 18 | ||||
-rw-r--r-- | recovery_utils/Android.bp | 1 |
3 files changed, 21 insertions, 2 deletions
diff --git a/minadbd/Android.bp b/minadbd/Android.bp index 071712599..b7075e670 100644 --- a/minadbd/Android.bp +++ b/minadbd/Android.bp @@ -40,6 +40,7 @@ cc_library { defaults: [ "minadbd_defaults", + "librecovery_utils_defaults", ], srcs: [ @@ -48,6 +49,7 @@ cc_library { ], static_libs: [ + "librecovery_utils", "libotautil", ], @@ -97,6 +99,7 @@ cc_test { defaults: [ "minadbd_defaults", + "librecovery_utils_defaults", ], srcs: [ @@ -107,6 +110,7 @@ cc_test { static_libs: [ "libminadbd_services", "libfusesideload", + "librecovery_utils", "libotautil", "libadbd", ], diff --git a/minadbd/minadbd_services.cpp b/minadbd/minadbd_services.cpp index cabcdaa09..eb91fb3e4 100644 --- a/minadbd/minadbd_services.cpp +++ b/minadbd/minadbd_services.cpp @@ -44,6 +44,7 @@ #include "fuse_adb_provider.h" #include "fuse_sideload.h" #include "minadbd/types.h" +#include "recovery_utils/battery_utils.h" #include "services.h" #include "sysdeps.h" @@ -160,7 +161,10 @@ static void RescueInstallHostService(unique_fd sfd, const std::string& args) { // If given an empty string, dumps all the supported properties (analogous to `adb shell getprop`) // in lines, e.g. "[prop]: [value]". static void RescueGetpropHostService(unique_fd sfd, const std::string& prop) { + constexpr const char* kRescueBatteryLevelProp = "rescue.battery_level"; static const std::set<std::string> kGetpropAllowedProps = { + // clang-format off + kRescueBatteryLevelProp, "ro.build.date.utc", "ro.build.fingerprint", "ro.build.flavor", @@ -170,18 +174,28 @@ static void RescueGetpropHostService(unique_fd sfd, const std::string& prop) { "ro.build.version.incremental", "ro.product.device", "ro.product.vendor.device", + // clang-format on }; + + auto query_prop = [](const std::string& key) { + if (key == kRescueBatteryLevelProp) { + auto battery_info = GetBatteryInfo(); + return std::to_string(battery_info.capacity); + } + return android::base::GetProperty(key, ""); + }; + std::string result; if (prop.empty()) { for (const auto& key : kGetpropAllowedProps) { - auto value = android::base::GetProperty(key, ""); + auto value = query_prop(key); if (value.empty()) { continue; } result += "[" + key + "]: [" + value + "]\n"; } } else if (kGetpropAllowedProps.find(prop) != kGetpropAllowedProps.end()) { - result = android::base::GetProperty(prop, "") + "\n"; + result = query_prop(prop) + "\n"; } if (result.empty()) { result = "\n"; diff --git a/recovery_utils/Android.bp b/recovery_utils/Android.bp index 1f4221757..bf79a2e87 100644 --- a/recovery_utils/Android.bp +++ b/recovery_utils/Android.bp @@ -75,6 +75,7 @@ cc_library_static { visibility: [ "//bootable/recovery", "//bootable/recovery/install", + "//bootable/recovery/minadbd", "//bootable/recovery/tests", ], } |