Package ghidra.app.merge
Class MergeManager
- java.lang.Object
- 
- ghidra.app.merge.MergeManager
 
- 
- All Implemented Interfaces:
- MergeProgressModifier,- DomainObjectMergeManager
 - Direct Known Subclasses:
- DataTypeArchiveMergeManager,- ProgramMultiUserMergeManager
 
 public abstract class MergeManager extends java.lang.Object implements DomainObjectMergeManager Top level object that manages each step of the merge/resolve conflicts process.
- 
- 
Field SummaryFields Modifier and Type Field Description protected intcurrentIndexprotected booleaninputReceivedprotected DomainObjectChangeSetlatestChangeSetprotected UndoableDomainObjectlatestDomainObjectprotected booleanmergeCompletedprotected TaskMonitormergeMonitorprotected MergeManagerPluginmergePluginprotected MergeProgressPanelmergeProgressPanelprotected MergeResolver[]mergeResolversprotected booleanmergeStatusprotected ModalPluginToolmergeToolprotected booleanmergeToolIsVisibleprotected DomainObjectChangeSetmyChangeSetprotected UndoableDomainObjectmyDomainObjectprotected UndoableDomainObjectoriginalDomainObjectprotected booleanpromptingprotected java.util.Hashtable<java.lang.String,java.lang.Object>resolveMapprotected UndoableDomainObjectresultDomainObjectprotected RunManagerrunManager
 - 
Constructor SummaryConstructors Constructor Description MergeManager(UndoableDomainObject resultDomainObject, UndoableDomainObject myDomainObject, UndoableDomainObject originalDomainObject, UndoableDomainObject latestDomainObject, DomainObjectChangeSet latestChangeSet, DomainObjectChangeSet myChangeSet)
 - 
Method SummaryAll Methods Instance Methods Abstract Methods Concrete Methods Modifier and Type Method Description protected abstract voidcleanupMerge()voidclearStatusText()Clear the status text on the merge dialog.protected abstract MergeManagerPlugincreateMergeManagerPlugin(ModalPluginTool mergePluginTool, MergeManager multiUserMergeManager, UndoableDomainObject modifiableDomainObject)protected abstract voidcreateMergeResolvers()UndoableDomainObjectgetDomainObject(int version)Returns one of the four programs involved in the merge as indicated by the version.MergeProgressPanelgetMergeProgressPanel()gets the default merge progress panel that indicates all the phases and their current status.MergeResolvergetMergeResolverByName(java.lang.String name)Returns the named merge resolver from the ones used directly by the MergeManager.PluginToolgetMergeTool()For Junit testsjavax.swing.JComponentgetMonitorComponent()Gets the TaskMonitor component that is displayed at the bottom of the merge tool.protected java.awt.DimensiongetPreferredMergeToolSize()java.lang.ObjectgetResolveInformation(java.lang.String infoType)Gets the resolve information object for the indicated standardized name.protected abstract voidinitializeMerge()booleanisMergeToolVisible()Determines if the modal merge tool is currently displayed on the screen.booleanisPromptingUser()Determines whether or not the user is being prompted to resolve a conflict.booleanmerge()Convenience method for Junit tests.booleanmerge(TaskMonitor taskMonitor)Merge domain objects and resolve any conflicts.booleanprocessingCompleted()Return whether the merge process has completed.voidremoveComponent(javax.swing.JComponent comp)Removes the component that is used to resolve conflicts.voidsetApplyEnabled(boolean enabled)Enable the apply button according to the "enabled" parameter.voidsetCompleted(java.lang.String[] mergePhase)The manager (MergeResolver) for a particular merge phase should call this when its phase or sub-phase completes.voidsetInProgress(java.lang.String[] mergePhase)The manager (MergeResolver) for a particular merge phase should call this when its phase or sub-phase begins.voidsetResolveInformation(java.lang.String infoType, java.lang.Object infoObject)Sets the resolve information object for the indicated standardized name.voidsetStatusText(java.lang.String msg)Set the status text on the merge dialog.voidshowComponent(javax.swing.JComponent comp, java.lang.String componentID, HelpLocation helpLoc)Show the component that is used to resolve conflicts.voidshowDefaultMergePanel(java.lang.String description)Show the default merge panel.protected voidshowMergeTool()voidshowMonitorComponent(boolean show)Shows/hides the monitor component at the bottom of the merge tool.voidshowProgressIcon(boolean show)Shows/hides the progress icon (spinning globe) at the bottom of the merge tool.voidupdateProgress(int currentProgressPercentage)Updates the current phase progress area in the default merge panel.voidupdateProgress(int currentProgressPercentage, java.lang.String progressMessage)Updates the current phase progress area in the default merge panel.voidupdateProgress(java.lang.String description)Updates the current phase progress area in the default merge panel.protected voidwaitForInput()Block until the user completes the current merge operation, or cancels the merge process.
 
