mirror of
				https://github.com/fankes/termux-app.git
				synced 2025-10-25 21:29:20 +08:00 
			
		
		
		
	Changed!: Rename TermuxTask to AppShell since its not part of termux-app or com.termux.shared.termux package
This commit is contained in:
		| @@ -12,7 +12,7 @@ import com.termux.shared.errors.Error; | ||||
| import com.termux.shared.logger.Logger; | ||||
| import com.termux.shared.markdown.MarkdownUtils; | ||||
| import com.termux.shared.data.DataUtils; | ||||
| import com.termux.shared.shell.command.runner.app.TermuxTask; | ||||
| import com.termux.shared.shell.command.runner.app.AppShell; | ||||
|  | ||||
| import java.util.Collections; | ||||
| import java.util.List; | ||||
| @@ -87,10 +87,10 @@ public class ExecutionCommand { | ||||
|     public boolean isFailsafe; | ||||
|  | ||||
|     /** | ||||
|      * The {@link ExecutionCommand} custom log level for background {@link TermuxTask} | ||||
|      * The {@link ExecutionCommand} custom log level for background {@link AppShell} | ||||
|      * commands. By default, @link com.termux.shared.shell.StreamGobbler} only logs stdout and | ||||
|      * stderr if {@link Logger} `CURRENT_LOG_LEVEL` is >= {@link Logger#LOG_LEVEL_VERBOSE} and | ||||
|      * {@link TermuxTask} only logs stdin if `CURRENT_LOG_LEVEL` is >= | ||||
|      * {@link AppShell} only logs stdin if `CURRENT_LOG_LEVEL` is >= | ||||
|      * {@link Logger#LOG_LEVEL_DEBUG}. | ||||
|      */ | ||||
|     public Integer backgroundCustomLogLevel; | ||||
|   | ||||
| @@ -24,23 +24,23 @@ import java.io.IOException; | ||||
| import java.nio.charset.StandardCharsets; | ||||
| 
 | ||||
| /** | ||||
|  * A class that maintains info for background Termux tasks run with {@link Runtime#exec(String[], String[], File)}. | ||||
|  * A class that maintains info for background app shells run with {@link Runtime#exec(String[], String[], File)}. | ||||
|  * It also provides a way to link each {@link Process} with the {@link ExecutionCommand} | ||||
|  * that started it. | ||||
|  * that started it. The shell is run in the app user context. | ||||
|  */ | ||||
| public final class TermuxTask { | ||||
| public final class AppShell { | ||||
| 
 | ||||
|     private final Process mProcess; | ||||
|     private final ExecutionCommand mExecutionCommand; | ||||
|     private final TermuxTaskClient mTermuxTaskClient; | ||||
|     private final AppShellClient mAppShellClient; | ||||
| 
 | ||||
|     private static final String LOG_TAG = "TermuxTask"; | ||||
|     private static final String LOG_TAG = "AppShell"; | ||||
| 
 | ||||
|     private TermuxTask(@NonNull final Process process, @NonNull final ExecutionCommand executionCommand, | ||||
|                        final TermuxTaskClient termuxTaskClient) { | ||||
|     private AppShell(@NonNull final Process process, @NonNull final ExecutionCommand executionCommand, | ||||
|                      final AppShellClient appShellClient) { | ||||
|         this.mProcess = process; | ||||
|         this.mExecutionCommand = executionCommand; | ||||
|         this.mTermuxTaskClient = termuxTaskClient; | ||||
|         this.mAppShellClient = appShellClient; | ||||
|     } | ||||
| 
 | ||||
|     /** | ||||
| @@ -52,23 +52,23 @@ public final class TermuxTask { | ||||
|      * | ||||
|      * @param context The {@link Context} for operations. | ||||
|      * @param executionCommand The {@link ExecutionCommand} containing the information for execution command. | ||||
|      * @param termuxTaskClient The {@link TermuxTaskClient} interface implementation. | ||||
|      *                           The {@link TermuxTaskClient#onTermuxTaskExited(TermuxTask)} will | ||||
|      * @param appShellClient The {@link AppShellClient} interface implementation. | ||||
|      *                           The {@link AppShellClient#onAppShellExited(AppShell)} will | ||||
|      *                           be called regardless of {@code isSynchronous} value but not if | ||||
|      *                           {@code null} is returned by this method. This can | ||||
|      *                           optionally be {@code null}. | ||||
|      * @param shellEnvironmentClient The {@link ShellEnvironmentClient} interface implementation. | ||||
|      * @param isSynchronous If set to {@code true}, then the command will be executed in the | ||||
|      *                      caller thread and results returned synchronously in the {@link ExecutionCommand} | ||||
|      *                      sub object of the {@link TermuxTask} returned. | ||||
|      *                      sub object of the {@link AppShell} returned. | ||||
|      *                      If set to {@code false}, then a new thread is started run the commands | ||||
|      *                      asynchronously in the background and control is returned to the caller thread. | ||||
|      * @return Returns the {@link TermuxTask}. This will be {@code null} if failed to start the execution command. | ||||
|      * @return Returns the {@link AppShell}. This will be {@code null} if failed to start the execution command. | ||||
|      */ | ||||
|     public static TermuxTask execute(@NonNull final Context context, @NonNull ExecutionCommand executionCommand, | ||||
|                                      final TermuxTaskClient termuxTaskClient, | ||||
|                                      @NonNull final ShellEnvironmentClient shellEnvironmentClient, | ||||
|                                      final boolean isSynchronous) { | ||||
|     public static AppShell execute(@NonNull final Context context, @NonNull ExecutionCommand executionCommand, | ||||
|                                    final AppShellClient appShellClient, | ||||
|                                    @NonNull final ShellEnvironmentClient shellEnvironmentClient, | ||||
|                                    final boolean isSynchronous) { | ||||
|         if (executionCommand.workingDirectory == null || executionCommand.workingDirectory.isEmpty()) | ||||
|             executionCommand.workingDirectory = shellEnvironmentClient.getDefaultWorkingDirectoryPath(); | ||||
|         if (executionCommand.workingDirectory.isEmpty()) | ||||
| @@ -79,8 +79,8 @@ public final class TermuxTask { | ||||
|         final String[] commandArray = shellEnvironmentClient.setupProcessArgs(executionCommand.executable, executionCommand.arguments); | ||||
| 
 | ||||
|         if (!executionCommand.setState(ExecutionState.EXECUTING)) { | ||||
|             executionCommand.setStateFailed(Errno.ERRNO_FAILED.getCode(), context.getString(R.string.error_failed_to_execute_termux_task_command, executionCommand.getCommandIdAndLabelLogString())); | ||||
|             TermuxTask.processTermuxTaskResult(null, executionCommand); | ||||
|             executionCommand.setStateFailed(Errno.ERRNO_FAILED.getCode(), context.getString(R.string.error_failed_to_execute_app_shell_command, executionCommand.getCommandIdAndLabelLogString())); | ||||
|             AppShell.processAppShellResult(null, executionCommand); | ||||
|             return null; | ||||
|         } | ||||
| 
 | ||||
| @@ -98,16 +98,16 @@ public final class TermuxTask { | ||||
|         try { | ||||
|             process = Runtime.getRuntime().exec(commandArray, env, new File(executionCommand.workingDirectory)); | ||||
|         } catch (IOException e) { | ||||
|             executionCommand.setStateFailed(Errno.ERRNO_FAILED.getCode(), context.getString(R.string.error_failed_to_execute_termux_task_command, executionCommand.getCommandIdAndLabelLogString()), e); | ||||
|             TermuxTask.processTermuxTaskResult(null, executionCommand); | ||||
|             executionCommand.setStateFailed(Errno.ERRNO_FAILED.getCode(), context.getString(R.string.error_failed_to_execute_app_shell_command, executionCommand.getCommandIdAndLabelLogString()), e); | ||||
|             AppShell.processAppShellResult(null, executionCommand); | ||||
|             return null; | ||||
|         } | ||||
| 
 | ||||
|         final TermuxTask termuxTask = new TermuxTask(process, executionCommand, termuxTaskClient); | ||||
|         final AppShell appShell = new AppShell(process, executionCommand, appShellClient); | ||||
| 
 | ||||
|         if (isSynchronous) { | ||||
|             try { | ||||
|                 termuxTask.executeInner(context); | ||||
|                 appShell.executeInner(context); | ||||
|             } catch (IllegalThreadStateException | InterruptedException e) { | ||||
|                 // TODO: Should either of these be handled or returned? | ||||
|             } | ||||
| @@ -116,7 +116,7 @@ public final class TermuxTask { | ||||
|                 @Override | ||||
|                 public void run() { | ||||
|                     try { | ||||
|                         termuxTask.executeInner(context); | ||||
|                         appShell.executeInner(context); | ||||
|                     } catch (IllegalThreadStateException | InterruptedException e) { | ||||
|                         // TODO: Should either of these be handled or returned? | ||||
|                     } | ||||
| @@ -124,22 +124,22 @@ public final class TermuxTask { | ||||
|             }.start(); | ||||
|         } | ||||
| 
 | ||||
|         return termuxTask; | ||||
|         return appShell; | ||||
|     } | ||||
| 
 | ||||
|     /** | ||||
|      * Sets up stdout and stderr readers for the {@link #mProcess} and waits for the process to end. | ||||
|      * | ||||
|      * If the processes finishes, then sets {@link ResultData#stdout}, {@link ResultData#stderr} | ||||
|      * and {@link ResultData#exitCode} for the {@link #mExecutionCommand} of the {@code termuxTask} | ||||
|      * and then calls {@link #processTermuxTaskResult(TermuxTask, ExecutionCommand) to process the result}. | ||||
|      * and {@link ResultData#exitCode} for the {@link #mExecutionCommand} of the {@code appShell} | ||||
|      * and then calls {@link #processAppShellResult(AppShell, ExecutionCommand) to process the result}. | ||||
|      * | ||||
|      * @param context The {@link Context} for operations. | ||||
|      */ | ||||
|     private void executeInner(@NonNull final Context context) throws IllegalThreadStateException, InterruptedException { | ||||
|         final int pid = ShellUtils.getPid(mProcess); | ||||
| 
 | ||||
|         Logger.logDebug(LOG_TAG, "Running \"" + mExecutionCommand.getCommandIdAndLabelLogString() + "\" TermuxTask with pid " + pid); | ||||
|         Logger.logDebug(LOG_TAG, "Running \"" + mExecutionCommand.getCommandIdAndLabelLogString() + "\" AppShell with pid " + pid); | ||||
| 
 | ||||
|         mExecutionCommand.resultData.exitCode = null; | ||||
| 
 | ||||
| @@ -168,9 +168,9 @@ public final class TermuxTask { | ||||
|                 } else { | ||||
|                     // other issues we don't know how to handle, leads to | ||||
|                     // returning null | ||||
|                     mExecutionCommand.setStateFailed(Errno.ERRNO_FAILED.getCode(), context.getString(R.string.error_exception_received_while_executing_termux_task_command, mExecutionCommand.getCommandIdAndLabelLogString(), e.getMessage()), e); | ||||
|                     mExecutionCommand.setStateFailed(Errno.ERRNO_FAILED.getCode(), context.getString(R.string.error_exception_received_while_executing_app_shell_command, mExecutionCommand.getCommandIdAndLabelLogString(), e.getMessage()), e); | ||||
|                     mExecutionCommand.resultData.exitCode = 1; | ||||
|                     TermuxTask.processTermuxTaskResult(this, null); | ||||
|                     AppShell.processAppShellResult(this, null); | ||||
|                     kill(); | ||||
|                     return; | ||||
|                 } | ||||
| @@ -196,13 +196,13 @@ public final class TermuxTask { | ||||
| 
 | ||||
|         // Process result | ||||
|         if (exitCode == 0) | ||||
|             Logger.logDebug(LOG_TAG, "The \"" + mExecutionCommand.getCommandIdAndLabelLogString() + "\" TermuxTask with pid " + pid + " exited normally"); | ||||
|             Logger.logDebug(LOG_TAG, "The \"" + mExecutionCommand.getCommandIdAndLabelLogString() + "\" AppShell with pid " + pid + " exited normally"); | ||||
|         else | ||||
|             Logger.logDebug(LOG_TAG, "The \"" + mExecutionCommand.getCommandIdAndLabelLogString() + "\" TermuxTask with pid " + pid + " exited with code: " + exitCode); | ||||
|             Logger.logDebug(LOG_TAG, "The \"" + mExecutionCommand.getCommandIdAndLabelLogString() + "\" AppShell with pid " + pid + " exited with code: " + exitCode); | ||||
| 
 | ||||
|         // If the execution command has already failed, like SIGKILL was sent, then don't continue | ||||
|         if (mExecutionCommand.isStateFailed()) { | ||||
|             Logger.logDebug(LOG_TAG, "Ignoring setting \"" + mExecutionCommand.getCommandIdAndLabelLogString() + "\" TermuxTask state to ExecutionState.EXECUTED and processing results since it has already failed"); | ||||
|             Logger.logDebug(LOG_TAG, "Ignoring setting \"" + mExecutionCommand.getCommandIdAndLabelLogString() + "\" AppShell state to ExecutionState.EXECUTED and processing results since it has already failed"); | ||||
|             return; | ||||
|         } | ||||
| 
 | ||||
| @@ -211,30 +211,30 @@ public final class TermuxTask { | ||||
|         if (!mExecutionCommand.setState(ExecutionState.EXECUTED)) | ||||
|             return; | ||||
| 
 | ||||
|         TermuxTask.processTermuxTaskResult(this, null); | ||||
|         AppShell.processAppShellResult(this, null); | ||||
|     } | ||||
| 
 | ||||
|     /** | ||||
|      * Kill this {@link TermuxTask} by sending a {@link OsConstants#SIGILL} to its {@link #mProcess} | ||||
|      * Kill this {@link AppShell} by sending a {@link OsConstants#SIGILL} to its {@link #mProcess} | ||||
|      * if its still executing. | ||||
|      * | ||||
|      * @param context The {@link Context} for operations. | ||||
|      * @param processResult If set to {@code true}, then the {@link #processTermuxTaskResult(TermuxTask, ExecutionCommand)} | ||||
|      * @param processResult If set to {@code true}, then the {@link #processAppShellResult(AppShell, ExecutionCommand)} | ||||
|      *                      will be called to process the failure. | ||||
|      */ | ||||
|     public void killIfExecuting(@NonNull final Context context, boolean processResult) { | ||||
|         // If execution command has already finished executing, then no need to process results or send SIGKILL | ||||
|         if (mExecutionCommand.hasExecuted()) { | ||||
|             Logger.logDebug(LOG_TAG, "Ignoring sending SIGKILL to \"" + mExecutionCommand.getCommandIdAndLabelLogString() + "\" TermuxTask since it has already finished executing"); | ||||
|             Logger.logDebug(LOG_TAG, "Ignoring sending SIGKILL to \"" + mExecutionCommand.getCommandIdAndLabelLogString() + "\" AppShell since it has already finished executing"); | ||||
|             return; | ||||
|         } | ||||
| 
 | ||||
|         Logger.logDebug(LOG_TAG, "Send SIGKILL to \"" + mExecutionCommand.getCommandIdAndLabelLogString() + "\" TermuxTask"); | ||||
|         Logger.logDebug(LOG_TAG, "Send SIGKILL to \"" + mExecutionCommand.getCommandIdAndLabelLogString() + "\" AppShell"); | ||||
| 
 | ||||
|         if (mExecutionCommand.setStateFailed(Errno.ERRNO_FAILED.getCode(), context.getString(R.string.error_sending_sigkill_to_process))) { | ||||
|             if (processResult) { | ||||
|                 mExecutionCommand.resultData.exitCode = 137; // SIGKILL | ||||
|                 TermuxTask.processTermuxTaskResult(this, null); | ||||
|                 AppShell.processAppShellResult(this, null); | ||||
|             } | ||||
|         } | ||||
| 
 | ||||
| @@ -244,7 +244,7 @@ public final class TermuxTask { | ||||
|     } | ||||
| 
 | ||||
|     /** | ||||
|      * Kill this {@link TermuxTask} by sending a {@link OsConstants#SIGILL} to its {@link #mProcess}. | ||||
|      * Kill this {@link AppShell} by sending a {@link OsConstants#SIGILL} to its {@link #mProcess}. | ||||
|      */ | ||||
|     public void kill() { | ||||
|         int pid = ShellUtils.getPid(mProcess); | ||||
| @@ -252,43 +252,43 @@ public final class TermuxTask { | ||||
|             // Send SIGKILL to process | ||||
|             Os.kill(pid, OsConstants.SIGKILL); | ||||
|         } catch (ErrnoException e) { | ||||
|             Logger.logWarn(LOG_TAG, "Failed to send SIGKILL to \"" + mExecutionCommand.getCommandIdAndLabelLogString() + "\" TermuxTask with pid " + pid + ": " + e.getMessage()); | ||||
|             Logger.logWarn(LOG_TAG, "Failed to send SIGKILL to \"" + mExecutionCommand.getCommandIdAndLabelLogString() + "\" AppShell with pid " + pid + ": " + e.getMessage()); | ||||
|         } | ||||
|     } | ||||
| 
 | ||||
|     /** | ||||
|      * Process the results of {@link TermuxTask} or {@link ExecutionCommand}. | ||||
|      * Process the results of {@link AppShell} or {@link ExecutionCommand}. | ||||
|      * | ||||
|      * Only one of {@code termuxTask} and {@code executionCommand} must be set. | ||||
|      * Only one of {@code appShell} and {@code executionCommand} must be set. | ||||
|      * | ||||
|      * If the {@code termuxTask} and its {@link #mTermuxTaskClient} are not {@code null}, | ||||
|      * then the {@link TermuxTaskClient#onTermuxTaskExited(TermuxTask)} callback will be called. | ||||
|      * If the {@code appShell} and its {@link #mAppShellClient} are not {@code null}, | ||||
|      * then the {@link AppShellClient#onAppShellExited(AppShell)} callback will be called. | ||||
|      * | ||||
|      * @param termuxTask The {@link TermuxTask}, which should be set if | ||||
|      *                  {@link #execute(Context, ExecutionCommand, TermuxTaskClient, ShellEnvironmentClient, boolean)} | ||||
|      * @param appShell The {@link AppShell}, which should be set if | ||||
|      *                  {@link #execute(Context, ExecutionCommand, AppShellClient, ShellEnvironmentClient, boolean)} | ||||
|      *                   successfully started the process. | ||||
|      * @param executionCommand The {@link ExecutionCommand}, which should be set if | ||||
|      *                          {@link #execute(Context, ExecutionCommand, TermuxTaskClient, ShellEnvironmentClient, boolean)} | ||||
|      *                          {@link #execute(Context, ExecutionCommand, AppShellClient, ShellEnvironmentClient, boolean)} | ||||
|      *                          failed to start the process. | ||||
|      */ | ||||
|     private static void processTermuxTaskResult(final TermuxTask termuxTask, ExecutionCommand executionCommand) { | ||||
|         if (termuxTask != null) | ||||
|             executionCommand = termuxTask.mExecutionCommand; | ||||
|     private static void processAppShellResult(final AppShell appShell, ExecutionCommand executionCommand) { | ||||
|         if (appShell != null) | ||||
|             executionCommand = appShell.mExecutionCommand; | ||||
| 
 | ||||
|         if (executionCommand == null) return; | ||||
| 
 | ||||
|         if (executionCommand.shouldNotProcessResults()) { | ||||
|             Logger.logDebug(LOG_TAG, "Ignoring duplicate call to process \"" + executionCommand.getCommandIdAndLabelLogString() + "\" TermuxTask result"); | ||||
|             Logger.logDebug(LOG_TAG, "Ignoring duplicate call to process \"" + executionCommand.getCommandIdAndLabelLogString() + "\" AppShell result"); | ||||
|             return; | ||||
|         } | ||||
| 
 | ||||
|         Logger.logDebug(LOG_TAG, "Processing \"" + executionCommand.getCommandIdAndLabelLogString() + "\" TermuxTask result"); | ||||
|         Logger.logDebug(LOG_TAG, "Processing \"" + executionCommand.getCommandIdAndLabelLogString() + "\" AppShell result"); | ||||
| 
 | ||||
|         if (termuxTask != null && termuxTask.mTermuxTaskClient != null) { | ||||
|             termuxTask.mTermuxTaskClient.onTermuxTaskExited(termuxTask); | ||||
|         if (appShell != null && appShell.mAppShellClient != null) { | ||||
|             appShell.mAppShellClient.onAppShellExited(appShell); | ||||
|         } else { | ||||
|             // If a callback is not set and execution command didn't fail, then we set success state now | ||||
|             // Otherwise, the callback host can set it himself when its done with the termuxTask | ||||
|             // Otherwise, the callback host can set it himself when its done with the appShell | ||||
|             if (!executionCommand.isStateFailed()) | ||||
|                 executionCommand.setState(ExecutionCommand.ExecutionState.SUCCESS); | ||||
|         } | ||||
| @@ -304,14 +304,14 @@ public final class TermuxTask { | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
|     public interface TermuxTaskClient { | ||||
|     public interface AppShellClient { | ||||
| 
 | ||||
|         /** | ||||
|          * Callback function for when {@link TermuxTask} exits. | ||||
|          * Callback function for when {@link AppShell} exits. | ||||
|          * | ||||
|          * @param termuxTask The {@link TermuxTask} that exited. | ||||
|          * @param appShell The {@link AppShell} that exited. | ||||
|          */ | ||||
|         void onTermuxTaskExited(TermuxTask termuxTask); | ||||
|         void onAppShellExited(AppShell appShell); | ||||
| 
 | ||||
|     } | ||||
| 
 | ||||
| @@ -14,6 +14,7 @@ import com.termux.shared.R; | ||||
| import com.termux.shared.android.AndroidUtils; | ||||
| import com.termux.shared.data.DataUtils; | ||||
| import com.termux.shared.file.FileUtils; | ||||
| import com.termux.shared.shell.command.runner.app.AppShell; | ||||
| import com.termux.shared.termux.file.TermuxFileUtils; | ||||
| import com.termux.shared.logger.Logger; | ||||
| import com.termux.shared.markdown.MarkdownUtils; | ||||
| @@ -21,7 +22,6 @@ import com.termux.shared.shell.command.ExecutionCommand; | ||||
| import com.termux.shared.errors.Error; | ||||
| import com.termux.shared.android.PackageUtils; | ||||
| import com.termux.shared.termux.shell.TermuxShellEnvironmentClient; | ||||
| import com.termux.shared.shell.command.runner.app.TermuxTask; | ||||
|  | ||||
| import org.apache.commons.io.IOUtils; | ||||
|  | ||||
| @@ -519,8 +519,8 @@ public class TermuxUtils { | ||||
|         ExecutionCommand executionCommand = new ExecutionCommand(1, TermuxConstants.TERMUX_BIN_PREFIX_DIR_PATH + "/bash", null, aptInfoScript, null, true, false); | ||||
|         executionCommand.commandLabel = "APT Info Command"; | ||||
|         executionCommand.backgroundCustomLogLevel = Logger.LOG_LEVEL_OFF; | ||||
|         TermuxTask termuxTask = TermuxTask.execute(context, executionCommand, null, new TermuxShellEnvironmentClient(), true); | ||||
|         if (termuxTask == null || !executionCommand.isSuccessful() || executionCommand.resultData.exitCode != 0) { | ||||
|         AppShell appShell = AppShell.execute(context, executionCommand, null, new TermuxShellEnvironmentClient(), true); | ||||
|         if (appShell == null || !executionCommand.isSuccessful() || executionCommand.resultData.exitCode != 0) { | ||||
|             Logger.logErrorExtended(LOG_TAG, executionCommand.toString()); | ||||
|             return null; | ||||
|         } | ||||
| @@ -577,8 +577,8 @@ public class TermuxUtils { | ||||
|         ExecutionCommand executionCommand = new ExecutionCommand(1, "/system/bin/sh", null, logcatScript + "\n", "/", true, true); | ||||
|         executionCommand.commandLabel = "Logcat dump command"; | ||||
|         executionCommand.backgroundCustomLogLevel = Logger.LOG_LEVEL_OFF; | ||||
|         TermuxTask termuxTask = TermuxTask.execute(context, executionCommand, null, new TermuxShellEnvironmentClient(), true); | ||||
|         if (termuxTask == null || !executionCommand.isSuccessful()) { | ||||
|         AppShell appShell = AppShell.execute(context, executionCommand, null, new TermuxShellEnvironmentClient(), true); | ||||
|         if (appShell == null || !executionCommand.isSuccessful()) { | ||||
|             Logger.logErrorExtended(LOG_TAG, executionCommand.toString()); | ||||
|             return null; | ||||
|         } | ||||
|   | ||||
| @@ -12,7 +12,7 @@ import com.termux.shared.shell.command.ExecutionCommand; | ||||
| import com.termux.shared.errors.Error; | ||||
| import com.termux.shared.file.FileUtilsErrno; | ||||
| import com.termux.shared.termux.shell.TermuxShellEnvironmentClient; | ||||
| import com.termux.shared.shell.command.runner.app.TermuxTask; | ||||
| import com.termux.shared.shell.command.runner.app.AppShell; | ||||
| import com.termux.shared.android.AndroidUtils; | ||||
| import com.termux.shared.termux.TermuxConstants; | ||||
| import com.termux.shared.termux.TermuxUtils; | ||||
| @@ -345,8 +345,8 @@ public class TermuxFileUtils { | ||||
|         ExecutionCommand executionCommand = new ExecutionCommand(1, "/system/bin/sh", null, statScript.toString() + "\n", "/", true, true); | ||||
|         executionCommand.commandLabel = TermuxConstants.TERMUX_APP_NAME + " Files Stat Command"; | ||||
|         executionCommand.backgroundCustomLogLevel = Logger.LOG_LEVEL_OFF; | ||||
|         TermuxTask termuxTask = TermuxTask.execute(context, executionCommand, null, new TermuxShellEnvironmentClient(), true); | ||||
|         if (termuxTask == null || !executionCommand.isSuccessful()) { | ||||
|         AppShell appShell = AppShell.execute(context, executionCommand, null, new TermuxShellEnvironmentClient(), true); | ||||
|         if (appShell == null || !executionCommand.isSuccessful()) { | ||||
|             Logger.logErrorExtended(LOG_TAG, executionCommand.toString()); | ||||
|             return null; | ||||
|         } | ||||
|   | ||||
		Reference in New Issue
	
	Block a user