/*
* Copyright 2010 The authors
* 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.struts2.reference;
import com.intellij.psi.PsiElement;
import com.intellij.psi.PsiReference;
import com.intellij.psi.PsiReferenceBase;
import com.intellij.psi.PsiReferenceProvider;
import com.intellij.psi.xml.XmlAttributeValue;
import com.intellij.util.ProcessingContext;
import org.jetbrains.annotations.NonNls;
import org.jetbrains.annotations.NotNull;
import java.util.Arrays;
/**
* Provides reference functionality for static String values.
*
* @author Yann Cébron
*/
public class StaticStringValuesReferenceProvider extends PsiReferenceProvider {
private final boolean allowOtherValues;
private final String[] values;
/**
* Creates a reference provider with the given values for autocompletion.
* Other values will *not* be highlighted as errors.
*
* @param values Autocompletion values.
*/
public StaticStringValuesReferenceProvider(@NotNull @NonNls final String... values) {
this(true, values);
}
/**
* Creates a reference provider with the given values for autocompletion and optional error highlighting.
*
* @param allowOtherValues Set to false to enable error highlighting.
* @param values Autocompletion values.
*/
public StaticStringValuesReferenceProvider(final boolean allowOtherValues, @NotNull @NonNls final String... values) {
this.allowOtherValues = allowOtherValues;
Arrays.sort(values); // make sure Arrays.binarySearch() works later on..
this.values = values;
}
@NotNull
public PsiReference[] getReferencesByElement(@NotNull final PsiElement element,
@NotNull final ProcessingContext context) {
return new PsiReference[]{new PsiReferenceBase<XmlAttributeValue>((XmlAttributeValue) element) {
public PsiElement resolve() {
final String myValue = myElement.getValue();
if (allowOtherValues ||
TaglibUtil.isDynamicExpression(myValue)) {
return myElement;
}
return Arrays.binarySearch(values, myValue) > -1 ? myElement : null;
}
@NotNull
public Object[] getVariants() {
return values;
}
}};
}
}