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: MemBufInputSource.hpp,v $ 00059 * Revision 1.1 2002/05/11 19:59:42 bhavani 00060 * CR#CR062582# adding xercesc 1.7 file 00061 * 00062 * Revision 1.2 2002/02/20 18:17:01 tng 00063 * [Bug 5977] Warnings on generating apiDocs. 00064 * 00065 * Revision 1.1.1.1 2002/02/01 22:21:50 peiyongz 00066 * sane_include 00067 * 00068 * Revision 1.6 2000/12/14 18:49:54 tng 00069 * Fix API document generation warning: "Warning: end of member group without matching begin" 00070 * 00071 * Revision 1.5 2000/02/24 20:00:22 abagchi 00072 * Swat for removing Log from API docs 00073 * 00074 * Revision 1.4 2000/02/15 23:59:06 roddey 00075 * More updated documentation of Framework classes. 00076 * 00077 * Revision 1.3 2000/02/15 01:21:30 roddey 00078 * Some initial documentation improvements. More to come... 00079 * 00080 * Revision 1.2 2000/02/06 07:47:46 rahulj 00081 * Year 2K copyright swat. 00082 * 00083 * Revision 1.1 2000/01/12 00:13:26 roddey 00084 * These were moved from internal/ to framework/, which was something that should have 00085 * happened long ago. They are really framework type of classes. 00086 * 00087 * Revision 1.1.1.1 1999/11/09 01:08:10 twl 00088 * Initial checkin 00089 * 00090 * Revision 1.2 1999/11/08 20:44:43 rahul 00091 * Swat for adding in Product name and CVS comment log variable. 00092 * 00093 */ 00094 00095 00096 #if !defined(MEMBUFINPUTSOURCE_HPP) 00097 #define MEMBUFINPUTSOURCE_HPP 00098 00099 #include <xercesc/sax/InputSource.hpp> 00100 00101 class BinInputStream; 00102 00103 00132 class XMLPARSER_EXPORT MemBufInputSource : public InputSource 00133 { 00134 public : 00135 // ----------------------------------------------------------------------- 00136 // Constructors and Destructor 00137 // ----------------------------------------------------------------------- 00138 00141 00161 MemBufInputSource 00162 ( 00163 const XMLByte* const srcDocBytes 00164 , const unsigned int byteCount 00165 , const XMLCh* const bufId 00166 , const bool adoptBuffer = false 00167 ); 00168 00173 MemBufInputSource 00174 ( 00175 const XMLByte* const srcDocBytes 00176 , const unsigned int byteCount 00177 , const char* const bufId 00178 , const bool adoptBuffer = false 00179 ); 00181 00188 ~MemBufInputSource(); 00190 00191 00192 // ----------------------------------------------------------------------- 00193 // Virtual input source interface 00194 // ----------------------------------------------------------------------- 00195 00198 00209 BinInputStream* makeStream() const; 00210 00212 00213 00214 // ----------------------------------------------------------------------- 00215 // Setter methods 00216 // ----------------------------------------------------------------------- 00217 00221 00237 void setCopyBufToStream(const bool newState); 00238 00240 00241 00242 private : 00243 // ----------------------------------------------------------------------- 00244 // Private data members 00245 // 00246 // fAdopted 00247 // Indicates whether the buffer is adopted or not. If so, then it 00248 // is destroyed when the input source is destroyed. 00249 // 00250 // fByteCount 00251 // The size of the source document. 00252 // 00253 // fCopyBufToStream 00254 // This defaults to true (the safe option), which causes it to 00255 // give a copy of the buffer to any streams it creates. If you set 00256 // it to false, it will allow the streams to just reference the 00257 // buffer (in which case this input source must stay alive as long 00258 // as the buffer is in use by the stream.) 00259 // 00260 // fSrcBytes 00261 // The source memory buffer that is being spooled from. Whether it 00262 // belongs to the this input source or not is controlled by the 00263 // fAdopted flag. 00264 // ----------------------------------------------------------------------- 00265 bool fAdopted; 00266 unsigned int fByteCount; 00267 bool fCopyBufToStream; 00268 const XMLByte* fSrcBytes; 00269 }; 00270 00271 00272 inline void MemBufInputSource::setCopyBufToStream(const bool newState) 00273 { 00274 fCopyBufToStream = newState; 00275 } 00276 00277 #endif