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

📄 orfilterwrapper.java

📁 HTMLParser开源代码附解析程序。
💻 JAVA
字号:
// HTMLParser Library $Name: v1_6 $ - A java-based parser for HTML// http://sourceforge.org/projects/htmlparser// Copyright (C) 2005 Derrick Oswald//// Revision Control Information//// $Source: /cvsroot/htmlparser/htmlparser/src/org/htmlparser/parserapplications/filterbuilder/wrappers/OrFilterWrapper.java,v $// $Author: derrickoswald $// $Date: 2005/04/12 11:27:42 $// $Revision: 1.2 $//// This library is free software; you can redistribute it and/or// modify it under the terms of the GNU Lesser General Public// License as published by the Free Software Foundation; either// version 2.1 of the License, or (at your option) any later version.//// This library 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// Lesser General Public License for more details.//// You should have received a copy of the GNU Lesser General Public// License along with this library; if not, write to the Free Software// Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA//package org.htmlparser.parserapplications.filterbuilder.wrappers;import org.htmlparser.Node;import org.htmlparser.NodeFilter;import org.htmlparser.Parser;import org.htmlparser.filters.OrFilter;import org.htmlparser.parserapplications.filterbuilder.Filter;import org.htmlparser.parserapplications.filterbuilder.SubFilterList;/** * Wrapper for OrFilters. */public class OrFilterWrapper    extends        Filter{    /**     * The drop target container.     */    protected SubFilterList mContainer;        /**     * The underlying filter.     */    protected OrFilter mFilter;    /**     * Create a wrapper over a new OrFilter.     */     public OrFilterWrapper ()    {        mFilter = new OrFilter ();        // add the subfilter container        mContainer = new SubFilterList (this, "Predicates", 0);        add (mContainer);    }    //    // Filter overrides and concrete implementations    //    /**     * Get the name of the filter.     * @return A descriptive name for the filter.     */    public String getDescription ()    {        return ("Or");    }    /**     * Get the resource name for the icon.     * @return The icon resource specification.     */    public String getIconSpec ()    {        return ("images/OrFilter.gif");    }    /**     * Get the underlying node filter object.     * @return The node filter object suitable for serialization.     */    public NodeFilter getNodeFilter ()    {        NodeFilter[] predicates;        NodeFilter[] temp;        OrFilter ret;                ret = new OrFilter ();        predicates = mFilter.getPredicates ();        temp = new NodeFilter[predicates.length];        for (int i = 0; i < predicates.length; i++)            temp[i] = ((Filter)predicates[i]).getNodeFilter ();        ret.setPredicates (temp);                    return (ret);    }    /**     * Assign the underlying node filter for this wrapper.     * @param filter The filter to wrap.     * @param context The parser to use for conditioning this filter.     * Some filters need contextual information to provide to the user,     * i.e. for tag names or attribute names or values,     * so the Parser context is provided.      */    public void setNodeFilter (NodeFilter filter, Parser context)    {        mFilter = (OrFilter)filter;    }    /**     * Get the underlying node filter's subordinate filters.     * @return The node filter object's contained filters.     */    public NodeFilter[] getSubNodeFilters ()    {        return (mFilter.getPredicates ());    }    /**     * Assign the underlying node filter's subordinate filters.     * @param filters The filters to insert into the underlying node filter.     */    public void setSubNodeFilters (NodeFilter[] filters)    {        mFilter.setPredicates (filters);    }    /**     * Convert this filter into Java code.     * Output whatever text necessary and return the variable name.     * @param out The output buffer.     * @param context Three integers as follows:     * <li>indent level - the number of spaces to insert at the beginning of each line</li>     * <li>filter number - the next available filter number</li>     * <li>filter array number - the next available array of filters number</li>     * @return The variable name to use when referencing this filter (usually "filter" + context[1]++)      */    public String toJavaCode (StringBuffer out, int[] context)    {        String array;        NodeFilter[] predicates;        String[] names;        String ret;                predicates = mFilter.getPredicates ();        array = null; // stoopid Java compiler        if (0 != predicates.length)        {            names = new String[predicates.length];            for (int i = 0; i < predicates.length; i++)            {                names[i] = ((Filter)predicates[i]).toJavaCode (out, context);            }            array = "array" + context[2]++;            spaces (out, context[0]);            out.append ("NodeFilter[] ");            out.append (array);            out.append (" = new NodeFilter[");            out.append (predicates.length);            out.append ("];");            newline (out);            for (int i = 0; i < predicates.length; i++)            {                spaces (out, context[0]);                out.append (array);                out.append ("[");                out.append (i);                out.append ("] = ");                out.append (names[i]);                out.append (";");                newline (out);            }        }        ret = "filter" + context[1]++;        spaces (out, context[0]);        out.append ("OrFilter ");        out.append (ret);        out.append (" = new OrFilter ();");        newline (out);        if (0 != predicates.length)        {            spaces (out, context[0]);            out.append (ret);            out.append (".setPredicates (");            out.append (array);            out.append (");");            newline (out);        }                return (ret);    }    //    // NodeFilter interface    //    /**     * Predicate to determine whether or not to keep the given node.     * The behaviour based on this outcome is determined by the context     * in which it is called. It may lead to the node being added to a list     * or printed out. See the calling routine for details.     * @return <code>true</code> if the node is to be kept, <code>false</code>     * if it is to be discarded.     * @param node The node to test.     */    public boolean accept (Node node)    {        return (mFilter.accept (node));    }}

⌨️ 快捷键说明

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