Search in sources :

Example 1 with Graph

use of com.intellij.util.graph.Graph in project intellij-community by JetBrains.

the class JavaModuleGraphUtil method findCycles.

// Looks for cycles between Java modules in the project sources.
// Library/JDK modules are excluded - in assumption there can't be any lib -> src dependencies.
// Module references are resolved "globally" (i.e., without taking project dependencies into account).
private static List<Set<PsiJavaModule>> findCycles(Project project) {
    Set<PsiJavaModule> projectModules = ContainerUtil.newHashSet();
    for (Module module : ModuleManager.getInstance(project).getModules()) {
        Collection<VirtualFile> files = FilenameIndex.getVirtualFilesByName(project, MODULE_INFO_FILE, module.getModuleScope(false));
        // aborts the process when there are incorrect modules in the project
        if (files.size() > 1)
            return Collections.emptyList();
        Optional.ofNullable(ContainerUtil.getFirstItem(files)).map(PsiManager.getInstance(project)::findFile).map(f -> f instanceof PsiJavaFile ? ((PsiJavaFile) f).getModuleDeclaration() : null).ifPresent(projectModules::add);
    }
    if (!projectModules.isEmpty()) {
        MultiMap<PsiJavaModule, PsiJavaModule> relations = MultiMap.create();
        for (PsiJavaModule module : projectModules) {
            for (PsiRequiresStatement statement : module.getRequires()) {
                PsiJavaModule dependency = PsiJavaModuleReference.resolve(statement, statement.getModuleName(), true);
                if (dependency != null && projectModules.contains(dependency)) {
                    relations.putValue(module, dependency);
                }
            }
        }
        if (!relations.isEmpty()) {
            Graph<PsiJavaModule> graph = new ChameleonGraph<>(relations, false);
            DFSTBuilder<PsiJavaModule> builder = new DFSTBuilder<>(graph);
            Collection<Collection<PsiJavaModule>> components = builder.getComponents();
            if (!components.isEmpty()) {
                return components.stream().map(ContainerUtil::newLinkedHashSet).collect(Collectors.toList());
            }
        }
    }
    return Collections.emptyList();
}
Also used : VirtualFile(com.intellij.openapi.vfs.VirtualFile) Trinity(com.intellij.openapi.util.Trinity) java.util(java.util) ModuleManager(com.intellij.openapi.module.ModuleManager) VirtualFile(com.intellij.openapi.vfs.VirtualFile) FilenameIndex(com.intellij.psi.search.FilenameIndex) BiFunction(java.util.function.BiFunction) DFSTBuilder(com.intellij.util.graph.DFSTBuilder) THashSet(gnu.trove.THashSet) OUT_OF_CODE_BLOCK_MODIFICATION_COUNT(com.intellij.psi.util.PsiModificationTracker.OUT_OF_CODE_BLOCK_MODIFICATION_COUNT) ContainerUtil(com.intellij.util.containers.ContainerUtil) Collectors(java.util.stream.Collectors) MODULE_INFO_FILE(com.intellij.psi.PsiJavaModule.MODULE_INFO_FILE) CachedValuesManager(com.intellij.psi.util.CachedValuesManager) Graph(com.intellij.util.graph.Graph) LightJavaModule(com.intellij.psi.impl.light.LightJavaModule) Nullable(org.jetbrains.annotations.Nullable) PsiJavaModuleReference(com.intellij.psi.impl.source.PsiJavaModuleReference) GraphGenerator(com.intellij.util.graph.GraphGenerator) Project(com.intellij.openapi.project.Project) Result(com.intellij.psi.util.CachedValueProvider.Result) com.intellij.psi(com.intellij.psi) Module(com.intellij.openapi.module.Module) NotNull(org.jetbrains.annotations.NotNull) MultiMap(com.intellij.util.containers.MultiMap) DFSTBuilder(com.intellij.util.graph.DFSTBuilder) LightJavaModule(com.intellij.psi.impl.light.LightJavaModule) Module(com.intellij.openapi.module.Module)

