org.reflections.util.FilterBuilder Maven / Gradle / Ivy
Show all versions of rapidpm-dynamic-cdi Show documentation
package org.reflections.util;
import com.google.common.base.Predicate;
import com.google.common.base.Joiner;
import com.google.common.collect.Lists;
import org.reflections.ReflectionsException;
import java.util.ArrayList;
import java.util.List;
import java.util.regex.Pattern;
/**
* Builds include/exclude filters for Reflections.
*
* For example:
*
* Predicate filter1 = FilterBuilder.parsePackages("-java, "-javax");
* Predicate filter2 = new FilterBuilder().include(".*").exclude("java.*");
*
*/
public class FilterBuilder implements Predicate {
private final List> chain;
public FilterBuilder() {chain = Lists.newArrayList();}
private FilterBuilder(final Iterable> filters) {chain = Lists.newArrayList(filters);}
/** include a regular expression */
public FilterBuilder include(final String regex) {return add(new Include(regex));}
/** exclude a regular expression*/
public FilterBuilder exclude(final String regex) {add(new Exclude(regex)); return this;}
/** add a Predicate to the chain of predicates*/
public FilterBuilder add(Predicate filter) {chain.add(filter); return this;}
/** include a package of a given class */
public FilterBuilder includePackage(final Class aClass) {return add(new Include(packageNameRegex(aClass)));}
/** exclude a package of a given class */
public FilterBuilder excludePackage(final Class aClass) {return add(new Exclude(packageNameRegex(aClass)));}
/** include packages of given prefixes */
public FilterBuilder includePackage(final String... prefixes) {
for (String prefix : prefixes) {
add(new Include(prefix(prefix)));
}
return this;
}
/** exclude a package of a given prefix */
public FilterBuilder excludePackage(final String prefix) {return add(new Exclude(prefix(prefix)));}
private static String packageNameRegex(Class aClass) {return prefix(aClass.getPackage().getName() + ".");}
public static String prefix(String qualifiedName) {return qualifiedName.replace(".","\\.") + ".*";}
@Override public String toString() {return Joiner.on(", ").join(chain);}
public boolean apply(String regex) {
boolean accept = chain == null || chain.isEmpty() || chain.get(0) instanceof Exclude;
if (chain != null) {
for (Predicate filter : chain) {
if (accept && filter instanceof Include) {continue;} //skip if this filter won't change
if (!accept && filter instanceof Exclude) {continue;}
accept = filter.apply(regex);
if (!accept && filter instanceof Exclude) {break;} //break on first exclusion
}
}
return accept;
}
public abstract static class Matcher implements Predicate {
final Pattern pattern;
public Matcher(final String regex) {pattern = Pattern.compile(regex);}
public abstract boolean apply(String regex);
@Override public String toString() {return pattern.pattern();}
}
public static class Include extends Matcher {
public Include(final String patternString) {super(patternString);}
@Override public boolean apply(final String regex) {return pattern.matcher(regex).matches();}
@Override public String toString() {return "+" + super.toString();}
}
public static class Exclude extends Matcher {
public Exclude(final String patternString) {super(patternString);}
@Override public boolean apply(final String regex) {return !pattern.matcher(regex).matches();}
@Override public String toString() {return "-" + super.toString();}
}
/**
* Parses a string representation of an include/exclude filter.
*
* The given includeExcludeString is a comma separated list of regexes,
* each starting with either + or - to indicate include/exclude.
*
* For example parsePackages("-java\\..*, -javax\\..*, -sun\\..*, -com\\.sun\\..*")
* or parse("+com\\.myn\\..*,-com\\.myn\\.excluded\\..*").
* Note that "-java\\..*" will block "java.foo" but not "javax.foo".
*
* See also the more useful {@link FilterBuilder#parsePackages(String)} method.
*/
public static FilterBuilder parse(String includeExcludeString) {
List> filters = new ArrayList>();
if (!Utils.isEmpty(includeExcludeString)) {
for (String string : includeExcludeString.split(",")) {
String trimmed = string.trim();
char prefix = trimmed.charAt(0);
String pattern = trimmed.substring(1);
Predicate filter;
switch (prefix) {
case '+':
filter = new Include(pattern);
break;
case '-':
filter = new Exclude(pattern);
break;
default:
throw new ReflectionsException("includeExclude should start with either + or -");
}
filters.add(filter);
}
return new FilterBuilder(filters);
} else {
return new FilterBuilder();
}
}
/**
* Parses a string representation of an include/exclude filter.
*
* The given includeExcludeString is a comma separated list of package name segments,
* each starting with either + or - to indicate include/exclude.
*
* For example parsePackages("-java, -javax, -sun, -com.sun") or parse("+com.myn,-com.myn.excluded").
* Note that "-java" will block "java.foo" but not "javax.foo".
*
* The input strings "-java" and "-java." are equivalent.
*/
public static FilterBuilder parsePackages(String includeExcludeString) {
List> filters = new ArrayList>();
if (!Utils.isEmpty(includeExcludeString)) {
for (String string : includeExcludeString.split(",")) {
String trimmed = string.trim();
char prefix = trimmed.charAt(0);
String pattern = trimmed.substring(1);
if (pattern.endsWith(".") == false) {
pattern += ".";
}
pattern = prefix(pattern);
Predicate filter;
switch (prefix) {
case '+':
filter = new Include(pattern);
break;
case '-':
filter = new Exclude(pattern);
break;
default:
throw new ReflectionsException("includeExclude should start with either + or -");
}
filters.add(filter);
}
return new FilterBuilder(filters);
} else {
return new FilterBuilder();
}
}
}