Package ghidra.util.task
Class Task
java.lang.Object
ghidra.util.task.Task
- All Implemented Interfaces:
- MonitoredRunnable
- Direct Known Subclasses:
- AbstractBSimSearchDialog.BSimQueryTask,- AbstractFileExtractorTask,- CalculateLayoutLocationsTask,- CompoundTask,- CopyTask,- DeleteProjectFilesTask,- GetDomainObjectTask,- GhidraURLQueryTask,- GoToSymbolSearchTask,- ImportBatchTask,- OpenProgramTask,- PasteFileTask,- ProgramTask,- ProjectDataDeleteTask,- SpecExtensionPanel.ChangeExtensionTask,- VersionControlTask
Base class for Tasks to be run in separate threads
- 
Field SummaryFields
- 
Constructor SummaryConstructors
- 
Method SummaryModifier and TypeMethodDescriptionvoidaddTaskListener(TaskListener listener) Sets the task listener on this task.booleanReturns true if the task can be canceled.voidcancel()intReturns the alignment of the text displayed in the modal dialog.final StringGet the title associated with the taskbooleanReturns the value of the 'wait for completed task' boolean that was passed into this classbooleanReturn true if the task has a progress indicator.booleanbooleanisModal()Returns true if the dialog associated with the task is modal.final voidmonitoredRun(TaskMonitor monitor) When an object implementing interfaceRunnableis used to create a thread, starting the thread causes the object'srunmethod to be called in that separately executing thread.protected voidnotifyTaskListeners(boolean wasCancelled) abstract voidrun(TaskMonitor monitor) This is the method that will be called to do the workvoidsetHasProgress(boolean b) Sets this task to have progress or not.
- 
Field Details- 
waitForTaskCompletedprotected boolean waitForTaskCompleted
- 
taskMonitor
 
- 
- 
Constructor Details- 
TaskCreates new Task.- Parameters:
- title- the title associated with the task
 
- 
TaskConstruct a new Task.- Parameters:
- title- title the title associated with the task
- canCancel- true means that the user can cancel the task
- hasProgress- true means that the dialog should show a progress indicator
- isModal- true means that the dialog is modal and the task has to complete or be canceled before any other action can occur
 
- 
Taskpublic Task(String title, boolean canCancel, boolean hasProgress, boolean isModal, boolean waitForTaskCompleted) Construct a new Task.- Parameters:
- title- title the title associated with the task
- canCancel- true means that the user can cancel the task
- hasProgress- true means that the dialog should show a progress indicator
- isModal- true means that the dialog is modal and the task has to complete or be canceled before any other action can occur
- waitForTaskCompleted- true causes the running thread to block until the finish or cancelled callback has completed on the swing thread. Note: passing true only makes sense if the task is modal.
 
 
- 
- 
Method Details- 
getTaskTitleGet the title associated with the task- Returns:
- String title shown in the dialog
 
- 
getStatusTextAlignmentpublic int getStatusTextAlignment()Returns the alignment of the text displayed in the modal dialog. The default isSwingConstants.CENTER. For status updates where the initial portion of the text does not change,SwingConstants.LEADINGis recommended. To change the default value, simply override this method and return one ofSwingConstantsCENTER, LEADING or TRAILING.- Returns:
- the alignment of the text displayed
 
- 
getWaitForTaskCompletedpublic boolean getWaitForTaskCompleted()Returns the value of the 'wait for completed task' boolean that was passed into this class- Returns:
- the value
 
- 
monitoredRunWhen an object implementing interfaceRunnableis used to create a thread, starting the thread causes the object'srunmethod to be called in that separately executing thread.- Specified by:
- monitoredRunin interface- MonitoredRunnable
- Parameters:
- monitor- the task monitor
 
- 
cancelpublic void cancel()
- 
isCancelledpublic boolean isCancelled()
- 
notifyTaskListenersprotected void notifyTaskListeners(boolean wasCancelled) 
- 
runThis is the method that will be called to do the workNote: The run(TaskMonitor) method should not make any calls directly on Swing components, as these calls are not thread safe. Place Swing calls in a Runnable, then call Swing.runLater(Runnable)orSwing.runNow(Runnable)to schedule the Runnable inside of the AWT Event Thread.- Parameters:
- monitor- The TaskMonitor that will monitor the executing Task
- Throws:
- CancelledException- if the task is cancelled. Subclasses can trigger this exception by calling- TaskMonitor.checkCancelled(). This allows them to break out of the current work stack.
 
- 
hasProgresspublic boolean hasProgress()Return true if the task has a progress indicator.- Returns:
- boolean true if the task shows progress
 
- 
setHasProgresspublic void setHasProgress(boolean b) Sets this task to have progress or not. Note: changing this value after launching the task will have no effect.- Parameters:
- b- true to show progress, false otherwise.
 
- 
canCancelpublic boolean canCancel()Returns true if the task can be canceled.- Returns:
- boolean true if the user can cancel the task
 
- 
isModalpublic boolean isModal()Returns true if the dialog associated with the task is modal.- Returns:
- boolean true if the associated dialog is modal
 
- 
addTaskListenerSets the task listener on this task. It is a programming error to call this method more than once or to call this method if a listener was passed into the constructor of this class.- Parameters:
- listener- the listener
 
 
-