/* * Copyright 2000-2014 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.psi; import com.intellij.psi.PsiElement; import com.intellij.psi.PsiFile; import com.jetbrains.python.codeInsight.controlflow.ScopeOwner; import com.jetbrains.python.psi.resolve.RatedResolveResult; import org.jetbrains.annotations.NotNull; import org.jetbrains.annotations.Nullable; import java.util.List; public interface PyFile extends PyElement, PsiFile, PyDocStringOwner, ScopeOwner { List<PyStatement> getStatements(); @NotNull List<PyClass> getTopLevelClasses(); @NotNull List<PyFunction> getTopLevelFunctions(); List<PyTargetExpression> getTopLevelAttributes(); @Nullable PyFunction findTopLevelFunction(@NotNull String name); @Nullable PyClass findTopLevelClass(@NotNull String name); @Nullable PyTargetExpression findTopLevelAttribute(@NotNull String name); LanguageLevel getLanguageLevel(); /** * Return the list of all 'from ... import' statements in the top-level scope of the file. * * @return the list of 'from ... import' statements. */ @NotNull List<PyFromImportStatement> getFromImports(); /** * Return an exported PSI element defined in the file with the given name. */ @Nullable PsiElement findExportedName(String name); /** * Iterate over exported PSI elements defined in the file. */ @NotNull Iterable<PyElement> iterateNames(); /** * Return the resolved exported elements. */ @NotNull List<RatedResolveResult> multiResolveName(@NotNull String name); /** * Return the resolved elements. * * @param exported found element must be exported, i.e. visible from other modules. */ @NotNull List<RatedResolveResult> multiResolveName(@NotNull String name, boolean exported); /** * @deprecated Use {@link #multiResolveName(String)} instead. */ @Deprecated @Nullable PsiElement getElementNamed(String name); /** * Returns the list of import elements in all 'import xxx' statements in the top-level scope of the file. * * @return the list of import targets. */ @NotNull List<PyImportElement> getImportTargets(); /** * Returns the list of names in the __all__ declaration, or null if there is no such declaration in the module. * * @return the list of names or null. */ @Nullable List<String> getDunderAll(); /** * Return true if the file contains a 'from __future__ import ...' statement with given feature. */ boolean hasImportFromFuture(FutureFeature feature); /** * If the function raises a DeprecationWarning or a PendingDeprecationWarning, returns the explanation text provided for the warning. * * @return the deprecation message or null if the function is not deprecated. */ String getDeprecationMessage(); /** * Returns the sequential list of import statements in the beginning of the file. */ List<PyImportStatementBase> getImportBlock(); }