diff options
author | Tor Norbye <tnorbye@google.com> | 2014-07-25 20:12:40 +0000 |
---|---|---|
committer | Gerrit Code Review <noreply-gerritcodereview@google.com> | 2014-07-24 20:55:36 +0000 |
commit | 6044be7330c93bc8dacb0f63e62da8029f39a16f (patch) | |
tree | 0ba72f5de1949e0527874a799baa224cbe1537e0 /platform/lang-impl/src/com/intellij/profile/codeInspection/ui/ToolDescriptors.java | |
parent | b03a5855292feb8c331815f883fe64372aacd872 (diff) | |
parent | e5266e2343c8d275d79fa0be725180d0fe3a993c (diff) | |
download | idea-6044be7330c93bc8dacb0f63e62da8029f39a16f.tar.gz |
Merge "Merge remote-tracking branch 'aosp/upstream-master' into merge"
Diffstat (limited to 'platform/lang-impl/src/com/intellij/profile/codeInspection/ui/ToolDescriptors.java')
-rw-r--r-- | platform/lang-impl/src/com/intellij/profile/codeInspection/ui/ToolDescriptors.java | 70 |
1 files changed, 70 insertions, 0 deletions
diff --git a/platform/lang-impl/src/com/intellij/profile/codeInspection/ui/ToolDescriptors.java b/platform/lang-impl/src/com/intellij/profile/codeInspection/ui/ToolDescriptors.java new file mode 100644 index 000000000000..47826735ec33 --- /dev/null +++ b/platform/lang-impl/src/com/intellij/profile/codeInspection/ui/ToolDescriptors.java @@ -0,0 +1,70 @@ +/* + * 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.profile.codeInspection.ui; + +import com.intellij.codeInspection.ex.Descriptor; +import com.intellij.codeInspection.ex.InspectionProfileImpl; +import com.intellij.codeInspection.ex.InspectionToolWrapper; +import com.intellij.codeInspection.ex.ScopeToolState; +import com.intellij.openapi.project.Project; +import org.jetbrains.annotations.NotNull; + +import java.util.ArrayList; +import java.util.List; + +/** + * @author Dmitry Batkovich + */ +public class ToolDescriptors { + + @NotNull + private final Descriptor myDefaultDescriptor; + @NotNull + private final List<Descriptor> myNonDefaultDescriptors; + + private ToolDescriptors(final @NotNull Descriptor defaultDescriptor, + final @NotNull List<Descriptor> nonDefaultDescriptors) { + myDefaultDescriptor = defaultDescriptor; + myNonDefaultDescriptors = nonDefaultDescriptors; + } + + public static ToolDescriptors fromScopeToolState(final ScopeToolState state, + final InspectionProfileImpl profile, + final Project project) { + final InspectionToolWrapper toolWrapper = state.getTool(); + final List<ScopeToolState> nonDefaultTools = profile.getNonDefaultTools(toolWrapper.getShortName(), project); + final ArrayList<Descriptor> descriptors = new ArrayList<Descriptor>(nonDefaultTools.size()); + for (final ScopeToolState nonDefaultToolState : nonDefaultTools) { + descriptors.add(new Descriptor(nonDefaultToolState, profile, project)); + } + return new ToolDescriptors(new Descriptor(state, profile, project), descriptors); + } + + @NotNull + public Descriptor getDefaultDescriptor() { + return myDefaultDescriptor; + } + + @NotNull + public List<Descriptor> getNonDefaultDescriptors() { + return myNonDefaultDescriptors; + } + + @NotNull + public ScopeToolState getDefaultScopeToolState() { + return myDefaultDescriptor.getState(); + } +} |