⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 genericpatterncache.java

📁 jakarta-oro-2.0.8 正则表达式 引擎 源代码
💻 JAVA
字号:
/* * $Id: GenericPatternCache.java,v 1.7 2003/11/07 20:16:24 dfs Exp $ * * ==================================================================== * The Apache Software License, Version 1.1 * * Copyright (c) 2000 The Apache Software Foundation.  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 acknowledgment: *       "This product includes software developed by the *        Apache Software Foundation (http://www.apache.org/)." *    Alternately, this acknowledgment may appear in the software itself, *    if and wherever such third-party acknowledgments normally appear. * * 4. The names "Apache" and "Apache Software Foundation", "Jakarta-Oro"  *    must not be used to endorse or promote products derived from this *    software without prior written permission. For written *    permission, please contact apache@apache.org. * * 5. Products derived from this software may not be called "Apache"  *    or "Jakarta-Oro", nor may "Apache" or "Jakarta-Oro" appear in their  *    name, without prior written permission of the Apache Software Foundation. * * 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 APACHE SOFTWARE FOUNDATION 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 on behalf of the Apache Software Foundation.  For more * information on the Apache Software Foundation, please see * <http://www.apache.org/>. */package org.apache.oro.text;import java.util.*;import org.apache.oro.text.regex.*;import org.apache.oro.util.*;/** * This is the base class for all cache implementations provided in the * org.apache.oro.text package. * Although 4 subclasses of GenericPatternCache are provided with this * package, users may not derive subclasses from this class. * Rather, users should create their own implmentations of the * {@link PatternCache} interface. * * @version @version@ * @since 1.0 * @see PatternCache * @see PatternCacheLRU * @see PatternCacheFIFO * @see PatternCacheFIFO2 * @see PatternCacheRandom */public abstract class GenericPatternCache implements PatternCache {  PatternCompiler _compiler;  Cache _cache;  /**   * The default capacity to be used by the GenericPatternCache subclasses   * provided with this package.  Its value is 20.   */  public static final int DEFAULT_CAPACITY = 20;  /**   * The primary constructor for GenericPatternCache.  It has default   * access so it will only be used within the package.  It initializes   * _cache and _compiler to the arguments provided.   * <p>   * @param cache The cache with which to store patterns.   * @param compiler The PatternCompiler that should be used to compile   *       patterns.   */  GenericPatternCache(Cache cache, PatternCompiler compiler) {    _cache    = cache;    _compiler = compiler;  }  /**   * Adds a pattern to the cache and returns the compiled pattern.  This   * method is in principle almost identical to   * {@link #getPattern getPattern()} except for the fact that   * it throws a MalformedPatternException if an expression cannot be   * compiled.   * <p>   * addPattern() is meant to be used when you expressly intend to add   * an expression to the cache and is useful for front-loading a cache   * with expressions before use.  If the expression added does not   * already exist in the cache, it is compiled, added to the cache,   * and returned.  If the compiled expression is already in the cache, it   * is simply returned.   * <p>   * The expected behavior of this method should be to start replacing   * patterns in the cache only after the cache has been filled to capacity.   * <p>   * @param expression  The regular expression to add to the cache.   * @param options The compilation options to use when compiling the   *        expression.   * @return The Pattern corresponding to the String representation of the   *         regular expression.   * @exception MalformedPatternException  If there is an error in compiling   *         the regular expression.   */  public final synchronized Pattern addPattern(String expression, int options)       throws MalformedPatternException  {    Object obj;    Pattern pattern;    obj = _cache.getElement(expression);    if(obj != null) {      pattern = (Pattern)obj;      if(pattern.getOptions() == options)	return pattern;    }    pattern = _compiler.compile(expression, options);    _cache.addElement(expression, pattern);    return pattern;  }  /**   * Same as calling   * <blockquote><pre>   * addPattern(expression, 0);   * </pre></blockquote>   * @exception MalformedPatternException  If there is an error in compiling   *         the regular expression.   */  public final synchronized Pattern addPattern(String expression)       throws MalformedPatternException  {    return addPattern(expression, 0);  }  /**   * This method fetches a pattern from the cache.  It is nearly identical   * to {@link #addPattern addPattern()} except that it doesn't   * throw a MalformedPatternException.  If the pattern is not in the   * cache, it is compiled, placed in the cache, and returned.  If   * the pattern cannot be compiled successfully, it   * throws a MalformedCachePatternException.   * Note that this exception is derived from RuntimeException, which means   * you are NOT forced to catch it by the compiler.  Please refer to   * {@link MalformedCachePatternException} for a discussion of   * when you should and shouldn't catch this exception.   * <p>   * @param expression  The regular expression to fetch from the cache in   *        compiled form.   * @param options The compilation options to use when compiling the   *        expression.   * @return The Pattern corresponding to the String representation of the   *         regular expression.   * @exception MalformedCachePatternException  If there is an error in   *     compiling the regular expression.   */  public final synchronized Pattern getPattern(String expression, int options)       throws MalformedCachePatternException   {    Pattern result = null;    try {      result = addPattern(expression, options);    } catch(MalformedPatternException e) {      throw new MalformedCachePatternException("Invalid expression: " +					       expression + "\n" + 					       e.getMessage());    }    return result;  }  /**   * Same as calling   * <blockquote><pre>   * getPattern(expression, 0)   * </pre></blockquote>   */  public final synchronized Pattern getPattern(String expression)        throws MalformedCachePatternException   {    return getPattern(expression, 0);  }  /**   * Returns the number of elements in the cache, not to be confused with   * the {@link #capacity()} which returns the number   * of elements that can be held in the cache at one time.   * <p>   * @return  The current size of the cache (i.e., the number of elements   *          currently cached).   */  public final int size()     { return _cache.size(); }  /**   * Returns the maximum number of patterns that can be cached at one time.   * <p>   * @return The maximum number of patterns that can be cached at one time.   */  public final int capacity() { return _cache.capacity(); }}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -