blob: 81e340679a50773420c47564e93a98d83afee6fe [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.
*/
/*
* User: anna
* Date: 20-Apr-2009
*/
package com.intellij.codeInspection.ex;
import com.intellij.codeHighlighting.HighlightDisplayLevel;
import com.intellij.openapi.diagnostic.Logger;
import com.intellij.openapi.project.Project;
import com.intellij.openapi.util.JDOMUtil;
import com.intellij.openapi.util.WriteExternalException;
import com.intellij.psi.search.scope.packageSet.NamedScope;
import com.intellij.psi.search.scope.packageSet.NamedScopesHolder;
import org.jdom.Element;
import org.jetbrains.annotations.NonNls;
import org.jetbrains.annotations.NotNull;
import org.jetbrains.annotations.Nullable;
import javax.swing.*;
public class ScopeToolState {
private NamedScope myScope;
@NotNull
private final String myScopeName;
private InspectionToolWrapper myToolWrapper;
private boolean myEnabled;
private HighlightDisplayLevel myLevel;
private boolean myAdditionalConfigPanelCreated = false;
private JComponent myAdditionalConfigPanel;
private static final Logger LOG = Logger.getInstance("#" + ScopeToolState.class.getName());
public ScopeToolState(@NotNull NamedScope scope, @NotNull InspectionToolWrapper toolWrapper, boolean enabled, @NotNull HighlightDisplayLevel level) {
this(scope.getName(), toolWrapper, enabled, level);
myScope = scope;
}
public ScopeToolState(@NotNull String scopeName, @NotNull InspectionToolWrapper toolWrapper, boolean enabled, @NotNull HighlightDisplayLevel level) {
myScopeName = scopeName;
myToolWrapper = toolWrapper;
myEnabled = enabled;
myLevel = level;
}
public ScopeToolState copy() {
return new ScopeToolState(myScopeName, myToolWrapper, myEnabled, myLevel);
}
@Nullable
public NamedScope getScope(Project project) {
if (myScope == null) {
if (project != null) {
myScope = NamedScopesHolder.getScope(project, myScopeName);
}
}
return myScope;
}
@NotNull
public String getScopeName() {
return myScopeName;
}
@NotNull
public InspectionToolWrapper getTool() {
return myToolWrapper;
}
public boolean isEnabled() {
return myEnabled;
}
@NotNull
public HighlightDisplayLevel getLevel() {
return myLevel;
}
public void setEnabled(boolean enabled) {
myEnabled = enabled;
}
public void setLevel(@NotNull HighlightDisplayLevel level) {
myLevel = level;
}
@Nullable
public JComponent getAdditionalConfigPanel() {
if (!myAdditionalConfigPanelCreated) {
myAdditionalConfigPanel = myToolWrapper.getTool().createOptionsPanel();
myAdditionalConfigPanelCreated = true;
}
return myAdditionalConfigPanel;
}
public void resetConfigPanel(){
myAdditionalConfigPanel = null;
}
public void setTool(@NotNull InspectionToolWrapper tool) {
myToolWrapper = tool;
}
public boolean equalTo(@NotNull ScopeToolState state2) {
if (isEnabled() != state2.isEnabled()) return false;
if (getLevel() != state2.getLevel()) return false;
InspectionToolWrapper toolWrapper = getTool();
InspectionToolWrapper toolWrapper2 = state2.getTool();
if (!toolWrapper.isInitialized() && !toolWrapper2.isInitialized()) return true;
try {
@NonNls String tempRoot = "root";
Element oldToolSettings = new Element(tempRoot);
toolWrapper.getTool().writeSettings(oldToolSettings);
Element newToolSettings = new Element(tempRoot);
toolWrapper2.getTool().writeSettings(newToolSettings);
return JDOMUtil.areElementsEqual(oldToolSettings, newToolSettings);
}
catch (WriteExternalException e) {
LOG.error(e);
}
return false;
}
public void scopesChanged() {
myScope = null;
}
}