00001 /* 00002 * The Apache Software License, Version 1.1 00003 * 00004 * Copyright (c) 1999-2000 The Apache Software Foundation. All rights 00005 * reserved. 00006 * 00007 * Redistribution and use in source and binary forms, with or without 00008 * modification, are permitted provided that the following conditions 00009 * are met: 00010 * 00011 * 1. Redistributions of source code must retain the above copyright 00012 * notice, this list of conditions and the following disclaimer. 00013 * 00014 * 2. Redistributions in binary form must reproduce the above copyright 00015 * notice, this list of conditions and the following disclaimer in 00016 * the documentation and/or other materials provided with the 00017 * distribution. 00018 * 00019 * 3. The end-user documentation included with the redistribution, 00020 * if any, must include the following acknowledgment: 00021 * "This product includes software developed by the 00022 * Apache Software Foundation (http://www.apache.org/)." 00023 * Alternately, this acknowledgment may appear in the software itself, 00024 * if and wherever such third-party acknowledgments normally appear. 00025 * 00026 * 4. The names "Xerces" and "Apache Software Foundation" must 00027 * not be used to endorse or promote products derived from this 00028 * software without prior written permission. For written 00029 * permission, please contact apache\@apache.org. 00030 * 00031 * 5. Products derived from this software may not be called "Apache", 00032 * nor may "Apache" appear in their name, without prior written 00033 * permission of the Apache Software Foundation. 00034 * 00035 * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED 00036 * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES 00037 * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE 00038 * DISCLAIMED. IN NO EVENT SHALL THE APACHE SOFTWARE FOUNDATION OR 00039 * ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, 00040 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT 00041 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF 00042 * USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND 00043 * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, 00044 * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT 00045 * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 00046 * SUCH DAMAGE. 00047 * ==================================================================== 00048 * 00049 * This software consists of voluntary contributions made by many 00050 * individuals on behalf of the Apache Software Foundation, and was 00051 * originally based on software copyright (c) 1999, International 00052 * Business Machines, Inc., http://www.ibm.com . For more information 00053 * on the Apache Software Foundation, please see 00054 * <http://www.apache.org/>. 00055 */ 00056 00057 /* 00058 * $Log: VecAttrListImpl.hpp,v $ 00059 * Revision 1.1 2002/05/11 20:18:51 bhavani 00060 * CR#CR062582# adding xercesc 1.7 file 00061 * 00062 * Revision 1.1.1.1 2002/02/01 22:21:58 peiyongz 00063 * sane_include 00064 * 00065 * Revision 1.4 2000/02/24 20:18:07 abagchi 00066 * Swat for removing Log from API docs 00067 * 00068 * Revision 1.3 2000/02/06 07:47:53 rahulj 00069 * Year 2K copyright swat. 00070 * 00071 * Revision 1.2 1999/12/15 19:49:37 roddey 00072 * Added second getValue() method which takes a short name for the attribute 00073 * to get the value for. Just a convenience method. 00074 * 00075 * Revision 1.1.1.1 1999/11/09 01:08:19 twl 00076 * Initial checkin 00077 * 00078 * Revision 1.2 1999/11/08 20:44:45 rahul 00079 * Swat for adding in Product name and CVS comment log variable. 00080 * 00081 */ 00082 00083 00084 #if !defined(VECATTRLISTIMPL_HPP) 00085 #define VECATTRLISTIMPL_HPP 00086 00087 #include <xercesc/sax/AttributeList.hpp> 00088 #include <xercesc/framework/XMLAttr.hpp> 00089 #include <xercesc/util/RefVectorOf.hpp> 00090 00091 class XMLPARSER_EXPORT VecAttrListImpl : public AttributeList 00092 { 00093 public : 00094 // ----------------------------------------------------------------------- 00095 // Constructors and Destructor 00096 // ----------------------------------------------------------------------- 00097 VecAttrListImpl(); 00098 ~VecAttrListImpl(); 00099 00100 00101 // ----------------------------------------------------------------------- 00102 // Implementation of the attribute list interface 00103 // ----------------------------------------------------------------------- 00104 virtual unsigned int getLength() const; 00105 virtual const XMLCh* getName(const unsigned int index) const; 00106 virtual const XMLCh* getType(const unsigned int index) const; 00107 virtual const XMLCh* getValue(const unsigned int index) const; 00108 virtual const XMLCh* getType(const XMLCh* const name) const; 00109 virtual const XMLCh* getValue(const XMLCh* const name) const; 00110 virtual const XMLCh* getValue(const char* const name) const; 00111 00112 00113 // ----------------------------------------------------------------------- 00114 // Setter methods 00115 // ----------------------------------------------------------------------- 00116 void setVector 00117 ( 00118 const RefVectorOf<XMLAttr>* const srcVec 00119 , const unsigned int count 00120 , const bool adopt = false 00121 ); 00122 00123 00124 private : 00125 // ----------------------------------------------------------------------- 00126 // Unimplemented constructors and operators 00127 // ----------------------------------------------------------------------- 00128 VecAttrListImpl(const VecAttrListImpl&); 00129 void operator=(const VecAttrListImpl&); 00130 00131 00132 // ----------------------------------------------------------------------- 00133 // Private data members 00134 // 00135 // fAdopt 00136 // Indicates whether the passed vector is to be adopted or not. If 00137 // so, we destroy it when we are destroyed (and when a new vector is 00138 // set!) 00139 // 00140 // fCount 00141 // The count of elements in the vector that should be considered 00142 // valid. This is an optimization to allow vector elements to be 00143 // reused over and over but a different count of them be valid for 00144 // each use. 00145 // 00146 // fVector 00147 // The vector that provides the backing for the list. 00148 // ----------------------------------------------------------------------- 00149 bool fAdopt; 00150 unsigned int fCount; 00151 const RefVectorOf<XMLAttr>* fVector; 00152 }; 00153 00154 #endif