Example 2 with Graph

use of com.intellij.util.graph.Graph in project intellij-community by JetBrains.

the class JavaModuleGraphUtil method buildRequiresGraph.

// Starting from source modules, collects all module dependencies in the project.
// The resulting graph is used for tracing readability and checking package conflicts.
private static RequiresGraph buildRequiresGraph(Project project) {
    MultiMap<PsiJavaModule, PsiJavaModule> relations = MultiMap.create();
    Set<String> transitiveEdges = ContainerUtil.newTroveSet();
    for (Module module : ModuleManager.getInstance(project).getModules()) {
        Collection<VirtualFile> files = FilenameIndex.getVirtualFilesByName(project, MODULE_INFO_FILE, module.getModuleScope(false));
        Optional.ofNullable(ContainerUtil.getFirstItem(files)).map(PsiManager.getInstance(project)::findFile).map(f -> f instanceof PsiJavaFile ? ((PsiJavaFile) f).getModuleDeclaration() : null).ifPresent(m -> visit(m, relations, transitiveEdges));
    }
    Graph<PsiJavaModule> graph = GraphGenerator.generate(new ChameleonGraph<>(relations, true));
    return new RequiresGraph(graph, transitiveEdges);
}
Also used : VirtualFile(com.intellij.openapi.vfs.VirtualFile) Trinity(com.intellij.openapi.util.Trinity) java.util(java.util) ModuleManager(com.intellij.openapi.module.ModuleManager) VirtualFile(com.intellij.openapi.vfs.VirtualFile) FilenameIndex(com.intellij.psi.search.FilenameIndex) BiFunction(java.util.function.BiFunction) DFSTBuilder(com.intellij.util.graph.DFSTBuilder) THashSet(gnu.trove.THashSet) OUT_OF_CODE_BLOCK_MODIFICATION_COUNT(com.intellij.psi.util.PsiModificationTracker.OUT_OF_CODE_BLOCK_MODIFICATION_COUNT) ContainerUtil(com.intellij.util.containers.ContainerUtil) Collectors(java.util.stream.Collectors) MODULE_INFO_FILE(com.intellij.psi.PsiJavaModule.MODULE_INFO_FILE) CachedValuesManager(com.intellij.psi.util.CachedValuesManager) Graph(com.intellij.util.graph.Graph) LightJavaModule(com.intellij.psi.impl.light.LightJavaModule) Nullable(org.jetbrains.annotations.Nullable) PsiJavaModuleReference(com.intellij.psi.impl.source.PsiJavaModuleReference) GraphGenerator(com.intellij.util.graph.GraphGenerator) Project(com.intellij.openapi.project.Project) Result(com.intellij.psi.util.CachedValueProvider.Result) com.intellij.psi(com.intellij.psi) Module(com.intellij.openapi.module.Module) NotNull(org.jetbrains.annotations.NotNull) MultiMap(com.intellij.util.containers.MultiMap) LightJavaModule(com.intellij.psi.impl.light.LightJavaModule) Module(com.intellij.openapi.module.Module)

Example 3 with Graph

use of com.intellij.util.graph.Graph in project kotlin by JetBrains.

the class IntellijLintProject method findAndroidModule.

