blob: 297f4478d261346335b447413dcfaf8146de7cd5 [file] [log] [blame]
/*
* 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.codeInspection.i18n.inconsistentResourceBundle;
import com.intellij.codeInspection.*;
import com.intellij.codeInspection.reference.RefManager;
import com.intellij.lang.properties.IProperty;
import com.intellij.lang.properties.psi.PropertiesFile;
import com.intellij.util.containers.BidirectionalMap;
import gnu.trove.THashSet;
import org.jetbrains.annotations.NotNull;
import java.util.List;
import java.util.Map;
import java.util.Set;
/**
* @author Dmitry Batkovich
*/
public class MissingTranslationsInspectionProvider implements InconsistentResourceBundleInspectionProvider {
@NotNull
@Override
public String getName() {
return "REPORT_MISSING_TRANSLATIONS";
}
@NotNull
@Override
public String getPresentableName() {
return InspectionsBundle.message("inconsistent.bundle.report.missing.translations");
}
@Override
public void check(BidirectionalMap<PropertiesFile, PropertiesFile> parents,
List<PropertiesFile> files,
Map<PropertiesFile, Set<String>> keysUpToParent,
Map<PropertiesFile, Map<String, String>> propertiesFilesNamesMaps,
InspectionManager manager,
RefManager refManager,
ProblemDescriptionsProcessor processor) {
for (PropertiesFile file : files) {
PropertiesFile parent = parents.get(file);
if (parent == null) continue;
List<PropertiesFile> children = parents.getKeysByValue(file);
boolean isLeaf = children == null || children.isEmpty();
if (!isLeaf) continue;
Set<String> keys = propertiesFilesNamesMaps.get(file).keySet();
Set<String> parentKeys = new THashSet<String>(keysUpToParent.get(parent));
if (parent.getLocale().getLanguage().equals(file.getLocale().getLanguage())) {
// properties can be left untranslated in the dialect files
keys = new THashSet<String>(keys);
keys.addAll(propertiesFilesNamesMaps.get(parent).keySet());
parent = parents.get(parent);
if (parent == null) continue;
parentKeys = new THashSet<String>(keysUpToParent.get(parent));
}
parentKeys.removeAll(keys);
for (String untranslatedKey : parentKeys) {
IProperty untranslatedProperty = null;
PropertiesFile untranslatedFile = parent;
while (untranslatedFile != null) {
untranslatedProperty = untranslatedFile.findPropertyByKey(untranslatedKey);
if (untranslatedProperty != null) break;
untranslatedFile = parents.get(untranslatedFile);
}
assert untranslatedProperty != null;
String message = InspectionsBundle.message("inconsistent.bundle.untranslated.property.error", untranslatedKey, file.getName());
ProblemDescriptor descriptor = manager.createProblemDescriptor(untranslatedProperty.getPsiElement(), message, false, LocalQuickFix.EMPTY_ARRAY,
ProblemHighlightType.GENERIC_ERROR_OR_WARNING);
processor.addProblemElement(refManager.getReference(untranslatedFile.getContainingFile()), descriptor);
}
}
}
}