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

📄 psviattributelist.hpp

📁 经典开源游戏glest的源代码
💻 HPP
字号:
/* * Licensed to the Apache Software Foundation (ASF) under one or more * contributor license agreements.  See the NOTICE file distributed with * this work for additional information regarding copyright ownership. * The ASF licenses this file to You under the Apache License, Version 2.0 * (the "License"); you may not use this file except in compliance with * the License.  You may obtain a copy of the License at *  *      http://www.apache.org/licenses/LICENSE-2.0 *  * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. *//* * $Id: PSVIAttributeList.hpp 568078 2007-08-21 11:43:25Z amassari $ */#if !defined(PSVIATTRIBUTEDERIVATION_LIST_HPP)#define PSVIATTRIBUTEDERIVATION_LIST_HPP#include <xercesc/util/PlatformUtils.hpp>#include <xercesc/framework/psvi/PSVIAttribute.hpp>#include <xercesc/util/ValueVectorOf.hpp>XERCES_CPP_NAMESPACE_BEGIN/** * A container for the PSVI contributions to attributes that occur * on a particular element. * This is always owned by the parser/validator from * which it is obtained.  The parser/validator will specify  * under what conditions it may be relied upon to have meaningful contents. */class XMLPARSER_EXPORT PSVIAttributeList : public XMemory{public:    //  Constructors and Destructor    // -----------------------------------------------------------------------    /** @name Constructors */    //@{    /**      * The default constructor       *      * @param  manager     The configurable memory manager      */    PSVIAttributeList( MemoryManager* const manager = XMLPlatformUtils::fgMemoryManager);    //@};    /** @name Destructor */    //@{    ~PSVIAttributeList();    //@}    //---------------------    /** @name PSVIAttributeList methods */    //@{    /*     * Get the number of attributes whose PSVI contributions     * are contained in this list.     */    unsigned int getLength() const;    /*     * Get the PSVI contribution of attribute at position i     * in this list.  Indeces start from 0.     * @param index index from which the attribute PSVI contribution     * is to come.       * @return PSVIAttribute containing the attributes PSVI contributions;     * null is returned if the index is out of range.     */    PSVIAttribute *getAttributePSVIAtIndex(const unsigned int index);    /*     * Get local part of attribute name at position index in the list.     * Indeces start from 0.     * @param index index from which the attribute name      * is to come.       * @return local part of the attribute's name; null is returned if the index     * is out of range.     */    const XMLCh *getAttributeNameAtIndex(const unsigned int index);    /*     * Get namespace of attribute at position index in the list.     * Indeces start from 0.     * @param index index from which the attribute namespace      * is to come.       * @return namespace of the attribute;      * null is returned if the index is out of range.     */    const XMLCh *getAttributeNamespaceAtIndex(const unsigned int index);    /*     * Get the PSVI contribution of attribute with given      * local name and namespace.     * @param attrName  local part of the attribute's name     * @param attrNamespace  namespace of the attribute     * @return null if the attribute PSVI does not exist     */    PSVIAttribute *getAttributePSVIByName(const XMLCh *attrName                    , const XMLCh * attrNamespace);    //@}    //----------------------------------    /** methods needed by implementation */    //@{    /**      * returns a PSVI attribute of undetermined state and given name/namespace and       * makes that object part of the internal list.  Intended to be called      * during validation of an element.      * @param attrName     name of this attribute      * @param attrNS       URI of the attribute      * @return             new, uninitialized, PSVIAttribute object      */    PSVIAttribute *getPSVIAttributeToFill(            const XMLCh * attrName            , const XMLCh * attrNS);    /**      * reset the list      */    void reset();    //@}private:    // -----------------------------------------------------------------------    //  Unimplemented constructors and operators    // -----------------------------------------------------------------------    PSVIAttributeList(const PSVIAttributeList&);    PSVIAttributeList & operator=(const PSVIAttributeList &);    // -----------------------------------------------------------------------    //  data members    // -----------------------------------------------------------------------    // fMemoryManager    //  handler to provide dynamically-need memory    // fAttrList    //  list of PSVIAttributes contained by this object    // fAttrNameList    //  list of the names of the initialized PSVIAttribute objects contained    //  in this listing    // fAttrNSList    //  list of the namespaces of the initialized PSVIAttribute objects contained    //  in this listing    // fAttrPos    //  current number of initialized PSVIAttributes in fAttrList    MemoryManager*                  fMemoryManager;        RefVectorOf<PSVIAttribute>*     fAttrList;    RefArrayVectorOf<XMLCh>*        fAttrNameList;    RefArrayVectorOf<XMLCh>*        fAttrNSList;    unsigned int                    fAttrPos;};inline PSVIAttributeList::~PSVIAttributeList() {    delete fAttrList;    delete fAttrNameList;    delete fAttrNSList;}inline PSVIAttribute *PSVIAttributeList::getPSVIAttributeToFill(            const XMLCh *attrName            , const XMLCh * attrNS){    PSVIAttribute *retAttr = 0;    if(fAttrPos == fAttrList->size())    {        retAttr = new (fMemoryManager)PSVIAttribute(fMemoryManager);        fAttrList->addElement(retAttr);        fAttrNameList->addElement((XMLCh *)attrName);        fAttrNSList->addElement((XMLCh *)attrNS);    }    else    {        retAttr = fAttrList->elementAt(fAttrPos);        fAttrNameList->setElementAt((XMLCh *)attrName, fAttrPos);        fAttrNSList->setElementAt((XMLCh *)attrNS, fAttrPos);    }    fAttrPos++;    return retAttr;}inline void PSVIAttributeList::reset(){    fAttrPos = 0;}XERCES_CPP_NAMESPACE_END#endif

⌨️ 快捷键说明

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