source: NonGTP/Xerces/xercesc/validators/datatype/NCNameDatatypeValidator.hpp @ 188

Revision 188, 7.9 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) 2001 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: NCNameDatatypeValidator.hpp,v 1.8 2004/01/29 11:51:22 cargilld Exp $
59 * $Log: NCNameDatatypeValidator.hpp,v $
60 * Revision 1.8  2004/01/29 11:51:22  cargilld
61 * Code cleanup changes to get rid of various compiler diagnostic messages.
62 *
63 * Revision 1.7  2003/12/17 00:18:39  cargilld
64 * Update to memory management so that the static memory manager (one used to call Initialize) is only for static data.
65 *
66 * Revision 1.6  2003/11/12 20:32:03  peiyongz
67 * Statless Grammar: ValidationContext
68 *
69 * Revision 1.5  2003/09/30 18:17:53  peiyongz
70 * Implementation of Serialization/Deserialization
71 *
72 * Revision 1.4  2003/05/15 18:53:26  knoaman
73 * Partial implementation of the configurable memory manager.
74 *
75 * Revision 1.3  2002/12/18 14:17:55  gareth
76 * Fix to bug #13438. When you eant a vector that calls delete[] on its members you should use RefArrayVectorOf.
77 *
78 * Revision 1.2  2002/11/04 14:53:28  tng
79 * C++ Namespace Support.
80 *
81 * Revision 1.1.1.1  2002/02/01 22:22:42  peiyongz
82 * sane_include
83 *
84 * Revision 1.3  2001/10/09 20:49:09  peiyongz
85 * init(): take 1 arg
86 *
87 * Revision 1.2  2001/09/27 13:51:25  peiyongz
88 * DTV Reorganization: ctor/init created to be used by derived class
89 *
90 * Revision 1.1  2001/09/25 15:58:45  peiyongz
91 * DTV Reorganization: new class
92 *
93 */
94
95#if !defined(NCNAME_DATATYPEVALIDATOR_HPP)
96#define NCNAME_DATATYPEVALIDATOR_HPP
97
98#include <xercesc/validators/datatype/StringDatatypeValidator.hpp>
99
100XERCES_CPP_NAMESPACE_BEGIN
101
102class VALIDATORS_EXPORT NCNameDatatypeValidator : public StringDatatypeValidator
103{
104public:
105
106    // -----------------------------------------------------------------------
107    //  Public ctor/dtor
108    // -----------------------------------------------------------------------
109        /** @name Constructors and Destructor */
110    //@{
111
112    NCNameDatatypeValidator
113    (
114        MemoryManager* const manager = XMLPlatformUtils::fgMemoryManager
115    );
116    NCNameDatatypeValidator
117    (
118        DatatypeValidator* const baseValidator
119        , RefHashTableOf<KVStringPair>* const facets
120        , RefArrayVectorOf<XMLCh>* const enums
121        , const int finalSet
122        , MemoryManager* const manager = XMLPlatformUtils::fgMemoryManager
123    );
124
125    virtual ~NCNameDatatypeValidator();
126
127        //@}
128
129    // -----------------------------------------------------------------------
130    // Validation methods
131    // -----------------------------------------------------------------------
132    /** @name Validation Function */
133    //@{
134
135    /**
136     * validate that a string matches the boolean datatype
137     * @param content A string containing the content to be validated
138     *
139     * @exception throws InvalidDatatypeException if the content is
140     * is not valid.
141     */
142
143        virtual void validate
144                 (
145                  const XMLCh*             const content
146                ,       ValidationContext* const context = 0
147                ,       MemoryManager*     const manager = XMLPlatformUtils::fgMemoryManager
148                  );
149
150    //@}
151
152    // -----------------------------------------------------------------------
153    // Compare methods
154    // -----------------------------------------------------------------------
155    /** @name Compare Function */
156    //@{
157
158    /**
159     * Compare two boolean data types
160     *
161     * @param content1
162     * @param content2
163     * @return
164     */
165    virtual int compare(const XMLCh* const, const XMLCh* const
166        ,       MemoryManager*     const manager = XMLPlatformUtils::fgMemoryManager);
167
168    //@}
169
170    /**
171      * Returns an instance of the base datatype validator class
172          * Used by the DatatypeValidatorFactory.
173      */
174    virtual DatatypeValidator* newInstance
175    (
176        RefHashTableOf<KVStringPair>* const facets
177        , RefArrayVectorOf<XMLCh>* const enums
178        , const int finalSet
179        , MemoryManager* const manager = XMLPlatformUtils::fgMemoryManager
180    );
181
182    /***
183     * Support for Serialization/De-serialization
184     ***/
185    DECL_XSERIALIZABLE(NCNameDatatypeValidator)
186
187protected:
188
189    //
190    // ctor provided to be used by derived classes
191    //
192    NCNameDatatypeValidator
193    (
194        DatatypeValidator* const baseValidator
195        , RefHashTableOf<KVStringPair>* const facets
196        , const int finalSet
197        , const ValidatorType type
198        , MemoryManager* const manager = XMLPlatformUtils::fgMemoryManager
199    );
200
201    virtual void checkValueSpace(const XMLCh* const content
202        , MemoryManager* const manager);
203
204private:
205    // -----------------------------------------------------------------------
206    //  Unimplemented constructors and operators
207    // -----------------------------------------------------------------------
208    NCNameDatatypeValidator(const NCNameDatatypeValidator&);
209    NCNameDatatypeValidator& operator=(const NCNameDatatypeValidator&);
210    // -----------------------------------------------------------------------
211    //  Private data members
212    //
213        //             
214    // -----------------------------------------------------------------------
215
216};
217
218XERCES_CPP_NAMESPACE_END
219
220#endif
221
222/**
223  * End of file NCNameDatatypeValidator.hpp
224  */
225
Note: See TracBrowser for help on using the repository browser.