1 /*
2  * Licensed to the Apache Software Foundation (ASF) under one or more
3  * contributor license agreements.  See the NOTICE file distributed with
4  * this work for additional information regarding copyright ownership.
5  * The ASF licenses this file to You under the Apache License, Version 2.0
6  * (the "License"); you may not use this file except in compliance with
7  * the License.  You may obtain a copy of the License at
8  *
9  *      http://www.apache.org/licenses/LICENSE-2.0
10  *
11  * Unless required by applicable law or agreed to in writing, software
12  * distributed under the License is distributed on an "AS IS" BASIS,
13  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14  * See the License for the specific language governing permissions and
15  * limitations under the License.
16  */
17 
18 /*
19  * $Id: DateTimeDatatypeValidator.cpp 471747 2006-11-06 14:31:56Z amassari $
20  */
21 
22 // ---------------------------------------------------------------------------
23 //  Includes
24 // ---------------------------------------------------------------------------
25 #include <xercesc/validators/datatype/DateTimeDatatypeValidator.hpp>
26 #include <xercesc/util/OutOfMemoryException.hpp>
27 
28 XERCES_CPP_NAMESPACE_BEGIN
29 
30 // ---------------------------------------------------------------------------
31 //  Constructors and Destructor
32 // ---------------------------------------------------------------------------
DateTimeDatatypeValidator(MemoryManager * const manager)33 DateTimeDatatypeValidator::DateTimeDatatypeValidator(MemoryManager* const manager)
34 :DateTimeValidator(0, 0, 0, DatatypeValidator::DateTime, manager)
35 {
36     setOrdered(XSSimpleTypeDefinition::ORDERED_PARTIAL);
37 }
38 
DateTimeDatatypeValidator(DatatypeValidator * const baseValidator,RefHashTableOf<KVStringPair> * const facets,RefArrayVectorOf<XMLCh> * const enums,const int finalSet,MemoryManager * const manager)39 DateTimeDatatypeValidator::DateTimeDatatypeValidator(
40                           DatatypeValidator*            const baseValidator
41                         , RefHashTableOf<KVStringPair>* const facets
42                         , RefArrayVectorOf<XMLCh>*      const enums
43                         , const int                           finalSet
44                         , MemoryManager* const                manager)
45 :DateTimeValidator(baseValidator, facets, finalSet, DatatypeValidator::DateTime, manager)
46 {
47     init(enums, manager);
48 }
49 
~DateTimeDatatypeValidator()50 DateTimeDatatypeValidator::~DateTimeDatatypeValidator()
51 {}
52 
newInstance(RefHashTableOf<KVStringPair> * const facets,RefArrayVectorOf<XMLCh> * const enums,const int finalSet,MemoryManager * const manager)53 DatatypeValidator* DateTimeDatatypeValidator::newInstance
54 (
55       RefHashTableOf<KVStringPair>* const facets
56     , RefArrayVectorOf<XMLCh>* const      enums
57     , const int                           finalSet
58     , MemoryManager* const                manager
59 )
60 {
61     return (DatatypeValidator*) new (manager) DateTimeDatatypeValidator(this, facets, enums, finalSet, manager);
62 }
63 
64 //
65 // caller need to release the date created here
66 //
parse(const XMLCh * const content,MemoryManager * const manager)67 XMLDateTime* DateTimeDatatypeValidator::parse(const XMLCh* const content, MemoryManager* const manager)
68 {
69     XMLDateTime *pRetDate = new (manager) XMLDateTime(content, manager);
70     Janitor<XMLDateTime> jan(pRetDate);
71 
72     try
73     {
74         pRetDate->parseDateTime();
75     }
76     catch(const OutOfMemoryException&)
77     {
78         jan.release();
79 
80         throw;
81     }
82 
83     return jan.release();
84 }
85 
parse(XMLDateTime * const pDate)86 void DateTimeDatatypeValidator::parse(XMLDateTime* const pDate)
87 {
88     pDate->parseDateTime();
89 }
90 
getCanonicalRepresentation(const XMLCh * const rawData,MemoryManager * const memMgr,bool toValidate) const91 const XMLCh* DateTimeDatatypeValidator::getCanonicalRepresentation(const XMLCh*         const rawData
92                                                                   ,      MemoryManager* const memMgr
93                                                                   ,      bool                 toValidate) const
94 {
95     MemoryManager* toUse = memMgr? memMgr : fMemoryManager;
96 
97     if (toValidate)
98     {
99         DateTimeDatatypeValidator* temp = (DateTimeDatatypeValidator*) this;
100 
101         try
102         {
103             temp->checkContent(rawData, 0, false, toUse);
104         }
105         catch (...)
106         {
107             return 0;
108         }
109     }
110 
111     try
112     {
113         XMLDateTime aDateTime(rawData, toUse);
114         aDateTime.parseDateTime();
115         return aDateTime.getDateTimeCanonicalRepresentation(toUse);
116     }
117     catch (...)
118     {
119         return 0;
120     }
121 
122 }
123 
124 /***
125  * Support for Serialization/De-serialization
126  ***/
127 
IMPL_XSERIALIZABLE_TOCREATE(DateTimeDatatypeValidator)128 IMPL_XSERIALIZABLE_TOCREATE(DateTimeDatatypeValidator)
129 
130 void DateTimeDatatypeValidator::serialize(XSerializeEngine& serEng)
131 {
132     DateTimeValidator::serialize(serEng);
133 }
134 
135 XERCES_CPP_NAMESPACE_END
136 
137 /**
138   * End of file DateTimeDatatypeValidator::cpp
139   */
140 
141