/*
* Copyright 2015 Lukas Krejci
*
* 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 org.revapi.basic;
import java.io.InputStreamReader;
import java.io.Reader;
import java.nio.charset.Charset;
import javax.annotation.Nonnull;
import javax.annotation.Nullable;
import org.revapi.Difference;
import org.revapi.Element;
import org.jboss.dmr.ModelNode;
/**
* A generic difference transform that can ignore differences based on the difference code ({@link
* org.revapi.Difference#code}) and on the old or new elements' full human representations
* ({@link org.revapi.Element#getFullHumanReadableString()}).
*
* <p>The transform is configured using properties in the general form of:
* <pre><code>
* {
* "revapi" : {
* "ignore" : [
* {
* "regex" : false,
* "code" : "PROBLEM_CODE",
* "old" : "FULL_REPRESENTATION_OF_THE_OLD_ELEMENT",
* "new" : "FULL_REPRESENTATION_OF_THE_NEW_ELEMENT",
* "justification": "blah"
* },
* ...
* ]
* }
* }
* </code></pre>
* The {@code code} is mandatory (obviously). The {@code old} and {@code new} properties are optional and the rule will
* match when all the specified properties of it match. If regex attribute is "true" (defaults to "false"), all the
* code, old and new are understood as regexes (java regexes, not javascript ones).
*
* @author Lukas Krejci
* @since 0.1
*/
public class IgnoreDifferenceTransform
extends AbstractDifferenceReferringTransform<IgnoreDifferenceTransform.IgnoreRecipe, Void> {
public static class IgnoreRecipe extends DifferenceMatchRecipe {
public IgnoreRecipe(ModelNode node) {
super(node, "justification");
}
@Override
public Difference transformMatching(Difference difference, Element oldElement,
Element newElement) {
//we ignore the matching elements, so null is the correct return value.
return null;
}
}
public IgnoreDifferenceTransform() {
super("revapi", "ignore");
}
@Nullable
@Override
public String[] getConfigurationRootPaths() {
return new String[]{"revapi.ignore"};
}
@Nullable
@Override
public Reader getJSONSchema(@Nonnull String configurationRootPath) {
if ("revapi.ignore".equals(configurationRootPath)) {
return new InputStreamReader(getClass().getResourceAsStream("/META-INF/ignore-schema.json"),
Charset.forName("UTF-8"));
} else {
return null;
}
}
@Nullable
@Override
protected Void initConfiguration() {
return null;
}
@Nonnull
@Override
protected IgnoreRecipe newRecipe(Void context, ModelNode config) {
return new IgnoreRecipe(config);
}
@Override
public void close() {
}
}