/** Find an Android module that depends on this module; prefer app modules over library modules */
@Nullable
private static Module findAndroidModule(@NonNull final Module module) {
    // Search for dependencies of this module
    Graph<Module> graph = ApplicationManager.getApplication().runReadAction(new Computable<Graph<Module>>() {

        @Override
        public Graph<Module> compute() {
            com.intellij.openapi.project.Project project = module.getProject();
            if (project.isDisposed()) {
                return null;
            }
            return ModuleManager.getInstance(project).moduleGraph();
        }
    });
    if (graph == null) {
        return null;
    }
    Set<AndroidFacet> facets = Sets.newHashSet();
    HashSet<Module> seen = Sets.newHashSet();
    seen.add(module);
    addAndroidModules(facets, seen, graph, module);
    // Prefer Android app modules
    for (AndroidFacet facet : facets) {
        if (!facet.isLibraryProject()) {
            return facet.getModule();
        }
    }
    // Resort to library modules if no app module depends directly on it
    if (!facets.isEmpty()) {
        return facets.iterator().next().getModule();
    }
    return null;
}
Also used : Project(com.android.tools.klint.detector.api.Project) Graph(com.intellij.util.graph.Graph) Module(com.intellij.openapi.module.Module) AndroidFacet(org.jetbrains.android.facet.AndroidFacet) Nullable(org.jetbrains.annotations.Nullable)

Example 4 with Graph

use of com.intellij.util.graph.Graph in project android by JetBrains.

the class LintIdeProject method findAndroidModule.

/** Find an Android module that depends on this module; prefer app modules over library modules */
@Nullable
private static Module findAndroidModule(@NonNull final Module module) {
    // Search for dependencies of this module
    Graph<Module> graph = ApplicationManager.getApplication().runReadAction(new Computable<Graph<Module>>() {

        @Override
        public Graph<Module> compute() {
            com.intellij.openapi.project.Project project = module.getProject();
            if (project.isDisposed()) {
                return null;
            }
            return ModuleManager.getInstance(project).moduleGraph();
        }
    });
    if (graph == null) {
        return null;
    }
    Set<AndroidFacet> facets = Sets.newHashSet();
    HashSet<Module> seen = Sets.newHashSet();
    seen.add(module);
    addAndroidModules(facets, seen, graph, module);
    // Prefer Android app modules
    for (AndroidFacet facet : facets) {
        if (facet.isAppProject()) {
            return facet.getModule();
        }
    }
    // Resort to library modules if no app module depends directly on it
    if (!facets.isEmpty()) {
        return facets.iterator().next().getModule();
    }
    return null;
}
Also used : Project(com.android.tools.lint.detector.api.Project) Graph(com.intellij.util.graph.Graph) Module(com.intellij.openapi.module.Module) AndroidFacet(org.jetbrains.android.facet.AndroidFacet) Nullable(org.jetbrains.annotations.Nullable)

Aggregations

Module (com.intellij.openapi.module.Module)4 Graph (com.intellij.util.graph.Graph)4 Nullable (org.jetbrains.annotations.Nullable)4 ModuleManager (com.intellij.openapi.module.ModuleManager)2 Project (com.intellij.openapi.project.Project)2 Trinity (com.intellij.openapi.util.Trinity)2 VirtualFile (com.intellij.openapi.vfs.VirtualFile)2 com.intellij.psi (com.intellij.psi)2 MODULE_INFO_FILE (com.intellij.psi.PsiJavaModule.MODULE_INFO_FILE)2 LightJavaModule (com.intellij.psi.impl.light.LightJavaModule)2 PsiJavaModuleReference (com.intellij.psi.impl.source.PsiJavaModuleReference)2 FilenameIndex (com.intellij.psi.search.FilenameIndex)2 Result (com.intellij.psi.util.CachedValueProvider.Result)2 CachedValuesManager (com.intellij.psi.util.CachedValuesManager)2 OUT_OF_CODE_BLOCK_MODIFICATION_COUNT (com.intellij.psi.util.PsiModificationTracker.OUT_OF_CODE_BLOCK_MODIFICATION_COUNT)2 ContainerUtil (com.intellij.util.containers.ContainerUtil)2 MultiMap (com.intellij.util.containers.MultiMap)2 DFSTBuilder (com.intellij.util.graph.DFSTBuilder)2 GraphGenerator (com.intellij.util.graph.GraphGenerator)2 THashSet (gnu.trove.THashSet)2