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

📄 dombuilderimpl.hpp

📁 基于属性证书的访问控制源代码,由c++编写,包括openssl,xercesc等
💻 HPP
📖 第 1 页 / 共 3 页
字号:
/* * The Apache Software License, Version 1.1 * * Copyright (c) 2002 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 "Xerces" and "Apache Software Foundation" 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", *    nor may "Apache" 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, and was * originally based on software copyright (c) 2001, International * Business Machines, Inc., http://www.ibm.com .  For more information * on the Apache Software Foundation, please see * <http://www.apache.org/>. *//* * $Id: DOMBuilderImpl.hpp,v 1.16 2004/01/29 11:46:32 cargilld Exp $ * */#if !defined(DOMBUILDERIMPL_HPP)#define DOMBUILDERIMPL_HPP#include <xercesc/parsers/AbstractDOMParser.hpp>#include <xercesc/dom/DOMBuilder.hpp>#include <xercesc/util/XercesDefs.hpp>XERCES_CPP_NAMESPACE_BEGINclass XMLEntityResolver;class XMLResourceIdentifier; /**  * Introduced in DOM Level 3  *  * DOMBuilderImpl provides an implementation of a DOMBuilder interface.  * A DOMBuilder instance is obtained from the DOMImplementationLS interface  * by invoking its createDOMBuilder method.  */class PARSERS_EXPORT DOMBuilderImpl : public AbstractDOMParser,                                      public DOMBuilder{public :    // -----------------------------------------------------------------------    //  Constructors and Detructor    // -----------------------------------------------------------------------    /** @name Constructors and Destructor */    //@{    /** Construct a DOMBuilderImpl, with an optional validator      *      * Constructor with an instance of validator class to use for      * validation. If you don't provide a validator, a default one will      * be created for you in the scanner.      *      * @param gramPool   Pointer to the grammar pool instance from       *                   external application.      *                   The parser does NOT own it.      *      * @param valToAdopt Pointer to the validator instance to use. The      *                   parser is responsible for freeing the memory.      */    DOMBuilderImpl    (          XMLValidator* const   valToAdopt = 0        , MemoryManager* const  manager = XMLPlatformUtils::fgMemoryManager        , XMLGrammarPool* const gramPool = 0            );    /**      * Destructor      */    virtual ~DOMBuilderImpl();    //@}    // -----------------------------------------------------------------------    //  Implementation of DOMBuilder interface    // -----------------------------------------------------------------------    // -----------------------------------------------------------------------    //  Getter methods    // -----------------------------------------------------------------------    /** @name Getter methods */    //@{    /**      * <p><b>"Experimental - subject to change"</b></p>      *      * Get a pointer to the error handler      *      * This method returns the installed error handler. If no handler      * has been installed, then it will be a zero pointer.      *      * @return The pointer to the installed error handler object.      */    DOMErrorHandler* getErrorHandler();    /**      * <p><b>"Experimental - subject to change"</b></p>      *      * Get a const pointer to the error handler      *      * This method returns the installed error handler.  If no handler      * has been installed, then it will be a zero pointer.      *      * @return A const pointer to the installed error handler object.      */    const DOMErrorHandler* getErrorHandler() const;    /**      * <p><b>"Experimental - subject to change"</b></p>      *      * Get a pointer to the entity resolver      *      * This method returns the installed entity resolver.  If no resolver      * has been installed, then it will be a zero pointer.      *      * @return The pointer to the installed entity resolver object.      */    DOMEntityResolver* getEntityResolver();    /**      * Get a pointer to the entity resolver      *      * This method returns the installed entity resolver.  If no resolver      * has been installed, then it will be a zero pointer.      *      * @return The pointer to the installed entity resolver object.      */    XMLEntityResolver* getXMLEntityResolver();     /**      * Get a const pointer to the entity resolver      *      * This method returns the installed entity resolver. If no resolver      * has been installed, then it will be a zero pointer.      *      * @return A const pointer to the installed entity resolver object.      */    const XMLEntityResolver* getXMLEntityResolver() const;    /**      * <p><b>"Experimental - subject to change"</b></p>      *      * Get a const pointer to the entity resolver      *      * This method returns the installed entity resolver. If no resolver      * has been installed, then it will be a zero pointer.      *      * @return A const pointer to the installed entity resolver object.      */    const DOMEntityResolver* getEntityResolver() const;    /**      * <p><b>"Experimental - subject to change"</b></p>      *      * Get a pointer to the application filter      *      * This method returns the installed application filter. If no filter      * has been installed, then it will be a zero pointer.      *      * @return The pointer to the installed application filter.      */    DOMBuilderFilter* getFilter();    /**      * <p><b>"Experimental - subject to change"</b></p>      *      * Get a const pointer to the application filter      *      * This method returns the installed application filter. If no filter      * has been installed, then it will be a zero pointer.      *      * @return A const pointer to the installed application filter      */    const DOMBuilderFilter* getFilter() const;    //@}    // -----------------------------------------------------------------------    //  Setter methods    // -----------------------------------------------------------------------    /** @name Setter methods */    //@{    /**      * <p><b>"Experimental - subject to change"</b></p>      *      * Set the error handler      *      * This method allows applications to install their own error handler      * to trap error and warning messages.      *      * <i>Any previously set handler is merely dropped, since the parser      * does not own them.</i>      *      * @param handler  A const pointer to the user supplied error      *                 handler.      *      * @see #getErrorHandler      */    void setErrorHandler(DOMErrorHandler* const handler);    /**      * <p><b>"Experimental - subject to change"</b></p>      *      * Set the entity resolver      *      * This method allows applications to install their own entity      * resolver. By installing an entity resolver, the applications      * can trap and potentially redirect references to external      * entities.      *      * <i>Any previously set entity resolver is merely dropped, since the parser      * does not own them.  If both setEntityResolver and setXMLEntityResolver      * are called, then the last one is used.</i>      *      * @param handler  A const pointer to the user supplied entity      *                 resolver.      *      * @see #getEntityResolver      */    void setEntityResolver(DOMEntityResolver* const handler);    /**      * Set the entity resolver      *      * This method allows applications to install their own entity      * resolver. By installing an entity resolver, the applications      * can trap and potentially redirect references to external      * entities.      *      * <i>Any previously set entity resolver is merely dropped, since the parser      * does not own them.  If both setEntityResolver and setXMLEntityResolver      * are called, then the last one is used.</i>      *      * @param handler  A const pointer to the user supplied entity      *                 resolver.      *      * @see #getXMLEntityResolver      */    void setXMLEntityResolver(XMLEntityResolver* const handler);    /**      * <p><b>"Experimental - subject to change"</b></p>      *      * Set the application filter      *      * When the application provides a filter, the parser will call out to      * the filter at the completion of the construction of each Element node.      * The filter implementation can choose to remove the element from the      * document being constructed (unless the element is the document element)      * or to terminate the parse early. If the document is being validated      * when it's loaded the validation happens before the filter is called.      *      * <i>Any previously set filter is merely dropped, since the parser      * does not own them.</i>      *      * @param filter  A const pointer to the user supplied application      *                filter.      *      * @see #getFilter      */    void setFilter(DOMBuilderFilter* const filter);    //@}    // -----------------------------------------------------------------------    //  Feature methods    // -----------------------------------------------------------------------    /** @name Feature methods */    //@{    /**      * <p><b>"Experimental - subject to change"</b></p>      *      * Set the state of a feature      *      * It is possible for a DOMBuilder to recognize a feature name but to be      * unable to set its value.      *      * @param name  The feature name.      * @param state The requested state of the feature (true or false).

⌨️ 快捷键说明

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