blob: 8abd39dc6bd29867420ed5e52dc29cf9a479553f [file] [log] [blame]
/*
* Copyright 2000-2009 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.intellij.openapi.roots;
import com.intellij.openapi.vfs.VirtualFile;
import org.jetbrains.annotations.NotNull;
import org.jetbrains.annotations.Nullable;
import org.jetbrains.jps.model.JpsElement;
import org.jetbrains.jps.model.module.JpsModuleSourceRootType;
import java.util.List;
import java.util.Set;
/**
* Represents a module's content root.
* You can get existing entries with {@link com.intellij.openapi.roots.ModuleRootModel#getContentEntries()} or
* create a new one with {@link ModifiableRootModel#addContentEntry(com.intellij.openapi.vfs.VirtualFile)}.
*
* @author dsl
* @see ModuleRootModel#getContentEntries()
* @see ModifiableRootModel#addContentEntry(com.intellij.openapi.vfs.VirtualFile)
*/
public interface ContentEntry extends Synthetic {
/**
* Returns the root file or directory for the content root, if it is valid.
*
* @return the content root file or directory, or null if content entry is invalid.
*/
@Nullable
VirtualFile getFile();
/**
* Returns the URL of content root.
* To validate returned roots, use
* <code>{@link com.intellij.openapi.vfs.VirtualFileManager#findFileByUrl(String)}</code>
*
* @return URL of content root, that should never be null.
*/
@NotNull
String getUrl();
/**
* Returns the list of source roots under this content root.
*
* @return list of this <code>ContentEntry</code> {@link com.intellij.openapi.roots.SourceFolder}s
*/
@NotNull
SourceFolder[] getSourceFolders();
/**
* @param rootType type of accepted source roots
* @return list of source roots of the specified type containing in this content root
*/
@NotNull
List<SourceFolder> getSourceFolders(@NotNull JpsModuleSourceRootType<?> rootType);
/**
*
* @param rootTypes types of accepted source roots
* @return list of source roots of the specified types containing in this content root
*/
@NotNull
List<SourceFolder> getSourceFolders(@NotNull Set<? extends JpsModuleSourceRootType<?>> rootTypes);
/**
* Returns the list of files and directories for valid source roots under this content root.
*
* @return list of all valid source roots.
*/
@NotNull
VirtualFile[] getSourceFolderFiles();
/**
* Returns the list of excluded roots configured under this content root. The result doesn't include synthetic excludes like the module output.
*
* @return list of this <code>ContentEntry</code> {@link com.intellij.openapi.roots.ExcludeFolder}s
*/
@NotNull
ExcludeFolder[] getExcludeFolders();
/**
* @return list of URLs for all excluded roots under this content root including synthetic excludes like the module output
*/
@NotNull
List<String> getExcludeFolderUrls();
/**
* Returns the list of files and directories for valid excluded roots under this content root.
*
* @return list of all valid exclude roots including synthetic excludes like the module output
*/
@NotNull
VirtualFile[] getExcludeFolderFiles();
/**
* Adds a source or test source root under the content root.
*
* @param file the file or directory to add as a source root.
* @param isTestSource true if the file or directory is added as a test source root.
* @return the object representing the added root.
*/
@NotNull
SourceFolder addSourceFolder(@NotNull VirtualFile file, boolean isTestSource);
/**
* Adds a source or test source root with the specified package prefix under the content root.
*
* @param file the file or directory to add as a source root.
* @param isTestSource true if the file or directory is added as a test source root.
* @param packagePrefix the package prefix for the root to add, or an empty string if no
* package prefix is required.
* @return the object representing the added root.
*/
@NotNull
SourceFolder addSourceFolder(@NotNull VirtualFile file, boolean isTestSource, @NotNull String packagePrefix);
@NotNull
<P extends JpsElement>
SourceFolder addSourceFolder(@NotNull VirtualFile file, @NotNull JpsModuleSourceRootType<P> type, @NotNull P properties);
@NotNull
<P extends JpsElement>
SourceFolder addSourceFolder(@NotNull VirtualFile file, @NotNull JpsModuleSourceRootType<P> type);
/**
* Adds a source or test source root under the content root.
*
* @param url the file or directory url to add as a source root.
* @param isTestSource true if the file or directory is added as a test source root.
* @return the object representing the added root.
*/
@NotNull
SourceFolder addSourceFolder(@NotNull String url, boolean isTestSource);
@NotNull
<P extends JpsElement>
SourceFolder addSourceFolder(@NotNull String url, @NotNull JpsModuleSourceRootType<P> type);
@NotNull
<P extends JpsElement>
SourceFolder addSourceFolder(@NotNull String url, @NotNull JpsModuleSourceRootType<P> type, @NotNull P properties);
/**
* Removes a source or test source root from this content root.
*
* @param sourceFolder the source root to remove (must belong to this content root).
*/
void removeSourceFolder(@NotNull SourceFolder sourceFolder);
void clearSourceFolders();
/**
* Adds an exclude root under the content root.
*
* @param file the file or directory to add as an exclude root.
* @return the object representing the added root.
*/
ExcludeFolder addExcludeFolder(@NotNull VirtualFile file);
/**
* Adds an exclude root under the content root.
*
* @param url the file or directory url to add as an exclude root.
* @return the object representing the added root.
*/
ExcludeFolder addExcludeFolder(@NotNull String url);
/**
* Removes an exclude root from this content root.
*
* @param excludeFolder the exclude root to remove (must belong to this content root).
*/
void removeExcludeFolder(@NotNull ExcludeFolder excludeFolder);
/**
* Removes an exclude root from this content root.
* @param url url of the exclude root
* @return {@code true} if the exclude root was removed
*/
boolean removeExcludeFolder(@NotNull String url);
void clearExcludeFolders();
}