/*
* Copyright 2013-2017 consulo.io
*
* 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 consulo.csharp.ide.highlight.check.impl;
import java.util.ArrayList;
import java.util.Collections;
import java.util.LinkedHashMap;
import java.util.List;
import java.util.Map;
import org.jetbrains.annotations.NotNull;
import consulo.annotations.RequiredReadAction;
import consulo.csharp.ide.codeInsight.actions.RemoveModifierFix;
import consulo.csharp.ide.highlight.CSharpHighlightContext;
import consulo.csharp.ide.highlight.check.CompilerCheck;
import consulo.csharp.lang.psi.CSharpAccessModifier;
import consulo.csharp.lang.psi.CSharpModifier;
import consulo.csharp.module.extension.CSharpLanguageVersion;
import consulo.dotnet.psi.DotNetModifierList;
import consulo.dotnet.psi.DotNetModifierListOwner;
import com.intellij.psi.PsiElement;
/**
* @author VISTALL
* @since 10.06.14
*/
public class CS0107 extends CompilerCheck<DotNetModifierListOwner>
{
@RequiredReadAction
@NotNull
@Override
public List<CompilerCheckBuilder> check(@NotNull CSharpLanguageVersion languageVersion, @NotNull CSharpHighlightContext highlightContext, @NotNull DotNetModifierListOwner element)
{
DotNetModifierList modifierList = element.getModifierList();
if(modifierList == null)
{
return Collections.emptyList();
}
Map<CSharpAccessModifier, Map<CSharpModifier, PsiElement>> map = new LinkedHashMap<CSharpAccessModifier, Map<CSharpModifier, PsiElement>>(5);
for(CSharpAccessModifier value : CSharpAccessModifier.VALUES)
{
collectModifierElements(value, modifierList, map);
}
if(map.size() <= 1)
{
return Collections.emptyList();
}
List<CompilerCheckBuilder> list = new ArrayList<CompilerCheckBuilder>(map.size());
for(Map.Entry<CSharpAccessModifier, Map<CSharpModifier, PsiElement>> entry : map.entrySet())
{
RemoveModifierFix modifierFix = new RemoveModifierFix(entry.getValue().keySet().toArray(CSharpModifier.EMPTY_ARRAY), element);
for(Map.Entry<CSharpModifier, PsiElement> psiElement : entry.getValue().entrySet())
{
list.add(newBuilder(psiElement.getValue()).addQuickFix(modifierFix));
}
}
return list;
}
private static void collectModifierElements(CSharpAccessModifier accessModifier,
DotNetModifierList modifierList,
Map<CSharpAccessModifier, Map<CSharpModifier, PsiElement>> result)
{
if(accessModifier == CSharpAccessModifier.NONE)
{
return;
}
Map<CSharpModifier, PsiElement> map = new LinkedHashMap<CSharpModifier, PsiElement>();
CSharpModifier[] modifiers = accessModifier.getModifiers();
for(CSharpModifier modifier : modifiers)
{
if((modifier == CSharpModifier.INTERNAL || modifier == CSharpModifier.PROTECTED) && result.containsKey(CSharpAccessModifier
.PROTECTED_INTERNAL))
{
continue;
}
PsiElement modifierElement = modifierList.getModifierElement(modifier);
if(modifierElement != null)
{
map.put(modifier, modifierElement);
}
}
// dont return array if size of elements if not equal tokens
if(modifiers.length != map.size())
{
return;
}
result.put(accessModifier, map);
}
}