handle old-style CACHE: packages

Change-Id: I7bf52b56770c207ba1c8329243991b07ebb65779
This commit is contained in:
Doug Zongker 2010-09-22 12:01:37 -07:00
parent 2c3c5c15d1
commit 9b125b04c6

View file

@ -88,7 +88,7 @@ static const char *SIDELOAD_TEMP_DIR = "/tmp/sideload";
* *
* OTA INSTALL * OTA INSTALL
* 1. main system downloads OTA package to /cache/some-filename.zip * 1. main system downloads OTA package to /cache/some-filename.zip
* 2. main system writes "--update_package=CACHE:some-filename.zip" * 2. main system writes "--update_package=/cache/some-filename.zip"
* 3. main system reboots into recovery * 3. main system reboots into recovery
* 4. get_args() writes BCB with "boot-recovery" and "--update_package=..." * 4. get_args() writes BCB with "boot-recovery" and "--update_package=..."
* -- after this, rebooting will attempt to reinstall the update -- * -- after this, rebooting will attempt to reinstall the update --
@ -711,7 +711,23 @@ main(int argc, char **argv) {
for (arg = 0; arg < argc; arg++) { for (arg = 0; arg < argc; arg++) {
printf(" \"%s\"", argv[arg]); printf(" \"%s\"", argv[arg]);
} }
printf("\n\n"); printf("\n");
if (update_package) {
// For backwards compatibility on the cache partition only, if
// we're given an old 'root' path "CACHE:foo", change it to
// "/cache/foo".
if (strncmp(update_package, "CACHE:", 6) == 0) {
int len = strlen(update_package) + 10;
char* modified_path = malloc(len);
strlcpy(modified_path, "/cache/", len);
strlcat(modified_path, update_package+6, len);
printf("(replacing path \"%s\" with \"%s\")\n",
update_package, modified_path);
update_package = modified_path;
}
}
printf("\n");
property_list(print_property, NULL); property_list(print_property, NULL);
printf("\n"); printf("\n");