- 
- 
- 
Field Detail- 
mergeResolversprotected MergeResolver[] mergeResolvers 
 - 
resultDomainObjectprotected UndoableDomainObject resultDomainObject 
 - 
myDomainObjectprotected UndoableDomainObject myDomainObject 
 - 
originalDomainObjectprotected UndoableDomainObject originalDomainObject 
 - 
latestDomainObjectprotected UndoableDomainObject latestDomainObject 
 - 
latestChangeSetprotected DomainObjectChangeSet latestChangeSet 
 - 
myChangeSetprotected DomainObjectChangeSet myChangeSet 
 - 
mergePluginprotected MergeManagerPlugin mergePlugin 
 - 
runManagerprotected RunManager runManager 
 - 
mergeMonitorprotected TaskMonitor mergeMonitor 
 - 
currentIndexprotected int currentIndex 
 - 
inputReceivedprotected volatile boolean inputReceived 
 - 
mergeStatusprotected boolean mergeStatus 
 - 
promptingprotected volatile boolean prompting 
 - 
mergeCompletedprotected volatile boolean mergeCompleted 
 - 
mergeToolIsVisibleprotected volatile boolean mergeToolIsVisible 
 - 
mergeToolprotected volatile ModalPluginTool mergeTool 
 - 
resolveMapprotected java.util.Hashtable<java.lang.String,java.lang.Object> resolveMap 
 - 
mergeProgressPanelprotected MergeProgressPanel mergeProgressPanel 
 
- 
 - 
Constructor Detail- 
MergeManagerpublic MergeManager(UndoableDomainObject resultDomainObject, UndoableDomainObject myDomainObject, UndoableDomainObject originalDomainObject, UndoableDomainObject latestDomainObject, DomainObjectChangeSet latestChangeSet, DomainObjectChangeSet myChangeSet) 
 
- 
 - 
Method Detail- 
createMergeResolversprotected abstract void createMergeResolvers() 
 - 
getDomainObjectpublic UndoableDomainObject getDomainObject(int version) Returns one of the four programs involved in the merge as indicated by the version.- Parameters:
- version- the program version to return. (LATEST, MY, ORIGINAL, or RESULT).
- Returns:
- the indicated program version or null if a valid version isn't specified.
- See Also:
- MergeConstants
 
 - 
mergepublic boolean merge(TaskMonitor taskMonitor) throws CancelledException Description copied from interface:DomainObjectMergeManagerMerge domain objects and resolve any conflicts.- Specified by:
- mergein interface- DomainObjectMergeManager
- Returns:
- true if the merge process completed successfully
- Throws:
- CancelledException- if the user canceled the merge process
 
 - 
createMergeManagerPluginprotected abstract MergeManagerPlugin createMergeManagerPlugin(ModalPluginTool mergePluginTool, MergeManager multiUserMergeManager, UndoableDomainObject modifiableDomainObject) 
 - 
initializeMergeprotected abstract void initializeMerge() 
 - 
cleanupMergeprotected abstract void cleanupMerge() 
 - 
getPreferredMergeToolSizeprotected java.awt.Dimension getPreferredMergeToolSize() 
 - 
mergepublic boolean merge() throws CancelledExceptionConvenience method for Junit tests.- Throws:
- CancelledException
 
 - 
setApplyEnabledpublic void setApplyEnabled(boolean enabled) Enable the apply button according to the "enabled" parameter.- Specified by:
- setApplyEnabledin interface- DomainObjectMergeManager
 
 - 
clearStatusTextpublic void clearStatusText() Clear the status text on the merge dialog.- Specified by:
- clearStatusTextin interface- DomainObjectMergeManager
 
 - 
setStatusTextpublic void setStatusText(java.lang.String msg) Set the status text on the merge dialog.- Specified by:
- setStatusTextin interface- DomainObjectMergeManager
 
 - 
showDefaultMergePanelpublic void showDefaultMergePanel(java.lang.String description) Show the default merge panel. The default merge panel now shows the status of each phase of the merge and also the progress in the current phase.- Parameters:
- description- description of current merge process near the top of the merge tool.
 
 - 
showComponentpublic void showComponent(javax.swing.JComponent comp, java.lang.String componentID, HelpLocation helpLoc)Show the component that is used to resolve conflicts. This method is called by the MergeResolvers when user input is required. If the component is not null, this method blocks until the user either cancels the merge process or resolves a conflict. If comp is null, then the default component is displayed, and the method does not wait for user input.- Specified by:
- showComponentin interface- DomainObjectMergeManager
- Parameters:
- comp- component to show; if component is null, show the default component and do not block
- componentID- id or name for the component
 
 - 
removeComponentpublic void removeComponent(javax.swing.JComponent comp) Removes the component that is used to resolve conflicts. This method is called by the MergeResolvers when user input is no longer required using the specified component.- Parameters:
- comp- component to show; if component is null, show the default component and do not block
 
 - 
