blob: 49a17efd28a69a77b773e58a9f9caa8660caa14f [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.documentation;
import com.intellij.openapi.components.PersistentStateComponent;
import com.intellij.openapi.components.State;
import com.intellij.openapi.components.Storage;
import com.intellij.openapi.module.Module;
import com.intellij.openapi.module.ModuleServiceManager;
import com.intellij.openapi.util.text.StringUtil;
import com.intellij.psi.PsiFile;
import com.intellij.util.xmlb.XmlSerializerUtil;
import com.intellij.util.xmlb.annotations.Transient;
import com.jetbrains.python.PyNames;
import com.jetbrains.python.psi.PyFile;
import com.jetbrains.python.psi.PyTargetExpression;
import com.jetbrains.python.psi.impl.PyPsiUtils;
import org.jetbrains.annotations.NotNull;
import org.jetbrains.annotations.Nullable;
import java.util.List;
/**
* @author yole
*/
@State(name = "PyDocumentationSettings",
storages = {@Storage(file = "$MODULE_FILE$")}
)
public class PyDocumentationSettings implements PersistentStateComponent<PyDocumentationSettings> {
public String myDocStringFormat = DocStringFormat.REST;
public boolean analyzeDoctest = true;
public boolean isEpydocFormat(PsiFile file) {
return isFormat(file, DocStringFormat.EPYTEXT);
}
public boolean isReSTFormat(PsiFile file) {
return isFormat(file, DocStringFormat.REST);
}
public boolean isPlain(PsiFile file) {
return isFormat(file, DocStringFormat.PLAIN);
}
private boolean isFormat(PsiFile file, final String format) {
if (file instanceof PyFile) {
PyTargetExpression expr = ((PyFile)file).findTopLevelAttribute(PyNames.DOCFORMAT);
if (expr != null) {
String docformat = PyPsiUtils.strValue(expr.findAssignedValue());
if (docformat != null) {
final List<String> words = StringUtil.split(docformat, " ");
return words.size() > 0 && format.equalsIgnoreCase(words.get(0));
}
}
}
return format.equalsIgnoreCase(myDocStringFormat);
}
public static PyDocumentationSettings getInstance(@NotNull Module module) {
return ModuleServiceManager.getService(module, PyDocumentationSettings.class);
}
public void setFormat(String format) {
myDocStringFormat = format;
}
@Transient
public String getFormat() {
return myDocStringFormat;
}
@Override
public PyDocumentationSettings getState() {
return this;
}
@Override
public void loadState(PyDocumentationSettings state) {
XmlSerializerUtil.copyBean(state, this);
}
/**
* TODO: Use this factory for the whole document infrastructure to simplify new documentation engine support
* Factory that returns appropriate instance of {@link StructuredDocStringBase} if specificed
*
* @return instance or null if no doctype os set
*/
@Nullable
public StructuredDocStringBase getDocString() {
if (myDocStringFormat.equals(DocStringFormat.EPYTEXT)) {
return new EpydocString();
}
if (myDocStringFormat.equals(DocStringFormat.REST)) {
return new SphinxDocString();
}
return null;
}
}