blob: c4fb34c5ce54c3fa52e79921d5499b7817e25d2b [file] [log] [blame]
/*
* 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.intellij.internal;
import com.intellij.openapi.actionSystem.AnActionEvent;
import com.intellij.openapi.module.Module;
import com.intellij.openapi.module.ModuleManager;
import com.intellij.openapi.project.DumbAwareAction;
import com.intellij.openapi.project.Project;
import com.intellij.openapi.roots.ModuleRootManager;
import com.intellij.openapi.roots.impl.DirectoryIndexExcludePolicy;
import com.intellij.openapi.vfs.VirtualFile;
import com.intellij.openapi.vfs.VirtualFileManager;
import com.intellij.openapi.vfs.newvfs.NewVirtualFile;
import com.intellij.openapi.vfs.newvfs.persistent.FSRecords;
import com.intellij.openapi.vfs.newvfs.persistent.PersistentFS;
import java.util.*;
/**
* @author nik
*/
@SuppressWarnings("UseOfSystemOutOrSystemErr")
public class DumpVfsInfoForExcludedFilesAction extends DumbAwareAction {
public DumpVfsInfoForExcludedFilesAction() {
super("Dump VFS content for files under excluded roots");
}
@Override
public void actionPerformed(AnActionEvent e) {
Project project = e.getProject();
if (project == null) return;
Set<String> excludeRoots = new HashSet<String>();
for (Module module : ModuleManager.getInstance(project).getModules()) {
Collections.addAll(excludeRoots, ModuleRootManager.getInstance(module).getExcludeRootUrls());
}
for (DirectoryIndexExcludePolicy policy : DirectoryIndexExcludePolicy.EP_NAME.getExtensions(project)) {
for (VirtualFile file : policy.getExcludeRootsForProject()) {
excludeRoots.add(file.getUrl());
}
}
if (excludeRoots.isEmpty()) {
System.out.println("No excluded roots found in project.");
}
for (String root : excludeRoots) {
VirtualFile file = VirtualFileManager.getInstance().findFileByUrl(root);
if (file == null) {
System.out.println(root + " not in VFS");
continue;
}
dumpChildrenInDbRecursively(file, 0);
}
}
private static void dumpChildrenInDbRecursively(VirtualFile dir, int depth) {
if (!(dir instanceof NewVirtualFile)) {
System.out.println(dir.getPresentableUrl() + ": not in db (" + dir.getClass().getName() + ")");
return;
}
List<VirtualFile> dirs = new ArrayList<VirtualFile>();
int inDb = 0, contentInDb = 0, nullChildren = 0;
PersistentFS persistentFS = PersistentFS.getInstance();
if (persistentFS.wereChildrenAccessed(dir)) {
for (String name : persistentFS.listPersisted(dir)) {
inDb++;
NewVirtualFile child = ((NewVirtualFile)dir).refreshAndFindChild(name);
if (child == null) {
nullChildren++;
continue;
}
if (child.isDirectory()) {
dirs.add(child);
}
else if (FSRecords.getContentId(child.getId()) != 0) {
contentInDb++;
}
}
}
System.out.print(dir.getPresentableUrl() + ": " + inDb + " children in db");
if (contentInDb > 0) {
System.out.print(", content of " + contentInDb + " files in db");
}
if (nullChildren > 0) {
System.out.print(", " + nullChildren + " invalid files in db");
}
System.out.println();
if (depth > 10) {
System.out.println("too deep, skipping children");
}
else {
for (VirtualFile childDir : dirs) {
dumpChildrenInDbRecursively(childDir, depth+1);
}
}
}
}