diff options
author | Dees_Troy <dees_troy@teamw.in> | 2012-09-19 22:18:00 +0200 |
---|---|---|
committer | Dees_Troy <dees_troy@teamw.in> | 2012-09-19 22:18:21 +0200 |
commit | e2920fa237cb0b69b82838e4c453ac7af48f7e48 (patch) | |
tree | 7993640d3d6fb4eca75c197963651813d3a0b9e3 /gui | |
parent | Improve adb sideload - use storage vs tmp (diff) | |
download | android_bootable_recovery-e2920fa237cb0b69b82838e4c453ac7af48f7e48.tar android_bootable_recovery-e2920fa237cb0b69b82838e4c453ac7af48f7e48.tar.gz android_bootable_recovery-e2920fa237cb0b69b82838e4c453ac7af48f7e48.tar.bz2 android_bootable_recovery-e2920fa237cb0b69b82838e4c453ac7af48f7e48.tar.lz android_bootable_recovery-e2920fa237cb0b69b82838e4c453ac7af48f7e48.tar.xz android_bootable_recovery-e2920fa237cb0b69b82838e4c453ac7af48f7e48.tar.zst android_bootable_recovery-e2920fa237cb0b69b82838e4c453ac7af48f7e48.zip |
Diffstat (limited to '')
-rw-r--r-- | gui/Android.mk | 3 | ||||
-rw-r--r-- | gui/action.cpp | 26 |
2 files changed, 29 insertions, 0 deletions
diff --git a/gui/Android.mk b/gui/Android.mk index a19a63ec2..86d7453b8 100644 --- a/gui/Android.mk +++ b/gui/Android.mk @@ -43,6 +43,9 @@ endif ifneq ($(RECOVERY_SDCARD_ON_DATA),) LOCAL_CFLAGS += -DRECOVERY_SDCARD_ON_DATA endif +ifneq ($(TW_EXTERNAL_STORAGE_PATH),) + LOCAL_CFLAGS += -DTW_EXTERNAL_STORAGE_PATH=$(TW_EXTERNAL_STORAGE_PATH) +endif LOCAL_C_INCLUDES += bionic external/stlport/stlport $(commands_recovery_local_path)/gui/devices/$(DEVICE_RESOLUTION) diff --git a/gui/action.cpp b/gui/action.cpp index 15180ca06..bbcca23f5 100644 --- a/gui/action.cpp +++ b/gui/action.cpp @@ -540,11 +540,37 @@ int GUIAction::doAction(Action action, int isThreaded /* = 0 */) } if (PartitionManager.Mount_Current_Storage(true)) { if (arg == "internal") { + string zip_path, zip_root; + DataManager::GetValue(TW_ZIP_INTERNAL_VAR, zip_path); + zip_root = TWFunc::Get_Root_Path(zip_path); +#ifdef RECOVERY_SDCARD_ON_DATA + #ifndef TW_EXTERNAL_STORAGE_PATH + if (zip_root != "/sdcard") + DataManager::SetValue(TW_ZIP_INTERNAL_VAR, "/sdcard"); + #else + if (strcmp(EXPAND(TW_EXTERNAL_STORAGE_PATH), "/sdcard") == 0) { + if (zip_root != "/emmc") + DataManager::SetValue(TW_ZIP_INTERNAL_VAR, "/emmc"); + } else { + if (zip_root != "/sdcard") + DataManager::SetValue(TW_ZIP_INTERNAL_VAR, "/sdcard"); + } + #endif +#else + if (zip_root != DataManager::GetCurrentStoragePath()) + DataManager::SetValue(TW_ZIP_LOCATION_VAR, DataManager::GetCurrentStoragePath()); +#endif // Save the current zip location to the external variable DataManager::SetValue(TW_ZIP_EXTERNAL_VAR, DataManager::GetStrValue(TW_ZIP_LOCATION_VAR)); // Change the current zip location to the internal variable DataManager::SetValue(TW_ZIP_LOCATION_VAR, DataManager::GetStrValue(TW_ZIP_INTERNAL_VAR)); } else if (arg == "external") { + string zip_path, zip_root; + DataManager::GetValue(TW_ZIP_EXTERNAL_VAR, zip_path); + zip_root = TWFunc::Get_Root_Path(zip_path); + if (zip_root != DataManager::GetCurrentStoragePath()) { + DataManager::SetValue(TW_ZIP_EXTERNAL_VAR, DataManager::GetCurrentStoragePath()); + } // Save the current zip location to the internal variable DataManager::SetValue(TW_ZIP_INTERNAL_VAR, DataManager::GetStrValue(TW_ZIP_LOCATION_VAR)); // Change the current zip location to the external variable |