blob: deb9134da0c091cfd090b3af14140ffa8a5889e8 [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.module.Module;
import org.jetbrains.annotations.NotNull;
/**
* Interface for getting information about the contents and dependencies of a module.
*
* @author dsl
*/
public abstract class ModuleRootManager implements ModuleRootModel {
/**
* Returns the module root manager instance for the specified module.
*
* @param module the module for which the root manager is requested.
* @return the root manager instance.
*/
public static ModuleRootManager getInstance(@NotNull Module module) {
return module.getComponent(ModuleRootManager.class);
}
/**
* Returns the file index for the current module.
*
* @return the file index instance.
*/
@NotNull
public abstract ModuleFileIndex getFileIndex();
/**
* Returns the interface for modifying the set of roots for this module. Must be called in a read action.
* !!!!! ACHTUNG !!!!!: This model MUST be either committed {@link ModifiableRootModel#commit()} or disposed {@link ModifiableRootModel#dispose()}
*
* @return the modifiable root model.
*/
@NotNull
public abstract ModifiableRootModel getModifiableModel();
/**
* Returns the list of modules on which the current module directly depends. The method does not traverse
* the entire dependency structure - dependencies of dependency modules are not included in the returned list.
*
* @return the list of module direct dependencies.
*/
@NotNull public abstract Module[] getDependencies();
/**
* Returns the list of modules on which the current module directly depends. The method does not traverse
* the entire dependency structure - dependencies of dependency modules are not included in the returned list.
*
* @param includeTests whether test-only dependencies should be included
* @return the list of module direct dependencies.
*/
@NotNull public abstract Module[] getDependencies(boolean includeTests);
/**
* Checks if the current module directly depends on the specified module.
*
* @param module the module to ckeck.
* @return true if <code>module</code> is contained in the list of dependencies for the current module, false otherwise.
*/
public abstract boolean isDependsOn(Module module);
}