public class AddXsiSchemaLocationForExtResourceAction extends BaseIntentionAction
Modifier and Type | Field and Description |
---|---|
static java.lang.String |
KEY |
EMPTY_ARRAY
Constructor and Description |
---|
AddXsiSchemaLocationForExtResourceAction() |
Modifier and Type | Method and Description |
---|---|
protected void |
doInvoke(PsiFile file,
int offset,
java.lang.String uri,
Editor editor) |
boolean |
equals(java.lang.Object obj) |
static java.lang.String |
findUri(PsiFile file,
int offset) |
PsiElement |
getElementToMakeWritable(PsiFile currentFile)
Controls whether this intention/fix is going to modify the current file.
|
java.lang.String |
getFamilyName()
Returns the name of the family of intentions.
|
protected java.lang.String |
getQuickFixKeyId() |
void |
invoke(Project project,
Editor editor,
PsiFile file)
Called when user invokes intention.
|
protected boolean |
isAcceptableUri(java.lang.String uri) |
boolean |
isAvailable(Project project,
Editor editor,
PsiFile file)
Checks whether this intention is available at a caret offset in the file.
|
boolean |
startInWriteAction()
Indicate whether this action should be invoked inside write action.
|
canModify, getText, setText, toString
public static final java.lang.String KEY
public AddXsiSchemaLocationForExtResourceAction()
protected java.lang.String getQuickFixKeyId()
public PsiElement getElementToMakeWritable(PsiFile currentFile)
FileModifier
@NotNull
, and the current file is read-only,
it will be made writable (honoring version control integration) before the intention/fix is invoked.
By default, as a heuristic, returns the same as WriteActionAware.startInWriteAction()
.
If the action is going to modify multiple files, or the set of the files is unknown in advance, please
don't bother overriding this method, return false
from WriteActionAware.startInWriteAction()
, and call FileModificationService
methods in the implementation, and take write actions yourself as needed.currentFile
- the same file where intention would be invoked (for LocalQuickFix
it would be the containing file of ProblemDescriptor.getPsiElement()
)public boolean startInWriteAction()
IntentionAction
false
if, e.g., a modal dialog is shown inside the action.
If false is returned the action itself is responsible for starting write action
when needed, by calling Application.runWriteAction(Runnable)
.startInWriteAction
in interface IntentionAction
startInWriteAction
in interface WriteActionAware
startInWriteAction
in class BaseIntentionAction
true
if the intention requires a write action, false
otherwise.protected void doInvoke(PsiFile file, int offset, java.lang.String uri, Editor editor) throws IncorrectOperationException
IncorrectOperationException
public boolean isAvailable(Project project, Editor editor, PsiFile file)
IntentionAction
isAvailable
in interface IntentionAction
project
- the project in which the availability is checked.editor
- the editor in which the intention will be invoked.file
- the file open in the editor.true
if the intention is available, false
otherwise.protected boolean isAcceptableUri(java.lang.String uri)
public java.lang.String getFamilyName()
IntentionAction
IntentionManager.registerIntentionAndMetaData(IntentionAction, String...)
public void invoke(Project project, Editor editor, PsiFile file) throws IncorrectOperationException
IntentionAction
IntentionAction.startInWriteAction()
returns true
, this method is also called
inside write action.project
- the project in which the intention is invoked.editor
- the editor in which the intention is invoked.file
- the file open in the editor.IncorrectOperationException
public static java.lang.String findUri(PsiFile file, int offset)
public boolean equals(java.lang.Object obj)
equals
in class java.lang.Object