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

org.objectstyle.cayenne.tools.NamePatternMatcher Maven / Gradle / Ivy

There is a newer version: 1.2.4
Show newest version
/* ====================================================================
 * 
 * The ObjectStyle Group Software License, version 1.1
 * ObjectStyle Group - http://objectstyle.org/
 * 
 * Copyright (c) 2002-2005, Andrei (Andrus) Adamchik and individual authors
 * of the software. All rights reserved.
 * 
 * Redistribution and use in source and binary forms, with or without
 * modification, are permitted provided that the following conditions
 * are met:
 * 
 * 1. Redistributions of source code must retain the above copyright
 *    notice, this list of conditions and the following disclaimer.
 * 
 * 2. Redistributions in binary form must reproduce the above copyright
 *    notice, this list of conditions and the following disclaimer in
 *    the documentation and/or other materials provided with the
 *    distribution.
 * 
 * 3. The end-user documentation included with the redistribution, if any,
 *    must include the following acknowlegement:
 *    "This product includes software developed by independent contributors
 *    and hosted on ObjectStyle Group web site (http://objectstyle.org/)."
 *    Alternately, this acknowlegement may appear in the software itself,
 *    if and wherever such third-party acknowlegements normally appear.
 * 
 * 4. The names "ObjectStyle Group" and "Cayenne" must not be used to endorse
 *    or promote products derived from this software without prior written
 *    permission. For written permission, email
 *    "andrus at objectstyle dot org".
 * 
 * 5. Products derived from this software may not be called "ObjectStyle"
 *    or "Cayenne", nor may "ObjectStyle" or "Cayenne" appear in their
 *    names without prior written permission.
 * 
 * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED
 * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
 * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
 * DISCLAIMED.  IN NO EVENT SHALL THE OBJECTSTYLE GROUP OR
 * ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF
 * USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
 * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
 * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
 * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
 * SUCH DAMAGE.
 * ====================================================================
 * 
 * This software consists of voluntary contributions made by many
 * individuals and hosted on ObjectStyle Group web site.  For more
 * information on the ObjectStyle Group, please see
 * .
 */
package org.objectstyle.cayenne.tools;

import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;
import java.util.StringTokenizer;
import java.util.regex.Pattern;
import java.util.regex.PatternSyntaxException;

import org.apache.tools.ant.Project;
import org.apache.tools.ant.Task;
import org.objectstyle.cayenne.util.CayenneMapEntry;

/**
 * Provides name pattern matching functionality.
 * 
 * @author Andrei Adamchik, Mike Kienenberger
 * @since 1.2
 */
public class NamePatternMatcher {

    protected Task parentTask;

    protected Pattern[] itemIncludeFilters;
    protected Pattern[] itemExcludeFilters;

    public NamePatternMatcher(Task parentTask, String includePattern,
            String excludePattern) {
        this.parentTask = parentTask;
        this.itemIncludeFilters = createPatterns(includePattern);
        this.itemExcludeFilters = createPatterns(excludePattern);
    }

    /**
     * Returns an array of Patterns. Takes a comma-separated list of patterns, attempting
     * to convert them to the java.util.regex.Pattern syntax. E.g.
     * 

* "billing_*,user?" will become an array of two expressions: *

* ^billing_.*$
* ^user.?$
*/ public Pattern[] createPatterns(String patternString) { String[] patternStrings = tokenizePattern(patternString); List patterns = new ArrayList(patternStrings.length); for (int i = 0; i < patternStrings.length; i++) { // test the pattern try { patterns.add(Pattern.compile(patternStrings[i])); } catch (PatternSyntaxException e) { if (parentTask != null) { parentTask.log("Ignoring invalid pattern [" + patternStrings[i] + "], reason: " + e.getMessage(), Project.MSG_WARN); } continue; } } return (Pattern[]) patterns.toArray(new Pattern[patterns.size()]); } /** * Returns an array of valid regular expressions. Takes a comma-separated list of * patterns, attempting to convert them to the java.util.regex.Pattern syntax. E.g. *

* "billing_*,user?" will become an array of two expressions: *

* ^billing_.*$
* ^user.?$
*/ public String[] tokenizePattern(String pattern) { if (pattern != null && pattern.length() > 0) { StringTokenizer toks = new StringTokenizer(pattern, ","); int len = toks.countTokens(); if (len == 0) { return new String[0]; } List patterns = new ArrayList(len); for (int i = 0; i < len; i++) { String nextPattern = toks.nextToken(); StringBuffer buffer = new StringBuffer(); // convert * into regex syntax // e.g. abc*x becomes ^abc.*x$ // or abc?x becomes ^abc.?x$ buffer.append("^"); for (int j = 0; j < nextPattern.length(); j++) { char nextChar = nextPattern.charAt(j); if (nextChar == '*' || nextChar == '?') { buffer.append('.'); } buffer.append(nextChar); } buffer.append("$"); patterns.add(buffer.toString()); } return (String[]) patterns.toArray(new String[patterns.size()]); } else { return new String[0]; } } /** * Applies preconfigured list of filters to the list, removing entities that do not * pass the filter. */ protected List filter(List items) { if (items == null || items.isEmpty()) { return items; } if ((itemIncludeFilters.length == 0) && (itemExcludeFilters.length == 0)) { return items; } Iterator it = items.iterator(); while (it.hasNext()) { CayenneMapEntry entity = (CayenneMapEntry) it.next(); if (!passedIncludeFilter(entity)) { it.remove(); continue; } if (!passedExcludeFilter(entity)) { it.remove(); continue; } } return items; } /** * Returns true if the entity matches any one of the "include" patterns, or if there * is no "include" patterns defined. */ protected boolean passedIncludeFilter(CayenneMapEntry item) { if (itemIncludeFilters.length == 0) { return true; } String itemName = item.getName(); for (int i = 0; i < itemIncludeFilters.length; i++) { if (itemIncludeFilters[i].matcher(itemName).find()) { return true; } } return false; } /** * Returns true if the entity does not match any one of the "exclude" patterns, or if * there is no "exclude" patterns defined. */ protected boolean passedExcludeFilter(CayenneMapEntry item) { if (itemExcludeFilters.length == 0) { return true; } String itemName = item.getName(); for (int i = 0; i < itemExcludeFilters.length; i++) { if (itemExcludeFilters[i].matcher(itemName).find()) { return false; } } return true; } public static String replaceWildcardInStringWithString( String wildcard, String pattern, String replacement) { if (null == pattern || null == wildcard) return pattern; StringBuffer buffer = new StringBuffer(); int lastPos = 0; int wildCardPos = pattern.indexOf(wildcard); while (-1 != wildCardPos) { if (lastPos != wildCardPos) { buffer.append(pattern.substring(lastPos, wildCardPos)); } buffer.append(replacement); lastPos += wildCardPos + wildcard.length(); wildCardPos = pattern.indexOf(wildcard, lastPos); } if (lastPos < pattern.length()) { buffer.append(pattern.substring(lastPos)); } return buffer.toString(); } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy