diff options
author | Tao Bao <tbao@google.com> | 2016-12-09 20:54:08 +0100 |
---|---|---|
committer | android-build-merger <android-build-merger@google.com> | 2016-12-09 20:54:08 +0100 |
commit | 6be6680109b7c0615753e3cf4da77f869c132829 (patch) | |
tree | 2154d1b1f5ca329134ff5e806d9522496296a077 | |
parent | Merge "recovery: Clean up get_args()." (diff) | |
parent | Merge "recovery: Fix the argument parsing from COMMAND_FILE." (diff) | |
download | android_bootable_recovery-6be6680109b7c0615753e3cf4da77f869c132829.tar android_bootable_recovery-6be6680109b7c0615753e3cf4da77f869c132829.tar.gz android_bootable_recovery-6be6680109b7c0615753e3cf4da77f869c132829.tar.bz2 android_bootable_recovery-6be6680109b7c0615753e3cf4da77f869c132829.tar.lz android_bootable_recovery-6be6680109b7c0615753e3cf4da77f869c132829.tar.xz android_bootable_recovery-6be6680109b7c0615753e3cf4da77f869c132829.tar.zst android_bootable_recovery-6be6680109b7c0615753e3cf4da77f869c132829.zip |
-rw-r--r-- | recovery.cpp | 7 |
1 files changed, 5 insertions, 2 deletions
diff --git a/recovery.cpp b/recovery.cpp index 5f1607553..e16f28c72 100644 --- a/recovery.cpp +++ b/recovery.cpp @@ -350,9 +350,12 @@ static std::vector<std::string> get_args(const int argc, char** const argv) { // --- if that doesn't work, try the command file (if we have /cache). if (argc == 1 && has_cache) { std::string content; - if (android::base::ReadFileToString(COMMAND_FILE, &content)) { + if (ensure_path_mounted(COMMAND_FILE) == 0 && + android::base::ReadFileToString(COMMAND_FILE, &content)) { std::vector<std::string> tokens = android::base::Split(content, "\n"); - for (auto it = tokens.begin() + 1; it != tokens.end(); it++) { + // All the arguments in COMMAND_FILE are needed (unlike the BCB message, + // COMMAND_FILE doesn't use filename as the first argument). + for (auto it = tokens.begin(); it != tokens.end(); it++) { // Skip empty and '\0'-filled tokens. if (!it->empty() && (*it)[0] != '\0') args.push_back(std::move(*it)); } |