showMergeToolprotected void showMergeTool() 
 - 
showMonitorComponentpublic void showMonitorComponent(boolean show) Shows/hides the monitor component at the bottom of the merge tool.- Parameters:
- show- true means to show the task monitor at the bottom of the merge tool.
 
 - 
showProgressIconpublic void showProgressIcon(boolean show) Shows/hides the progress icon (spinning globe) at the bottom of the merge tool.- Parameters:
- show- true means to show the icon.
 
 - 
isPromptingUserpublic boolean isPromptingUser() Determines whether or not the user is being prompted to resolve a conflict.- Returns:
- true if the user is being prompted for input.
 
 - 
processingCompletedpublic boolean processingCompleted() Return whether the merge process has completed. (Needed for Junit testing only.)
 - 
waitForInputprotected void waitForInput() Block until the user completes the current merge operation, or cancels the merge process.
 - 
getResolveInformationpublic java.lang.Object getResolveInformation(java.lang.String infoType) Gets the resolve information object for the indicated standardized name. This is how information is passed between merge managers.
 For example:
 the data type merger knows what data type in the result is equivalent to a given data type from my checked out program. The code unit and function mergers need to be able to get this information so they don't unknowingly re-introduce a data type that was already eliminated by a data type conflict.- Parameters:
- infoType- the string indicating the type of resolve information
- Returns:
- the object for the named string or null
 
 - 
setResolveInformationpublic void setResolveInformation(java.lang.String infoType, java.lang.Object infoObject)Sets the resolve information object for the indicated standardized name. This is how information is passed between merge managers.- Specified by:
- setResolveInformationin interface- DomainObjectMergeManager
- Parameters:
- infoType- the string indicating the type of resolve information
- infoObject- the object for the named string. This information is determined by the merge manager that creates it.
- See Also:
- getResolveInformation(java.lang.String)
 
 - 
getMergeResolverByNamepublic MergeResolver getMergeResolverByName(java.lang.String name) Returns the named merge resolver from the ones used directly by the MergeManager.- Parameters:
- name- the name of the desired merge resolver
- Returns:
- the merge resolver or null.
 
 - 
getMergeToolpublic PluginTool getMergeTool() For Junit tests- Returns:
- the merge tool
 
 - 
isMergeToolVisiblepublic boolean isMergeToolVisible() Determines if the modal merge tool is currently displayed on the screen.- Returns:
- true if the merge tool is displayed.
 
 - 
getMergeProgressPanelpublic MergeProgressPanel getMergeProgressPanel() gets the default merge progress panel that indicates all the phases and their current status.- Returns:
- the merge panel that indicates progress.
 
 - 
getMonitorComponentpublic javax.swing.JComponent getMonitorComponent() Gets the TaskMonitor component that is displayed at the bottom of the merge tool.- Returns:
- the task monitor component.
 
 - 
updateProgresspublic void updateProgress(java.lang.String description) Updates the current phase progress area in the default merge panel.- Specified by:
- updateProgressin interface- MergeProgressModifier
- Parameters:
- currentProgressPercentage- the progress percentage completed for the current phase. This should be a value from 0 to 100.
- progressMessage- a message indicating what is currently occurring in this phase. Null indicates to use the default message.
 
 - 
updateProgresspublic void updateProgress(int currentProgressPercentage) Updates the current phase progress area in the default merge panel.- Specified by:
- updateProgressin interface- MergeProgressModifier
- Parameters:
- currentProgressPercentage- the progress percentage completed for the current phase. This should be a value from 0 to 100.
 
 - 
updateProgresspublic void updateProgress(int currentProgressPercentage, java.lang.String progressMessage)Updates the current phase progress area in the default merge panel.- Specified by:
- updateProgressin interface- MergeProgressModifier
- Parameters:
- currentProgressPercentage- the progress percentage completed for the current phase. This should be a value from 0 to 100.
- progressMessage- a message indicating what is currently occurring in this phase.
 
 - 
setInProgresspublic void setInProgress(java.lang.String[] mergePhase) The manager (MergeResolver) for a particular merge phase should call this when its phase or sub-phase begins. The string array should match one that the returned by MergeResolver.getPhases().- Specified by:
- setInProgressin interface- MergeProgressModifier
- Parameters:
- mergePhase- identifier for the merge phase to change to in progress status.
- See Also:
- MergeResolver
 
 - 
setCompletedpublic void setCompleted(java.lang.String[] mergePhase) The manager (MergeResolver) for a particular merge phase should call this when its phase or sub-phase completes. The string array should match one that the returned by MergeResolver.getPhases().- Specified by:
- setCompletedin interface- MergeProgressModifier
- Parameters:
- mergePhase- identifier for the merge phase to change to completed status.
- See Also:
- MergeResolver
 
 
- 
 
-