blob: ca7ec65f990862f843cff55b6279de75264c87df [file] [log] [blame]
/*
* Copyright 2000-2013 JetBrains s.r.o.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package com.jetbrains.python.codeInsight.intentions;
import com.intellij.codeInsight.FileModificationService;
import com.intellij.codeInsight.intention.impl.BaseIntentionAction;
import com.intellij.openapi.editor.Editor;
import com.intellij.openapi.module.Module;
import com.intellij.openapi.module.ModuleManager;
import com.intellij.openapi.project.Project;
import com.intellij.openapi.ui.Messages;
import com.intellij.psi.PsiElement;
import com.intellij.psi.PsiFile;
import com.intellij.psi.util.PsiTreeUtil;
import com.intellij.util.IncorrectOperationException;
import com.jetbrains.python.PyBundle;
import com.jetbrains.python.debugger.PySignature;
import com.jetbrains.python.debugger.PySignatureCacheManager;
import com.jetbrains.python.documentation.DocStringFormat;
import com.jetbrains.python.documentation.PyDocstringGenerator;
import com.jetbrains.python.documentation.PyDocumentationSettings;
import com.jetbrains.python.documentation.doctest.PyDocstringFile;
import com.jetbrains.python.psi.PyFile;
import com.jetbrains.python.psi.PyFunction;
import com.jetbrains.python.psi.PyStatementList;
import com.jetbrains.python.psi.PyUtil;
import org.jetbrains.annotations.NotNull;
/**
* User: catherine
* Intention to add documentation string for function
* (with checked format)
*/
public class PyGenerateDocstringIntention extends BaseIntentionAction {
private String myText;
@NotNull
public String getFamilyName() {
return PyBundle.message("INTN.doc.string.stub");
}
@NotNull
@Override
public String getText() {
return myText;
}
public boolean isAvailable(@NotNull Project project, Editor editor, PsiFile file) {
if (!(file instanceof PyFile) || file instanceof PyDocstringFile) return false;
PsiElement elementAt = PyUtil.findNonWhitespaceAtOffset(file, editor.getCaretModel().getOffset());
if (elementAt == null) {
return false;
}
PyFunction function = PsiTreeUtil.getParentOfType(elementAt, PyFunction.class);
final PyStatementList statementList = PsiTreeUtil.getParentOfType(elementAt, PyStatementList.class, false, PyFunction.class);
if (function == null || statementList != null) {
return false;
}
if (!elementAt.equals(function.getNameNode())) return false;
return isAvailableForFunction(project, function);
}
private boolean isAvailableForFunction(Project project, PyFunction function) {
if (function.getDocStringValue() != null) {
PySignature signature = PySignatureCacheManager.getInstance(project).findSignature(function);
PyDocstringGenerator docstringGenerator = new PyDocstringGenerator(function);
docstringGenerator.addFunctionArguments(function, signature);
if (docstringGenerator.haveParametersToAdd()) {
myText = PyBundle.message("INTN.add.parameters.to.docstring");
return true;
}
else {
return false;
}
}
else {
myText = PyBundle.message("INTN.doc.string.stub");
return true;
}
}
public void invoke(@NotNull Project project, Editor editor, PsiFile file) throws IncorrectOperationException {
if (!FileModificationService.getInstance().preparePsiElementForWrite(file)) {
return;
}
PsiElement elementAt = PyUtil.findNonWhitespaceAtOffset(file, editor.getCaretModel().getOffset());
PyFunction function = PsiTreeUtil.getParentOfType(elementAt, PyFunction.class);
if (function == null) {
return;
}
generateDocstringForFunction(project, editor, function);
}
public static void generateDocstringForFunction(Project project, Editor editor, PyFunction function) {
final Module module = ModuleManager.getInstance(project).getModules()[0];
final PyDocumentationSettings documentationSettings = PyDocumentationSettings.getInstance(module);
if (documentationSettings.isPlain(function.getContainingFile())) {
final String[] values = {DocStringFormat.EPYTEXT, DocStringFormat.REST};
final int i = Messages.showChooseDialog("Docstring format:", "Select Docstring Type", values, DocStringFormat.EPYTEXT, null);
if (i < 0) return;
final String value = values[i];
documentationSettings.setFormat(value);
}
PyDocstringGenerator docstringGenerator = new PyDocstringGenerator(function).withSignatures();
if (function.getDocStringValue() == null) {
docstringGenerator.withReturn();
}
docstringGenerator.build();
}
}