export html action: do not traverse tree for excluded elements
[idea/community.git] / platform / lang-impl / src / com / intellij / codeInspection / ui / ExcludedInspectionTreeNodesManager.java
1 /*
2  * Copyright 2000-2016 JetBrains s.r.o.
3  *
4  * Licensed under the Apache License, Version 2.0 (the "License");
5  * you may not use this file except in compliance with the License.
6  * You may obtain a copy of the License at
7  *
8  * http://www.apache.org/licenses/LICENSE-2.0
9  *
10  * Unless required by applicable law or agreed to in writing, software
11  * distributed under the License is distributed on an "AS IS" BASIS,
12  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13  * See the License for the specific language governing permissions and
14  * limitations under the License.
15  */
16 package com.intellij.codeInspection.ui;
17
18
19 import com.intellij.codeInspection.CommonProblemDescriptor;
20 import com.intellij.codeInspection.offlineViewer.OfflineProblemDescriptorNode;
21 import com.intellij.codeInspection.offlineViewer.OfflineRefElementNode;
22 import com.intellij.codeInspection.reference.RefEntity;
23 import com.intellij.util.containers.FactoryMap;
24 import gnu.trove.THashSet;
25 import org.jetbrains.annotations.NotNull;
26 import org.jetbrains.annotations.Nullable;
27
28 import java.util.Collections;
29 import java.util.Map;
30 import java.util.Set;
31
32 /**
33  * @author Dmitry Batkovich
34  */
35 public class ExcludedInspectionTreeNodesManager {
36   @SuppressWarnings("MismatchedQueryAndUpdateOfCollection")
37   private final Map<Class, Set<Object>> myExcludedNodeObjects = new FactoryMap<Class, Set<Object>>() {
38     @Nullable
39     @Override
40     protected Set<Object> create(Class key) {
41       return new THashSet<Object>();
42     }
43   };
44
45   private final boolean myOffline;
46
47   public ExcludedInspectionTreeNodesManager(boolean offline) {
48     myOffline = offline;
49   }
50
51   public synchronized boolean isExcluded(InspectionTreeNode node) {
52     final Set<?> excluded = myExcludedNodeObjects.get(node.getClass());
53     return excluded.contains(node.getUserObject());
54   }
55
56   public synchronized void exclude(InspectionTreeNode node) {
57     myExcludedNodeObjects.get(node.getClass()).add(node.getUserObject());
58   }
59
60   public synchronized void amnesty(InspectionTreeNode node) {
61     myExcludedNodeObjects.get(node.getClass()).remove(node.getUserObject());
62   }
63
64   public synchronized boolean containsRefEntity(@NotNull RefEntity entity) {
65     return myExcludedNodeObjects.getOrDefault(myOffline ? OfflineRefElementNode.class : RefElementNode.class, Collections.emptySet()).contains(entity);
66   }
67
68   public synchronized boolean containsProblemDescriptor(@NotNull CommonProblemDescriptor descriptor) {
69     return myExcludedNodeObjects.getOrDefault(myOffline ? OfflineProblemDescriptorNode.class : ProblemDescriptionNode.class, Collections.emptySet()).contains(descriptor);
70   }
71 }