source: NonGTP/Xerces/xercesc/framework/LocalFileFormatTarget.hpp @ 188

Revision 188, 6.1 KB checked in by mattausch, 19 years ago (diff)

added xercesc to support

Line 
1/*
2 * The Apache Software License, Version 1.1
3 *
4 * Copyright (c) 2002 The Apache Software Foundation.  All rights
5 * reserved.
6 *
7 * Redistribution and use in source and binary forms, with or without
8 * modification, are permitted provided that the following conditions
9 * are met:
10 *
11 * 1. Redistributions of source code must retain the above copyright
12 *    notice, this list of conditions and the following disclaimer.
13 *
14 * 2. Redistributions in binary form must reproduce the above copyright
15 *    notice, this list of conditions and the following disclaimer in
16 *    the documentation and/or other materials provided with the
17 *    distribution.
18 *
19 * 3. The end-user documentation included with the redistribution,
20 *    if any, must include the following acknowledgment:
21 *       "This product includes software developed by the
22 *        Apache Software Foundation (http://www.apache.org/)."
23 *    Alternately, this acknowledgment may appear in the software itself,
24 *    if and wherever such third-party acknowledgments normally appear.
25 *
26 * 4. The names "Xerces" and "Apache Software Foundation" must
27 *    not be used to endorse or promote products derived from this
28 *    software without prior written permission. For written
29 *    permission, please contact apache\@apache.org.
30 *
31 * 5. Products derived from this software may not be called "Apache",
32 *    nor may "Apache" appear in their name, without prior written
33 *    permission of the Apache Software Foundation.
34 *
35 * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED
36 * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
37 * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
38 * DISCLAIMED.  IN NO EVENT SHALL THE APACHE SOFTWARE FOUNDATION OR
39 * ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
40 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
41 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF
42 * USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
43 * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
44 * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
45 * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
46 * SUCH DAMAGE.
47 * ====================================================================
48 *
49 * This software consists of voluntary contributions made by many
50 * individuals on behalf of the Apache Software Foundation, and was
51 * originally based on software copyright (c) 1999, International
52 * Business Machines, Inc., http://www.ibm.com .  For more information
53 * on the Apache Software Foundation, please see
54 * <http://www.apache.org/>.
55 */
56
57/*
58 * $Id: LocalFileFormatTarget.hpp,v 1.6 2003/05/16 21:36:55 knoaman Exp $
59 * $Log: LocalFileFormatTarget.hpp,v $
60 * Revision 1.6  2003/05/16 21:36:55  knoaman
61 * Memory manager implementation: Modify constructors to pass in the memory manager.
62 *
63 * Revision 1.5  2003/05/15 18:26:07  knoaman
64 * Partial implementation of the configurable memory manager.
65 *
66 * Revision 1.4  2003/01/24 20:20:22  tng
67 * Add method flush to XMLFormatTarget
68 *
69 * Revision 1.3  2002/11/27 18:09:25  tng
70 * [Bug 13447] Performance: Using LocalFileFormatTarget with DOMWriter is very slow.
71 *
72 * Revision 1.2  2002/11/04 15:00:21  tng
73 * C++ Namespace Support.
74 *
75 * Revision 1.1  2002/06/19 21:59:26  peiyongz
76 * DOM3:DOMSave Interface support: LocalFileFormatTarget
77 *
78 *
79 */
80
81#ifndef LocalFileFormatTarget_HEADER_GUARD_
82#define LocalFileFormatTarget_HEADER_GUARD_
83
84#include <xercesc/framework/XMLFormatter.hpp>
85
86XERCES_CPP_NAMESPACE_BEGIN
87
88class XMLPARSER_EXPORT LocalFileFormatTarget : public XMLFormatTarget {
89public:
90
91    /** @name constructors and destructor */
92    //@{
93    LocalFileFormatTarget
94    (
95        const XMLCh* const
96        , MemoryManager* const  manager = XMLPlatformUtils::fgMemoryManager
97    );
98
99    LocalFileFormatTarget
100    (
101        const char* const
102        , MemoryManager* const  manager = XMLPlatformUtils::fgMemoryManager
103    );
104
105    ~LocalFileFormatTarget();
106    //@}
107
108    // -----------------------------------------------------------------------
109    //  Implementations of the format target interface
110    // -----------------------------------------------------------------------
111    virtual void writeChars(const XMLByte* const toWrite
112                          , const unsigned int   count
113                          , XMLFormatter* const  formatter);
114
115    virtual void flush();
116
117private:
118    // -----------------------------------------------------------------------
119    //  Unimplemented methods.
120    // -----------------------------------------------------------------------
121    LocalFileFormatTarget(const LocalFileFormatTarget&);
122    LocalFileFormatTarget& operator=(const LocalFileFormatTarget&);
123
124    // -----------------------------------------------------------------------
125    //  Private helpers
126    // -----------------------------------------------------------------------
127    void flushBuffer();
128    void insureCapacity(const unsigned int extraNeeded);
129
130    // -----------------------------------------------------------------------
131    //  Private data members
132    //
133    //  fSource
134    //      The source file that we represent. The FileHandle type is defined
135    //      per platform.
136    //
137    //  fDataBuf
138    //      The pointer to the buffer data. Its always
139    //      one larger than fCapacity, to leave room for the null terminator.
140    //
141    //  fIndex
142    //      The current index into the buffer, as characters are appended
143    //      to it. If its zero, then the buffer is empty.
144    //
145    //  fCapacity
146    //      The current capacity of the buffer. Its actually always one
147    //      larger, to leave room for the null terminator.
148    // -----------------------------------------------------------------------
149    FileHandle      fSource;
150    XMLByte*        fDataBuf;
151    unsigned int    fIndex;
152    unsigned int    fCapacity;
153    MemoryManager*  fMemoryManager;
154};
155
156
157XERCES_CPP_NAMESPACE_END
158
159#endif
160
Note: See TracBrowser for help on using the repository browser.