mirror of
https://github.com/NationalSecurityAgency/ghidra.git
synced 2025-10-03 17:59:46 +02:00
Merge remote-tracking branch
'origin/GP-5565-dragonmacher-decompiler-rename-label-action' (Closes #7507)
This commit is contained in:
commit
c75c852001
2 changed files with 21 additions and 16 deletions
|
@ -190,7 +190,7 @@ public class AddEditDialog extends ReusableDialogComponentProvider {
|
|||
|
||||
boolean isCurrentlyEntryPoint = false;
|
||||
boolean isCurrentlyPinned = false;
|
||||
CompoundCmd cmd = new CompoundCmd(symbol == null ? "Add Label" : "Edit Label");
|
||||
CompoundCmd<Program> cmd = new CompoundCmd<>(symbol == null ? "Add Label" : "Edit Label");
|
||||
if (symbol == null) {
|
||||
cmd.add(new AddLabelCmd(addr, symbolName, parent, SourceType.USER_DEFINED));
|
||||
}
|
||||
|
@ -205,7 +205,7 @@ public class AddEditDialog extends ReusableDialogComponentProvider {
|
|||
return;
|
||||
}
|
||||
|
||||
cmd = new CompoundCmd(symbol == null ? "Add Label" : "Edit Label");
|
||||
cmd = new CompoundCmd<>(symbol == null ? "Add Label" : "Edit Label");
|
||||
if (primaryCheckBox.isEnabled() && primaryCheckBox.isSelected()) {
|
||||
cmd.add(new SetLabelPrimaryCmd(addr, symbolName, parent));
|
||||
}
|
||||
|
@ -245,7 +245,8 @@ public class AddEditDialog extends ReusableDialogComponentProvider {
|
|||
"You have removed the label text--would you like to remove the existing label?");
|
||||
if (choice == OptionDialog.YES_OPTION) {
|
||||
|
||||
Command cmd = new DeleteLabelCmd(addr, symbol.getName(), symbol.getParentNamespace());
|
||||
Command<Program> cmd =
|
||||
new DeleteLabelCmd(addr, symbol.getName(), symbol.getParentNamespace());
|
||||
if (!tool.execute(cmd, program)) {
|
||||
setStatusText(cmd.getStatusMsg());
|
||||
}
|
||||
|
@ -328,9 +329,8 @@ public class AddEditDialog extends ReusableDialogComponentProvider {
|
|||
|
||||
private void initRecentChoices() {
|
||||
labelNameChoices.removeAllItems();
|
||||
Iterator<String> it = recentLabels.iterator();
|
||||
while (it.hasNext()) {
|
||||
labelNameChoices.addItem(it.next());
|
||||
for (String recentLabel : recentLabels) {
|
||||
labelNameChoices.addItem(recentLabel);
|
||||
}
|
||||
if (recentLabels.size() > 0) {
|
||||
labelNameChoices.setSelectedIndex(-1);
|
||||
|
|
|
@ -24,7 +24,7 @@ import ghidra.app.decompiler.ClangToken;
|
|||
import ghidra.app.plugin.core.decompile.DecompilerActionContext;
|
||||
import ghidra.app.util.AddEditDialog;
|
||||
import ghidra.app.util.HelpTopics;
|
||||
import ghidra.program.model.symbol.Symbol;
|
||||
import ghidra.program.model.symbol.*;
|
||||
import ghidra.util.HelpLocation;
|
||||
|
||||
public class RenameLabelAction extends AbstractDecompilerAction {
|
||||
|
@ -47,10 +47,15 @@ public class RenameLabelAction extends AbstractDecompilerAction {
|
|||
|
||||
@Override
|
||||
protected void decompilerActionPerformed(DecompilerActionContext context) {
|
||||
Symbol symbol = getSymbol(context);
|
||||
if (symbol != null) {
|
||||
AddEditDialog dialog = new AddEditDialog("", context.getTool());
|
||||
dialog.editLabel(symbol, context.getProgram());
|
||||
Symbol s = getSymbol(context);
|
||||
if (s != null) {
|
||||
AddEditDialog dialog = new AddEditDialog("Add/Edit Label", context.getTool());
|
||||
if (s.getSource() == SourceType.DEFAULT && s.getSymbolType() == SymbolType.LABEL) {
|
||||
dialog.addLabel(s.getAddress(), context.getProgram());
|
||||
}
|
||||
else {
|
||||
dialog.editLabel(s, context.getProgram());
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue