<HTML><HEAD><TITLE>Xalan-C++ API Documentation</TITLE></HEAD> <BODY> <h2 align="center">Xalan-C++ API Documentation</h2> <h3 align="center">The Xalan C++ XSLT Processor Version 1.4</h3> </BODY> <!-- Generated by Doxygen 1.1.2 on Mon Sep 16 08:22:53 2002 --> <center> <a class="qindex" href="index.html">Main Page</a> <a class="qindex" href="namespaces.html">Namespace List</a> <a class="qindex" href="hierarchy.html">Class Hierarchy</a> <a class="qindex" href="classes.html">Alphabetical List</a> <a class="qindex" href="annotated.html">Compound List</a> <a class="qindex" href="files.html">File List</a> <a class="qindex" href="functions.html">Compound Members</a> <a class="qindex" href="globals.html">File Members</a> </center> <hr><h1>AttributeListImpl.hpp</h1><a href="AttributeListImpl.hpp.html">Go to the documentation of this file.</a><div class="fragment"><pre>00001 /* 00002 * The Apache Software License, Version 1.1 00003 * 00004 * 00005 * Copyright (c) 1999 The Apache Software Foundation. All rights 00006 * reserved. 00007 * 00008 * Redistribution and use in source and binary forms, with or without 00009 * modification, are permitted provided that the following conditions 00010 * are met: 00011 * 00012 * 1. Redistributions of source code must retain the above copyright 00013 * notice, this list of conditions and the following disclaimer. 00014 * 00015 * 2. Redistributions in binary form must reproduce the above copyright 00016 * notice, this list of conditions and the following disclaimer in 00017 * the documentation and/or other materials provided with the 00018 * distribution. 00019 * 00020 * 3. The end-user documentation included with the redistribution, 00021 * if any, must include the following acknowledgment: 00022 * "This product includes software developed by the 00023 * Apache Software Foundation (http://www.apache.org/)." 00024 * Alternately, this acknowledgment may appear in the software itself, 00025 * if and wherever such third-party acknowledgments normally appear. 00026 * 00027 * 4. The names "Xalan" and "Apache Software Foundation" must 00028 * not be used to endorse or promote products derived from this 00029 * software without prior written permission. For written 00030 * permission, please contact apache@apache.org. 00031 * 00032 * 5. Products derived from this software may not be called "Apache", 00033 * nor may "Apache" appear in their name, without prior written 00034 * permission of the Apache Software Foundation. 00035 * 00036 * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED 00037 * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES 00038 * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE 00039 * DISCLAIMED. IN NO EVENT SHALL THE APACHE SOFTWARE FOUNDATION OR 00040 * ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, 00041 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT 00042 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF 00043 * USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND 00044 * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, 00045 * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT 00046 * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 00047 * SUCH DAMAGE. 00048 * ==================================================================== 00049 * 00050 * This software consists of voluntary contributions made by many 00051 * individuals on behalf of the Apache Software Foundation and was 00052 * originally based on software copyright (c) 1999, International 00053 * Business Machines, Inc., http://www.ibm.com. For more 00054 * information on the Apache Software Foundation, please see 00055 * <http://www.apache.org/>. 00056 */ 00057 #if !defined(ATTRIBUTELISTIMPL_HEADER_GUARD_1357924680) <a name="l00058"><a class="code" href="AttributeListImpl.hpp.html#a0">00058</a></a> #define ATTRIBUTELISTIMPL_HEADER_GUARD_1357924680 00059 00060 00061 00062 // Base include file. Must be first. 00063 #include <PlatformSupport/PlatformSupportDefinitions.hpp> 00064 00065 00066 00067 #include <vector> 00068 00069 00070 00071 #include <xercesc/sax/AttributeList.hpp> 00072 00073 00074 00075 class <a class="code" href="class_attributevectorentry.html">AttributeVectorEntry</a>; 00076 00077 00078 <a name="l00079"><a class="code" href="class_attributelistimpl.html">00079</a></a> class XALAN_PLATFORMSUPPORT_EXPORT <a class="code" href="class_attributelistimpl.html">AttributeListImpl</a> : public <a class="code" href="class_attributelist.html">AttributeList</a> 00080 { 00081 public: 00082 00083 explicit 00084 <a class="code" href="class_attributelistimpl.html#a0">AttributeListImpl</a>(); 00085 00086 virtual 00087 <a class="code" href="class_attributelistimpl.html#a1">~AttributeListImpl</a>(); 00088 00089 <a class="code" href="class_attributelistimpl.html#a0">AttributeListImpl</a>(const <a class="code" href="class_attributelistimpl.html">AttributeListImpl</a>& theSource); 00090 00091 <a class="code" href="class_attributelistimpl.html#a0">AttributeListImpl</a>(const <a class="code" href="class_attributelist.html">AttributeList</a>& theSource); 00092 00093 <a class="code" href="class_attributelistimpl.html">AttributeListImpl</a>& 00094 operator=(const <a class="code" href="class_attributelistimpl.html">AttributeListImpl</a>& theRHS); 00095 00096 <a class="code" href="class_attributelistimpl.html">AttributeListImpl</a>& 00097 operator=(const <a class="code" href="class_attributelist.html">AttributeList</a>& theRHS); 00098 00099 // These are inherited from AttributeList 00100 virtual unsigned int 00101 <a class="code" href="class_attributelistimpl.html#a6">getLength</a>() const; 00102 00103 virtual const XMLCh* 00104 <a class="code" href="class_attributelistimpl.html#a7">getName</a>(const unsigned int index) const; 00105 00106 virtual const XMLCh* 00107 <a class="code" href="class_attributelistimpl.html#a8">getType</a>(const unsigned int index) const; 00108 00109 virtual const XMLCh* 00110 <a class="code" href="class_attributelistimpl.html#a9">getValue</a>(const unsigned int index) const; 00111 00112 virtual const XMLCh* 00113 <a class="code" href="class_attributelistimpl.html#a8">getType</a>(const XMLCh* const name) const; 00114 00115 virtual const XMLCh* 00116 <a class="code" href="class_attributelistimpl.html#a9">getValue</a>(const XMLCh* const name) const; 00117 00118 virtual const XMLCh* 00119 <a class="code" href="class_attributelistimpl.html#a9">getValue</a>(const char* const name) const; 00120 00121 // The mutators are new to this class. 00122 00126 virtual void 00127 <a class="code" href="class_attributelistimpl.html#a13">clear</a>(); 00128 00136 virtual bool 00137 <a class="code" href="class_attributelistimpl.html#a14">addAttribute</a>( 00138 const XMLCh* name, 00139 const XMLCh* type, 00140 const XMLCh* value); 00141 00147 virtual bool 00148 <a class="code" href="class_attributelistimpl.html#a15">removeAttribute</a>(const XMLCh* name); 00149 00156 void <a name="l00157"><a class="code" href="class_attributelistimpl.html#a16">00157</a></a> <a class="code" href="class_attributelistimpl.html#a16">swap</a>(<a class="code" href="class_attributelistimpl.html">AttributeListImpl</a>& theOther) 00158 { 00159 m_AttributeVector.swap(theOther.m_AttributeVector); 00160 } 00161 00168 void <a name="l00169"><a class="code" href="class_attributelistimpl.html#a17">00169</a></a> <a class="code" href="class_attributelistimpl.html#a17">reserve</a>(unsigned int theCount) 00170 { 00171 m_AttributeVector.reserve(theCount); 00172 } 00173 00174 #if defined(XALAN_NO_NAMESPACES) 00175 // This vector will hold the entries. 00176 typedef vector<<a class="code" href="class_attributevectorentry.html">AttributeVectorEntry</a>*> AttributeVectorType; 00177 #else 00178 // This vector will hold the entries. <a name="l00179"><a class="code" href="class_attributelistimpl.html#s0">00179</a></a> typedef std::vector<<a class="code" href="class_attributevectorentry.html">AttributeVectorEntry</a>*> AttributeVectorType; 00180 #endif 00181 00182 #if defined(XALAN_NEEDS_EXPLICIT_TEMPLATE_INSTANTIATION) 00183 struct NameCompareFunctor 00184 { 00185 NameCompareFunctor(const XMLCh* theName) : 00186 m_name(theName) 00187 { 00188 } 00189 00190 bool 00191 operator()(const <a class="code" href="class_attributevectorentry.html">AttributeVectorEntry</a>* theEntry) const; 00192 00193 private: 00194 00195 const XMLCh* const m_name; 00196 }; 00197 #endif 00198 00199 private: 00200 00201 // This is not implemented. 00202 bool 00203 operator==(const <a class="code" href="class_attributelistimpl.html">AttributeListImpl</a>&) const; 00204 00205 // Default vector allocation size. 00206 enum 00207 { 00208 eDefaultVectorSize = 5 00209 }; 00210 00211 <a class="code" href="class_attributevectorentry.html">AttributeVectorEntry</a>* 00212 getNewEntry( 00213 const XMLCh* name, 00214 const XMLCh* type, 00215 const XMLCh* value); 00216 00217 // Helper function to delete entries... 00218 static void 00219 deleteEntries(AttributeVectorType& theVector); 00220 00221 AttributeVectorType m_AttributeVector; 00222 00223 AttributeVectorType m_cacheVector; 00224 }; 00225 00226 00227 00228 #endif // ATTRIBUTELISTIMPL_HEADER_GUARD_1357924680 </div></pre><p align="center"><a href="diagramnotes.html">Interpreting class diagrams</a></p> <p><FONT color="#000000" face="arial,helvetica,sanserif" size="-1"> <i><A href="http://www.stack.nl/~dimitri/doxygen/">Doxygen</A> and <A href="http://www.research.att.com/sw/tools/graphviz/">GraphViz</A> are used to generate this API documentation from the Xalan-C header files.</I></FONT></p> <TABLE border="0" cellpadding="0" cellspacing="0" width="820"><TR><TD bgcolor="#0086b2"><IMG height="1" src="images/dot.gif" width="1"></TD></TR></TABLE> <TABLE BORDER="0" CELLPADDING="0" CELLSPACING="0" WIDTH="80%"> <TR> <TD WIDTH="80%" VALIGN="TOP"> <P ALIGN="CENTER"><B>Xalan-C++ XSLT Processor Version 1.4</B><BR> Copyright © 2000, 2001, 2002 The Apache Software Foundation. All Rights Reserved.</i></p> </TD> </TR> <TR> <TD WIDTH="100%"> <P ALIGN="CENTER"><IMG SRC="ApacheLogo.jpg" WIDTH="387" HEIGHT="100" ALIGN="BOTTOM" BORDER="0"> </TD> </TR> </TABLE>