// BlogBridge -- RSS feed reader, manager, and web based service // Copyright (C) 2002-2006 by R. Pito Salas // // This program is free software; you can redistribute it and/or modify it under // the terms of the GNU General Public License as published by the Free Software Foundation; // either version 2 of the License, or (at your option) any later version. // // This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; // without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. // See the GNU General Public License for more details. // // You should have received a copy of the GNU General Public License along with this program; // if not, write to the Free Software Foundation, Inc., 59 Temple Place, // Suite 330, Boston, MA 02111-1307 USA // // Contact: R. Pito Salas // mailto:pitosalas@users.sourceforge.net // More information: about BlogBridge // http://www.blogbridge.com // http://sourceforge.net/projects/blogbridge // // $Id: StringContainsCO.java,v 1.8 2007/03/29 15:14:54 spyromus Exp $ // package com.salas.bb.domain.query.general; import com.salas.bb.domain.query.AbstractComparisonOperation; import com.salas.bb.utils.StringUtils; import com.salas.bb.utils.i18n.Strings; import java.util.Map; import java.util.WeakHashMap; import java.util.regex.Pattern; /** * Checks if the target value contains one of the space-delimitered words or multi-words * enclosed in quotes. */ public class StringContainsCO extends AbstractComparisonOperation { /** Instance of this comparison operation. */ public static final StringContainsCO INSTANCE = new StringContainsCO(); /** * Creates operation. */ public StringContainsCO() { this(Strings.message("query.operation.contains"), "contains"); } /** * Constructor for extensions. * * @param aName name. * @param aDescriptor descriptor. */ protected StringContainsCO(String aName, String aDescriptor) { super(aName, aDescriptor); } /** * Compares some target value against value for comparison. * * @param targetValue target value. * @param comparisonValue comparison value. * * @return TRUE if the target value matches the condition presented by this comparison operation * in conjunction with comparison value. */ public boolean match(String targetValue, String comparisonValue) { Pattern pattern = preparePattern(comparisonValue); return pattern != null && targetValue != null && pattern.matcher(targetValue).find(); } private static final Map<String, Pattern> patterns = new WeakHashMap<String, Pattern>(); /** * Prepares new pattern for matching or takes an old one from the cache. * * @param comparisonValue comparison value. * * @return value. */ private static synchronized Pattern preparePattern(String comparisonValue) { if (comparisonValue == null) return null; Pattern pattern = patterns.get(comparisonValue); if (pattern == null) { String[] keys = StringUtils.keywordsToArray(comparisonValue); String regex = StringUtils.keywordsToPattern(keys); pattern = regex == null ? null : Pattern.compile(regex, Pattern.CASE_INSENSITIVE); patterns.put(comparisonValue, pattern); } return pattern; } }