forked from phoedos/pmd
Update some usages early
This commit is contained in:
@ -305,7 +305,7 @@ public class RuleSetFactory {
|
|||||||
public RuleSet createSingleRuleRuleSet(final Rule rule) { // TODO make static?
|
public RuleSet createSingleRuleRuleSet(final Rule rule) { // TODO make static?
|
||||||
final long checksum;
|
final long checksum;
|
||||||
if (rule instanceof XPathRule) {
|
if (rule instanceof XPathRule) {
|
||||||
checksum = rule.getProperty(XPathRule.XPATH_DESCRIPTOR).hashCode();
|
checksum = ((XPathRule) rule).getXPathExpression().hashCode();
|
||||||
} else {
|
} else {
|
||||||
// TODO : Is this good enough? all properties' values + rule name
|
// TODO : Is this good enough? all properties' values + rule name
|
||||||
checksum = rule.getPropertiesByPropertyDescriptor().values().hashCode() * 31 + rule.getName().hashCode();
|
checksum = rule.getPropertiesByPropertyDescriptor().values().hashCode() * 31 + rule.getName().hashCode();
|
||||||
|
@ -106,6 +106,21 @@ public class XPathRule extends AbstractRule {
|
|||||||
setVersion(version.getXmlName());
|
setVersion(version.getXmlName());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns the version for this rule. Returns null if this is not
|
||||||
|
* set or invalid.
|
||||||
|
*/
|
||||||
|
public XPathVersion getVersion() {
|
||||||
|
return XPathVersion.ofId(getProperty(VERSION_DESCRIPTOR));
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns the XPath expression that implements this rule.
|
||||||
|
*/
|
||||||
|
public String getXPathExpression() {
|
||||||
|
return getProperty(XPATH_DESCRIPTOR);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @deprecated Use the constructor {@link #XPathRule(XPathVersion, String)},
|
* @deprecated Use the constructor {@link #XPathRule(XPathVersion, String)},
|
||||||
* don't set the expression after the fact.
|
* don't set the expression after the fact.
|
||||||
@ -156,13 +171,21 @@ public class XPathRule extends AbstractRule {
|
|||||||
* engine in which the query will be run it looks at the XPath version.
|
* engine in which the query will be run it looks at the XPath version.
|
||||||
*/
|
*/
|
||||||
private void initXPathRuleQuery() {
|
private void initXPathRuleQuery() {
|
||||||
String xpath = getProperty(XPATH_DESCRIPTOR);
|
String xpath = getXPathExpression();
|
||||||
String version = getProperty(VERSION_DESCRIPTOR);
|
XPathVersion version = getVersion();
|
||||||
|
|
||||||
initRuleQueryBasedOnVersion(version);
|
if (version == null) {
|
||||||
|
throw new IllegalStateException("Invalid XPath version, should have been caught by Rule::dysfunctionReason");
|
||||||
|
}
|
||||||
|
|
||||||
|
if (version.equals(XPathVersion.XPATH_1_0)) {
|
||||||
|
xpathRuleQuery = new JaxenXPathRuleQuery();
|
||||||
|
} else {
|
||||||
|
xpathRuleQuery = new SaxonXPathRuleQuery();
|
||||||
|
}
|
||||||
|
|
||||||
xpathRuleQuery.setXPath(xpath);
|
xpathRuleQuery.setXPath(xpath);
|
||||||
xpathRuleQuery.setVersion(version);
|
xpathRuleQuery.setVersion(version.getXmlName());
|
||||||
xpathRuleQuery.setProperties(getPropertiesByPropertyDescriptor());
|
xpathRuleQuery.setProperties(getPropertiesByPropertyDescriptor());
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -175,10 +198,6 @@ public class XPathRule extends AbstractRule {
|
|||||||
return xpathRuleQuery == null;
|
return xpathRuleQuery == null;
|
||||||
}
|
}
|
||||||
|
|
||||||
private void initRuleQueryBasedOnVersion(final String version) {
|
|
||||||
xpathRuleQuery = XPATH_1_0.equals(version) ? new JaxenXPathRuleQuery() : new SaxonXPathRuleQuery();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public List<String> getRuleChainVisits() {
|
public List<String> getRuleChainVisits() {
|
||||||
if (xPathRuleQueryNeedsInitialization()) {
|
if (xPathRuleQueryNeedsInitialization()) {
|
||||||
@ -193,10 +212,11 @@ public class XPathRule extends AbstractRule {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public String dysfunctionReason() {
|
public String dysfunctionReason() {
|
||||||
return hasXPathExpression() ? null : "Missing xPath expression";
|
if (getVersion() == null) {
|
||||||
}
|
return "Invalid XPath version '" + getProperty(VERSION_DESCRIPTOR) + "'";
|
||||||
|
} else if (StringUtils.isBlank(getXPathExpression())) {
|
||||||
private boolean hasXPathExpression() {
|
return "Missing XPath expression";
|
||||||
return StringUtils.isNotBlank(getProperty(XPATH_DESCRIPTOR));
|
}
|
||||||
|
return null;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -14,14 +14,15 @@ public enum XPathVersion {
|
|||||||
/**
|
/**
|
||||||
* XPath 1.0.
|
* XPath 1.0.
|
||||||
*
|
*
|
||||||
* @deprecated not supported anymore
|
* @deprecated Will become unsupported in 7.0.0
|
||||||
*/
|
*/
|
||||||
@Deprecated
|
@Deprecated
|
||||||
XPATH_1_0(XPathRuleQuery.XPATH_1_0),
|
XPATH_1_0(XPathRuleQuery.XPATH_1_0),
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* XPath 1.0 compatibility mode.
|
* XPath 1.0 compatibility mode.
|
||||||
*
|
*
|
||||||
* @deprecated Not supported any more.
|
* @deprecated Will become unsupported in 7.0.0
|
||||||
*/
|
*/
|
||||||
@Deprecated
|
@Deprecated
|
||||||
XPATH_1_0_COMPATIBILITY(XPathRuleQuery.XPATH_1_0_COMPATIBILITY),
|
XPATH_1_0_COMPATIBILITY(XPathRuleQuery.XPATH_1_0_COMPATIBILITY),
|
||||||
@ -61,9 +62,7 @@ public enum XPathVersion {
|
|||||||
*
|
*
|
||||||
* @param version A version string
|
* @param version A version string
|
||||||
*
|
*
|
||||||
* @return An XPath version
|
* @return An XPath version, or null if the argument is not a valid version
|
||||||
*
|
|
||||||
* @return Null if the argument is not a valid version
|
|
||||||
*/
|
*/
|
||||||
public static XPathVersion ofId(String version) {
|
public static XPathVersion ofId(String version) {
|
||||||
return BY_NAME.get(version);
|
return BY_NAME.get(version);
|
||||||
|
@ -405,10 +405,11 @@ public class RuleDocGenerator {
|
|||||||
lines.addAll(EscapeUtils.escapeLines(toLines(stripIndentation(rule.getDescription()))));
|
lines.addAll(EscapeUtils.escapeLines(toLines(stripIndentation(rule.getDescription()))));
|
||||||
lines.add("");
|
lines.add("");
|
||||||
|
|
||||||
if (rule instanceof XPathRule || rule instanceof RuleReference && ((RuleReference) rule).getRule() instanceof XPathRule) {
|
XPathRule xpathRule = asXPathRule(rule);
|
||||||
|
if (xpathRule != null) {
|
||||||
lines.add("**This rule is defined by the following XPath expression:**");
|
lines.add("**This rule is defined by the following XPath expression:**");
|
||||||
lines.add("``` xpath");
|
lines.add("``` xpath");
|
||||||
lines.addAll(toLines(StringUtils.stripToEmpty(rule.getProperty(XPathRule.XPATH_DESCRIPTOR))));
|
lines.addAll(toLines(StringUtils.stripToEmpty(xpathRule.getXPathExpression())));
|
||||||
lines.add("```");
|
lines.add("```");
|
||||||
} else {
|
} else {
|
||||||
lines.add("**This rule is defined by the following Java class:** "
|
lines.add("**This rule is defined by the following Java class:** "
|
||||||
@ -502,6 +503,15 @@ public class RuleDocGenerator {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private XPathRule asXPathRule(Rule rule) {
|
||||||
|
if (rule instanceof XPathRule) {
|
||||||
|
return (XPathRule) rule;
|
||||||
|
} else if (rule instanceof RuleReference && ((RuleReference) rule).getRule() instanceof XPathRule) {
|
||||||
|
return (XPathRule) ((RuleReference) rule).getRule();
|
||||||
|
}
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
private static boolean isDeprecated(PropertyDescriptor<?> propertyDescriptor) {
|
private static boolean isDeprecated(PropertyDescriptor<?> propertyDescriptor) {
|
||||||
return propertyDescriptor.description() != null
|
return propertyDescriptor.description() != null
|
||||||
&& propertyDescriptor.description().toLowerCase(Locale.ROOT).startsWith(DEPRECATED_RULE_PROPERTY_MARKER);
|
&& propertyDescriptor.description().toLowerCase(Locale.ROOT).startsWith(DEPRECATED_RULE_PROPERTY_MARKER);
|
||||||
|
Reference in New Issue
Block a user