mirror of
				https://github.com/fankes/termux-app.git
				synced 2025-10-23 12:19:21 +08:00 
			
		
		
		
	Fix cases where bootstrap was not reinstalled even if PREFIX was broken
The TermuxInstaller.setupBootstrapIfNeeded() previously only checked if PREFIX directory existed or not to decide whether to install bootstrap or not. Now it will also check if its empty or only contains the tmp directory, since in that case the PREFIX must be deleted and bootstrap reinstalled, otherwise a broken environment will be loaded since no termux binaries/libs would exist. It will now also delete any file at the prefix or staging prefix path, even if its not a directory. If the user does not want the bootstrap to be installed for some reason, then any other file other than "tmp" can be created under PREFIX.
This commit is contained in:
		| @@ -62,10 +62,21 @@ final class TermuxInstaller { | ||||
|             return; | ||||
|         } | ||||
|  | ||||
|         final String PREFIX_FILE_PATH = TermuxConstants.TERMUX_PREFIX_DIR_PATH; | ||||
|         final File PREFIX_FILE = TermuxConstants.TERMUX_PREFIX_DIR; | ||||
|         if (PREFIX_FILE.isDirectory()) { | ||||
|             whenDone.run(); | ||||
|             return; | ||||
|  | ||||
|         // If prefix directory exists | ||||
|         if (FileUtils.directoryFileExists(PREFIX_FILE_PATH, false)) { | ||||
|              File[] PREFIX_FILE_LIST =  PREFIX_FILE.listFiles(); | ||||
|             // If prefix directory is empty or only contains the tmp directory | ||||
|              if(PREFIX_FILE_LIST == null || PREFIX_FILE_LIST.length == 0 || (PREFIX_FILE_LIST.length == 1 && TermuxConstants.TERMUX_TMP_PREFIX_DIR_PATH.equals(PREFIX_FILE_LIST[0].getAbsolutePath()))) { | ||||
|                  Logger.logInfo(LOG_TAG, "The prefix directory \"" + PREFIX_FILE_PATH + "\" exists but is empty or only contains the tmp directory."); | ||||
|              } else { | ||||
|                  whenDone.run(); | ||||
|                  return; | ||||
|              } | ||||
|         } else if (FileUtils.fileExists(PREFIX_FILE_PATH, false)) { | ||||
|             Logger.logInfo(LOG_TAG, "The prefix directory \"" + PREFIX_FILE_PATH + "\" does not exist but another file exists at its destination."); | ||||
|         } | ||||
|  | ||||
|         final ProgressDialog progress = ProgressDialog.show(activity, null, activity.getString(R.string.bootstrap_installer_body), true, false); | ||||
| @@ -80,12 +91,19 @@ final class TermuxInstaller { | ||||
|                     final String STAGING_PREFIX_PATH = TermuxConstants.TERMUX_STAGING_PREFIX_DIR_PATH; | ||||
|                     final File STAGING_PREFIX_FILE = new File(STAGING_PREFIX_PATH); | ||||
|  | ||||
|                     errmsg = FileUtils.clearDirectory(activity, "prefix staging directory", STAGING_PREFIX_PATH); | ||||
|                     // Delete prefix staging directory or any file at its destination | ||||
|                     errmsg = FileUtils.deleteFile(activity, "prefix staging directory", STAGING_PREFIX_PATH, true); | ||||
|                     if (errmsg != null) { | ||||
|                         throw new RuntimeException(errmsg); | ||||
|                     } | ||||
|  | ||||
|                     Logger.logInfo(LOG_TAG, "Extracting bootstrap zip to prefix staging directory \"" + TermuxConstants.TERMUX_STAGING_PREFIX_DIR_PATH + "\"."); | ||||
|                     // Delete prefix directory or any file at its destination | ||||
|                     errmsg = FileUtils.deleteFile(activity, "prefix directory", PREFIX_FILE_PATH, true); | ||||
|                     if (errmsg != null) { | ||||
|                         throw new RuntimeException(errmsg); | ||||
|                     } | ||||
|  | ||||
|                     Logger.logInfo(LOG_TAG, "Extracting bootstrap zip to prefix staging directory \"" + STAGING_PREFIX_PATH + "\"."); | ||||
|  | ||||
|                     final byte[] buffer = new byte[8096]; | ||||
|                     final List<Pair<String, String>> symlinks = new ArrayList<>(50); | ||||
|   | ||||
		Reference in New Issue
	
	Block a user