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

org.eclipse.jetty.util.IncludeExclude Maven / Gradle / Ivy

There is a newer version: 9.4.9.v20180320
Show newest version
//
//  ========================================================================
//  Copyright (c) 1995-2016 Mort Bay Consulting Pty. Ltd.
//  ------------------------------------------------------------------------
//  All rights reserved. This program and the accompanying materials
//  are made available under the terms of the Eclipse Public License v1.0
//  and Apache License v2.0 which accompanies this distribution.
//
//      The Eclipse Public License is available at
//      http://www.eclipse.org/legal/epl-v10.html
//
//      The Apache License v2.0 is available at
//      http://www.opensource.org/licenses/apache2.0.php
//
//  You may elect to redistribute this code under either of these licenses.
//  ========================================================================
//

package org.eclipse.jetty.util;

import java.util.HashSet;
import java.util.Objects;
import java.util.Set;
import java.util.function.Predicate;


/** Utility class to maintain a set of inclusions and exclusions.
 * 

Maintains a set of included and excluded elements. The method {@link #matches(Object)} * will return true IFF the passed object is not in the excluded set AND ( either the * included set is empty OR the object is in the included set) *

The type of the underlying {@link Set} used may be passed into the * constructor, so special sets like Servlet PathMap may be used. *

* @param The type of element */ public class IncludeExclude { private final Set _includes; private final Predicate _includePredicate; private final Set _excludes; private final Predicate _excludePredicate; private static class SetContainsPredicate implements Predicate { private final Set set; public SetContainsPredicate(Set set) { this.set = set; } @Override public boolean test(ITEM item) { return set.contains(item); } } /** * Default constructor over {@link HashSet} */ public IncludeExclude() { this(HashSet.class); } /** * Construct an IncludeExclude. *

* If the {@link Set} class also implements {@link Predicate}, then that Predicate is * used to match against the set, otherwise a simple {@link Set#contains(Object)} test is used. * @param setClass The type of {@link Set} to using internally * @param the {@link Set} type */ public > IncludeExclude(Class setClass) { try { _includes = setClass.newInstance(); _excludes = setClass.newInstance(); if(_includes instanceof Predicate) { _includePredicate = (Predicate)_includes; } else { _includePredicate = new SetContainsPredicate<>(_includes); } if(_excludes instanceof Predicate) { _excludePredicate = (Predicate)_excludes; } else { _excludePredicate = new SetContainsPredicate<>(_excludes); } } catch (InstantiationException | IllegalAccessException e) { throw new RuntimeException(e); } } /** * Construct an IncludeExclude * * @param includeSet the Set of items that represent the included space * @param includePredicate the Predicate for included item testing * @param excludeSet the Set of items that represent the excluded space * @param excludePredicate the Predicate for excluded item testing * @param the {@link Set} type */ public > IncludeExclude(Set includeSet, Predicate includePredicate, Set excludeSet, Predicate excludePredicate) { Objects.requireNonNull(includeSet,"Include Set"); Objects.requireNonNull(includePredicate,"Include Predicate"); Objects.requireNonNull(excludeSet,"Exclude Set"); Objects.requireNonNull(excludePredicate,"Exclude Predicate"); _includes = includeSet; _includePredicate = includePredicate; _excludes = excludeSet; _excludePredicate = excludePredicate; } public void include(ITEM element) { _includes.add(element); } public void include(ITEM... element) { for (ITEM e: element) _includes.add(e); } public void exclude(ITEM element) { _excludes.add(element); } public void exclude(ITEM... element) { for (ITEM e: element) _excludes.add(e); } public boolean matches(ITEM e) { if (!_includes.isEmpty() && !_includePredicate.test(e)) return false; return !_excludePredicate.test(e); } public int size() { return _includes.size()+_excludes.size(); } public Set getIncluded() { return _includes; } public Set getExcluded() { return _excludes; } public void clear() { _includes.clear(); _excludes.clear(); } @Override public String toString() { return String.format("%s@%x{i=%s,ip=%s,e=%s,ep=%s}",this.getClass().getSimpleName(),hashCode(),_includes,_includePredicate,_excludes,_excludePredicate); } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy