All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.reflections.util.FilterBuilder Maven / Gradle / Ivy

There is a newer version: 1.1.1
Show newest version
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(); } } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy