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

ch.qos.logback.core.util.StringCollectionUtil Maven / Gradle / Ivy

/**
 * Logback: the reliable, generic, fast and flexible logging framework.
 * Copyright (C) 1999-2015, QOS.ch. All rights reserved.
 *
 * This program and the accompanying materials are dual-licensed under
 * either the terms of the Eclipse Public License v1.0 as published by
 * the Eclipse Foundation
 *
 *   or (per the licensee's choosing)
 *
 * under the terms of the GNU Lesser General Public License version 2.1
 * as published by the Free Software Foundation.
 */
package ch.qos.logback.core.util;

import java.util.Arrays;
import java.util.ArrayList;
import java.util.Collection;
import java.util.List;
import java.util.regex.Pattern;

/**
 * Static utility methods for working with collections of strings.
 *
 * @author Carl Harris
 */
public class StringCollectionUtil {

    /**
     * Retains all values in the subject collection that are matched by
     * at least one of a collection of regular expressions.
     * 

* This method is a convenience overload for * {@link #retainMatching(Collection, Collection)}. * * @param values subject value collection * @param patterns patterns to match */ @SuppressWarnings("unchecked") public static void retainMatching(Collection values, String... patterns) { retainMatching(values, Arrays.asList(patterns)); } /** * Retains all values in the subject collection that are matched by * at least one of a collection of regular expressions. *

* The semantics of this method are conceptually similar to * {@link Collection#retainAll(Collection)}, but uses pattern matching * instead of exact matching. * * @param values subject value collection * @param patterns patterns to match */ public static void retainMatching(Collection values, Collection patterns) { if (patterns.isEmpty()) return; List matches = new ArrayList(values.size()); for (String p : patterns) { Pattern pattern = Pattern.compile(p); for (String value : values) { if (pattern.matcher(value).matches()) { matches.add(value); } } } values.retainAll(matches); } /** * Removes all values in the subject collection that are matched by * at least one of a collection of regular expressions. *

* This method is a convenience overload for * {@link #removeMatching(Collection, Collection)}. * * @param values subject value collection * @param patterns patterns to match */ @SuppressWarnings("unchecked") public static void removeMatching(Collection values, String... patterns) { removeMatching(values, Arrays.asList(patterns)); } /** * Removes all values in the subject collection that are matched by * at least one of a collection of regular expressions. *

* The semantics of this method are conceptually similar to * {@link Collection#removeAll(Collection)}, but uses pattern matching * instead of exact matching. * * @param values subject value collection * @param patterns patterns to match */ public static void removeMatching(Collection values, Collection patterns) { List matches = new ArrayList(values.size()); for (String p : patterns) { Pattern pattern = Pattern.compile(p); for (String value : values) { if (pattern.matcher(value).matches()) { matches.add(value); } } } values.removeAll(matches); } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy