/*
* WPCleaner: A tool to help on Wikipedia maintenance tasks.
* Copyright (C) 2013 Nicolas Vervelle
*
* See README.txt file for licensing information.
*/
package org.wikipediacleaner.api.check.algorithm;
import java.util.Collection;
import java.util.List;
import java.util.Map;
import org.wikipediacleaner.api.check.CheckErrorResult;
import org.wikipediacleaner.api.check.CheckErrorResult.ErrorLevel;
import org.wikipediacleaner.api.constants.WPCConfiguration;
import org.wikipediacleaner.api.data.Page;
import org.wikipediacleaner.api.data.PageAnalysis;
import org.wikipediacleaner.api.data.PageElementTag;
import org.wikipediacleaner.api.data.PageElementTemplate;
import org.wikipediacleaner.i18n.GT;
/**
* Algorithm for analyzing error 111 of check wikipedia project.
* Error 111: Ref after last reference list
*/
public class CheckErrorAlgorithm111 extends CheckErrorAlgorithmBase {
public CheckErrorAlgorithm111() {
super("Ref after last reference list");
}
/**
* Analyze a page to check if errors are present.
*
* @param analysis Page analysis.
* @param errors Errors found in the page.
* @param onlyAutomatic True if analysis could be restricted to errors automatically fixed.
* @return Flag indicating if the error was found.
*/
@Override
public boolean analyze(
PageAnalysis analysis,
Collection<CheckErrorResult> errors, boolean onlyAutomatic) {
if (analysis == null) {
return false;
}
// Analyzing text for <ref> tags
PageElementTag lastRefTag = null;
List<PageElementTag> refTags = analysis.getTags(PageElementTag.TAG_WIKI_REF);
if ((refTags != null) && (refTags.size() > 0)) {
for (int numTag = refTags.size() - 1; (numTag >= 0) && (lastRefTag == null); numTag--) {
boolean usefulRef = true;
PageElementTag refTag = refTags.get(numTag);
if (analysis.getSurroundingTag(PageElementTag.TAG_WIKI_NOWIKI, refTag.getBeginIndex()) != null) {
usefulRef = false;
}
if (usefulRef) {
lastRefTag = refTag;
}
}
}
if (lastRefTag == null) {
return false;
}
boolean referencesFound = false;
// Analyzing text for <references> tags
List<PageElementTag> referencesTags = analysis.getTags(PageElementTag.TAG_WIKI_REFERENCES);
if (referencesTags != null) {
for (PageElementTag referencesTag : referencesTags) {
if (referencesTag.isComplete()) {
if (referencesTag.getCompleteEndIndex() > lastRefTag.getCompleteEndIndex()) {
return false;
}
referencesFound = true;
}
}
}
// Search for templates like {{References}}
String templates = getSpecificProperty(
"templates", true, true, false);
if (templates == null) {
templates = getSpecificProperty(
"references_templates", true, true, false);
}
List<String> referencesTemplates = null;
if (templates != null) {
referencesTemplates = WPCConfiguration.convertPropertyToStringList(templates);
}
if (referencesTemplates != null) {
List<PageElementTemplate> allTemplates = analysis.getTemplates();
int templateNum = allTemplates.size();
while (templateNum > 0) {
templateNum--;
PageElementTemplate template = allTemplates.get(templateNum);
for (String referencesTemplate : referencesTemplates) {
if (Page.areSameTitle(template.getTemplateName(), referencesTemplate)) {
if (template.getEndIndex() > lastRefTag.getCompleteEndIndex()) {
return false;
}
referencesFound = true;
}
}
}
}
if (!referencesFound) {
return false;
}
// Report error
if (errors == null) {
return true;
}
CheckErrorResult errorResult = createCheckErrorResult(
analysis,
lastRefTag.getCompleteBeginIndex(),
lastRefTag.getCompleteEndIndex(),
referencesFound ? ErrorLevel.WARNING : ErrorLevel.ERROR);
errors.add(errorResult);
return true;
}
/**
* Automatic fixing of all the errors in the page.
*
* @param analysis Page analysis.
* @return Page contents after fix.
*/
@Override
protected String internalAutomaticFix(PageAnalysis analysis) {
return fixUsingAutomaticReplacement(analysis);
}
/**
* @return Map of parameters (Name -> description).
* @see org.wikipediacleaner.api.check.algorithm.CheckErrorAlgorithmBase#getParameters()
*/
@Override
public Map<String, String> getParameters() {
Map<String, String> parameters = super.getParameters();
//parameters.put("references_templates", GT._("A list of templates resulting in the inclusion of {0}", "<references/>"));
parameters.put("templates", GT._("A list of templates resulting in the inclusion of {0}", "<references/>"));
return parameters;
}
}