mirror of
				https://github.com/fankes/termux-app.git
				synced 2025-10-25 13:19:21 +08:00 
			
		
		
		
	Redo fix execution commands exceptions not being logged or sent back to plugins
The f62febbf commit mentioned that it solved "the bug where Termux:Tasker would hang indefinitely if Runtime.getRuntime().exec raised an exception, like for invalid or missing interpreter errors and Termux:Tasker wasn't notified of it. Now the errmsg will be used to send any exceptions back to Termux:Tasker and other 3rd party calls."
This however was still broken due to local design changes made to TermuxTask after testing was already done. This commit should solve that problem. Moreover, now a notification will be shown if execution commands **fail to start** that are run by plugins that don't expect the result back, like with Termux:Widget or RUN_COMMAND intent. This should make it easier for users to debug problems, since otherwise logcat needs to be looked. But logcat would still need to be looked if commands/scripts fail after they have started due to internal errors. Notifications can be disabled from Termux Settings by disabling the "Plugin Error Notifications" toggle.
			
			
This commit is contained in:
		| @@ -70,8 +70,11 @@ public final class TermuxTask { | ||||
|  | ||||
|         final String[] commandArray = ShellUtils.setupProcessArgs(executionCommand.executable, executionCommand.arguments); | ||||
|  | ||||
|         if (!executionCommand.setState(ExecutionState.EXECUTING)) | ||||
|         if (!executionCommand.setState(ExecutionState.EXECUTING)) { | ||||
|             executionCommand.setStateFailed(ExecutionCommand.RESULT_CODE_FAILED, context.getString(R.string.error_failed_to_execute_termux_task_command, executionCommand.getCommandIdAndLabelLogString()), null); | ||||
|             TermuxTask.processTermuxTaskResult(null, executionCommand); | ||||
|             return null; | ||||
|         } | ||||
|  | ||||
|         Logger.logDebug(LOG_TAG, executionCommand.toString()); | ||||
|  | ||||
|   | ||||
		Reference in New Issue
	
	Block a user