2 * Copyright 2001-2008 Internet2
\r
4 * Licensed under the Apache License, Version 2.0 (the "License");
\r
5 * you may not use this file except in compliance with the License.
\r
6 * You may obtain a copy of the License at
\r
8 * http://www.apache.org/licenses/LICENSE-2.0
\r
10 * Unless required by applicable law or agreed to in writing, software
\r
11 * distributed under the License is distributed on an "AS IS" BASIS,
\r
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
\r
13 * See the License for the specific language governing permissions and
\r
14 * limitations under the License.
\r
18 * @file xmltooling/base.h
\r
20 * Base header file definitions
\r
21 * Must be included prior to including any other header
\r
24 #ifndef __xmltooling_base_h__
\r
25 #define __xmltooling_base_h__
\r
29 /* Required for sprintf, used by integer XML attribute macros. */
\r
32 #if defined (_MSC_VER) || defined(__BORLANDC__)
\r
33 #include <xmltooling/config_pub_win32.h>
\r
35 #include <xmltooling/config_pub.h>
\r
38 #ifdef XMLTOOLING_LITE
\r
39 # define XMLTOOLING_NO_XMLSEC 1
\r
42 #if defined(XMLTOOLING_NO_XMLSEC) || !defined(HAVE_XSECSIZE_T)
\r
43 # ifdef XMLTOOLING_XERCESC_64BITSAFE
\r
44 # include <xercesc/util/XercesDefs.hpp>
\r
45 typedef XMLSize_t xsecsize_t;
\r
47 typedef unsigned int xsecsize_t;
\r
51 // Windows and GCC4 Symbol Visibility Macros
\r
53 #define XMLTOOL_IMPORT __declspec(dllimport)
\r
54 #define XMLTOOL_EXPORT __declspec(dllexport)
\r
55 #define XMLTOOL_DLLLOCAL
\r
56 #define XMLTOOL_DLLPUBLIC
\r
58 #define XMLTOOL_IMPORT
\r
59 #ifdef GCC_HASCLASSVISIBILITY
\r
60 #define XMLTOOL_EXPORT __attribute__ ((visibility("default")))
\r
61 #define XMLTOOL_DLLLOCAL __attribute__ ((visibility("hidden")))
\r
62 #define XMLTOOL_DLLPUBLIC __attribute__ ((visibility("default")))
\r
64 #define XMLTOOL_EXPORT
\r
65 #define XMLTOOL_DLLLOCAL
\r
66 #define XMLTOOL_DLLPUBLIC
\r
70 // Define XMLTOOL_API for DLL builds
\r
71 #ifdef XMLTOOLING_EXPORTS
\r
72 #define XMLTOOL_API XMLTOOL_EXPORT
\r
74 #define XMLTOOL_API XMLTOOL_IMPORT
\r
77 // Throwable classes must always be visible on GCC in all binaries
\r
79 #define XMLTOOL_EXCEPTIONAPI(api) api
\r
80 #elif defined(GCC_HASCLASSVISIBILITY)
\r
81 #define XMLTOOL_EXCEPTIONAPI(api) XMLTOOL_EXPORT
\r
83 #define XMLTOOL_EXCEPTIONAPI(api)
\r
87 #define XMLTOOLING_DOXYGEN(desc) /##** desc */
\r
89 #define XMLTOOLING_DOXYGEN(desc)
\r
93 * Blocks copy c'tor and assignment operator for a class.
\r
95 #define MAKE_NONCOPYABLE(type) \
\r
97 type(const type&); \
\r
98 type& operator=(const type&)
\r
100 #ifndef DOXYGEN_SKIP
\r
104 #define UNICODE_LITERAL_1(a) {xercesc::chLatin_##a, xercesc::chNull}
\r
105 #define UNICODE_LITERAL_2(a,b) {xercesc::chLatin_##a, xercesc::chLatin_##b, xercesc::chNull}
\r
106 #define UNICODE_LITERAL_3(a,b,c) {xercesc::chLatin_##a, xercesc::chLatin_##b, xercesc::chLatin_##c, xercesc::chNull}
\r
107 #define UNICODE_LITERAL_4(a,b,c,d) {xercesc::chLatin_##a, xercesc::chLatin_##b, xercesc::chLatin_##c, xercesc::chLatin_##d, xercesc::chNull}
\r
108 #define UNICODE_LITERAL_5(a,b,c,d,e) \
\r
109 {xercesc::chLatin_##a, xercesc::chLatin_##b, xercesc::chLatin_##c, xercesc::chLatin_##d, xercesc::chLatin_##e, xercesc::chNull}
\r
110 #define UNICODE_LITERAL_6(a,b,c,d,e,f) \
\r
111 {xercesc::chLatin_##a, xercesc::chLatin_##b, xercesc::chLatin_##c, xercesc::chLatin_##d, xercesc::chLatin_##e, xercesc::chLatin_##f, xercesc::chNull}
\r
112 #define UNICODE_LITERAL_7(a,b,c,d,e,f,g) \
\r
113 {xercesc::chLatin_##a, xercesc::chLatin_##b, xercesc::chLatin_##c, xercesc::chLatin_##d, xercesc::chLatin_##e, xercesc::chLatin_##f, xercesc::chLatin_##g, xercesc::chNull}
\r
114 #define UNICODE_LITERAL_8(a,b,c,d,e,f,g,h) \
\r
115 {xercesc::chLatin_##a, xercesc::chLatin_##b, xercesc::chLatin_##c, xercesc::chLatin_##d, xercesc::chLatin_##e, xercesc::chLatin_##f, xercesc::chLatin_##g, xercesc::chLatin_##h, xercesc::chNull}
\r
116 #define UNICODE_LITERAL_9(a,b,c,d,e,f,g,h,i) \
\r
117 {xercesc::chLatin_##a, xercesc::chLatin_##b, xercesc::chLatin_##c, xercesc::chLatin_##d, xercesc::chLatin_##e, xercesc::chLatin_##f, xercesc::chLatin_##g, xercesc::chLatin_##h, xercesc::chLatin_##i, xercesc::chNull}
\r
118 #define UNICODE_LITERAL_10(a,b,c,d,e,f,g,h,i,j) \
\r
119 {xercesc::chLatin_##a, xercesc::chLatin_##b, xercesc::chLatin_##c, xercesc::chLatin_##d, xercesc::chLatin_##e, xercesc::chLatin_##f, xercesc::chLatin_##g, xercesc::chLatin_##h, xercesc::chLatin_##i, \
\r
120 xercesc::chLatin_##j, xercesc::chNull}
\r
121 #define UNICODE_LITERAL_11(a,b,c,d,e,f,g,h,i,j,k) \
\r
122 {xercesc::chLatin_##a, xercesc::chLatin_##b, xercesc::chLatin_##c, xercesc::chLatin_##d, xercesc::chLatin_##e, xercesc::chLatin_##f, xercesc::chLatin_##g, xercesc::chLatin_##h, xercesc::chLatin_##i, \
\r
123 xercesc::chLatin_##j, xercesc::chLatin_##k, xercesc::chNull}
\r
124 #define UNICODE_LITERAL_12(a,b,c,d,e,f,g,h,i,j,k,l) \
\r
125 {xercesc::chLatin_##a, xercesc::chLatin_##b, xercesc::chLatin_##c, xercesc::chLatin_##d, xercesc::chLatin_##e, xercesc::chLatin_##f, xercesc::chLatin_##g, xercesc::chLatin_##h, xercesc::chLatin_##i, \
\r
126 xercesc::chLatin_##j, xercesc::chLatin_##k, xercesc::chLatin_##l, xercesc::chNull}
\r
127 #define UNICODE_LITERAL_13(a,b,c,d,e,f,g,h,i,j,k,l,m) \
\r
128 {xercesc::chLatin_##a, xercesc::chLatin_##b, xercesc::chLatin_##c, xercesc::chLatin_##d, xercesc::chLatin_##e, xercesc::chLatin_##f, xercesc::chLatin_##g, xercesc::chLatin_##h, xercesc::chLatin_##i, \
\r
129 xercesc::chLatin_##j, xercesc::chLatin_##k, xercesc::chLatin_##l, xercesc::chLatin_##m, xercesc::chNull}
\r
130 #define UNICODE_LITERAL_14(a,b,c,d,e,f,g,h,i,j,k,l,m,n) \
\r
131 {xercesc::chLatin_##a, xercesc::chLatin_##b, xercesc::chLatin_##c, xercesc::chLatin_##d, xercesc::chLatin_##e, xercesc::chLatin_##f, xercesc::chLatin_##g, xercesc::chLatin_##h, xercesc::chLatin_##i, \
\r
132 xercesc::chLatin_##j, xercesc::chLatin_##k, xercesc::chLatin_##l, xercesc::chLatin_##m, xercesc::chLatin_##n, xercesc::chNull}
\r
133 #define UNICODE_LITERAL_15(a,b,c,d,e,f,g,h,i,j,k,l,m,n,o) \
\r
134 {xercesc::chLatin_##a, xercesc::chLatin_##b, xercesc::chLatin_##c, xercesc::chLatin_##d, xercesc::chLatin_##e, xercesc::chLatin_##f, xercesc::chLatin_##g, xercesc::chLatin_##h, xercesc::chLatin_##i, \
\r
135 xercesc::chLatin_##j, xercesc::chLatin_##k, xercesc::chLatin_##l, xercesc::chLatin_##m, xercesc::chLatin_##n, xercesc::chLatin_##o, xercesc::chNull}
\r
136 #define UNICODE_LITERAL_16(a,b,c,d,e,f,g,h,i,j,k,l,m,n,o,p) \
\r
137 {xercesc::chLatin_##a, xercesc::chLatin_##b, xercesc::chLatin_##c, xercesc::chLatin_##d, xercesc::chLatin_##e, xercesc::chLatin_##f, xercesc::chLatin_##g, xercesc::chLatin_##h, xercesc::chLatin_##i, \
\r
138 xercesc::chLatin_##j, xercesc::chLatin_##k, xercesc::chLatin_##l, xercesc::chLatin_##m, xercesc::chLatin_##n, xercesc::chLatin_##o, xercesc::chLatin_##p, xercesc::chNull}
\r
139 #define UNICODE_LITERAL_17(a,b,c,d,e,f,g,h,i,j,k,l,m,n,o,p,q) \
\r
140 {xercesc::chLatin_##a, xercesc::chLatin_##b, xercesc::chLatin_##c, xercesc::chLatin_##d, xercesc::chLatin_##e, xercesc::chLatin_##f, xercesc::chLatin_##g, xercesc::chLatin_##h, xercesc::chLatin_##i, \
\r
141 xercesc::chLatin_##j, xercesc::chLatin_##k, xercesc::chLatin_##l, xercesc::chLatin_##m, xercesc::chLatin_##n, xercesc::chLatin_##o, xercesc::chLatin_##p, xercesc::chLatin_##q, xercesc::chNull}
\r
142 #define UNICODE_LITERAL_18(a,b,c,d,e,f,g,h,i,j,k,l,m,n,o,p,q,r) \
\r
143 {xercesc::chLatin_##a, xercesc::chLatin_##b, xercesc::chLatin_##c, xercesc::chLatin_##d, xercesc::chLatin_##e, xercesc::chLatin_##f, xercesc::chLatin_##g, xercesc::chLatin_##h, xercesc::chLatin_##i, \
\r
144 xercesc::chLatin_##j, xercesc::chLatin_##k, xercesc::chLatin_##l, xercesc::chLatin_##m, xercesc::chLatin_##n, xercesc::chLatin_##o, xercesc::chLatin_##p, xercesc::chLatin_##q, xercesc::chLatin_##r, xercesc::chNull}
\r
145 #define UNICODE_LITERAL_19(a,b,c,d,e,f,g,h,i,j,k,l,m,n,o,p,q,r,s) \
\r
146 {xercesc::chLatin_##a, xercesc::chLatin_##b, xercesc::chLatin_##c, xercesc::chLatin_##d, xercesc::chLatin_##e, xercesc::chLatin_##f, xercesc::chLatin_##g, xercesc::chLatin_##h, xercesc::chLatin_##i, \
\r
147 xercesc::chLatin_##j, xercesc::chLatin_##k, xercesc::chLatin_##l, xercesc::chLatin_##m, xercesc::chLatin_##n, xercesc::chLatin_##o, xercesc::chLatin_##p, xercesc::chLatin_##q, xercesc::chLatin_##r, \
\r
148 xercesc::chLatin_##s, xercesc::chNull}
\r
149 #define UNICODE_LITERAL_20(a,b,c,d,e,f,g,h,i,j,k,l,m,n,o,p,q,r,s,t) \
\r
150 {xercesc::chLatin_##a, xercesc::chLatin_##b, xercesc::chLatin_##c, xercesc::chLatin_##d, xercesc::chLatin_##e, xercesc::chLatin_##f, xercesc::chLatin_##g, xercesc::chLatin_##h, xercesc::chLatin_##i, \
\r
151 xercesc::chLatin_##j, xercesc::chLatin_##k, xercesc::chLatin_##l, xercesc::chLatin_##m, xercesc::chLatin_##n, xercesc::chLatin_##o, xercesc::chLatin_##p, xercesc::chLatin_##q, xercesc::chLatin_##r, \
\r
152 xercesc::chLatin_##s, xercesc::chLatin_##t, xercesc::chNull}
\r
153 #define UNICODE_LITERAL_21(a,b,c,d,e,f,g,h,i,j,k,l,m,n,o,p,q,r,s,t,u) \
\r
154 {xercesc::chLatin_##a, xercesc::chLatin_##b, xercesc::chLatin_##c, xercesc::chLatin_##d, xercesc::chLatin_##e, xercesc::chLatin_##f, xercesc::chLatin_##g, xercesc::chLatin_##h, xercesc::chLatin_##i, \
\r
155 xercesc::chLatin_##j, xercesc::chLatin_##k, xercesc::chLatin_##l, xercesc::chLatin_##m, xercesc::chLatin_##n, xercesc::chLatin_##o, xercesc::chLatin_##p, xercesc::chLatin_##q, xercesc::chLatin_##r, \
\r
156 xercesc::chLatin_##s, xercesc::chLatin_##t, xercesc::chLatin_##u, xercesc::chNull}
\r
157 #define UNICODE_LITERAL_22(a,b,c,d,e,f,g,h,i,j,k,l,m,n,o,p,q,r,s,t,u,v) \
\r
158 {xercesc::chLatin_##a, xercesc::chLatin_##b, xercesc::chLatin_##c, xercesc::chLatin_##d, xercesc::chLatin_##e, xercesc::chLatin_##f, xercesc::chLatin_##g, xercesc::chLatin_##h, xercesc::chLatin_##i, \
\r
159 xercesc::chLatin_##j, xercesc::chLatin_##k, xercesc::chLatin_##l, xercesc::chLatin_##m, xercesc::chLatin_##n, xercesc::chLatin_##o, xercesc::chLatin_##p, xercesc::chLatin_##q, xercesc::chLatin_##r, \
\r
160 xercesc::chLatin_##s, xercesc::chLatin_##t, xercesc::chLatin_##u, xercesc::chLatin_##v, xercesc::chNull}
\r
161 #define UNICODE_LITERAL_23(a,b,c,d,e,f,g,h,i,j,k,l,m,n,o,p,q,r,s,t,u,v,w) \
\r
162 {xercesc::chLatin_##a, xercesc::chLatin_##b, xercesc::chLatin_##c, xercesc::chLatin_##d, xercesc::chLatin_##e, xercesc::chLatin_##f, xercesc::chLatin_##g, xercesc::chLatin_##h, xercesc::chLatin_##i, \
\r
163 xercesc::chLatin_##j, xercesc::chLatin_##k, xercesc::chLatin_##l, xercesc::chLatin_##m, xercesc::chLatin_##n, xercesc::chLatin_##o, xercesc::chLatin_##p, xercesc::chLatin_##q, xercesc::chLatin_##r, \
\r
164 xercesc::chLatin_##s, xercesc::chLatin_##t, xercesc::chLatin_##u, xercesc::chLatin_##v, xercesc::chLatin_##w, xercesc::chNull}
\r
165 #define UNICODE_LITERAL_24(a,b,c,d,e,f,g,h,i,j,k,l,m,n,o,p,q,r,s,t,u,v,w,x) \
\r
166 {xercesc::chLatin_##a, xercesc::chLatin_##b, xercesc::chLatin_##c, xercesc::chLatin_##d, xercesc::chLatin_##e, xercesc::chLatin_##f, xercesc::chLatin_##g, xercesc::chLatin_##h, xercesc::chLatin_##i, \
\r
167 xercesc::chLatin_##j, xercesc::chLatin_##k, xercesc::chLatin_##l, xercesc::chLatin_##m, xercesc::chLatin_##n, xercesc::chLatin_##o, xercesc::chLatin_##p, xercesc::chLatin_##q, xercesc::chLatin_##r, \
\r
168 xercesc::chLatin_##s, xercesc::chLatin_##t, xercesc::chLatin_##u, xercesc::chLatin_##v, xercesc::chLatin_##w, xercesc::chLatin_##x, xercesc::chNull}
\r
169 #define UNICODE_LITERAL_25(a,b,c,d,e,f,g,h,i,j,k,l,m,n,o,p,q,r,s,t,u,v,w,x,y) \
\r
170 {xercesc::chLatin_##a, xercesc::chLatin_##b, xercesc::chLatin_##c, xercesc::chLatin_##d, xercesc::chLatin_##e, xercesc::chLatin_##f, xercesc::chLatin_##g, xercesc::chLatin_##h, xercesc::chLatin_##i, \
\r
171 xercesc::chLatin_##j, xercesc::chLatin_##k, xercesc::chLatin_##l, xercesc::chLatin_##m, xercesc::chLatin_##n, xercesc::chLatin_##o, xercesc::chLatin_##p, xercesc::chLatin_##q, xercesc::chLatin_##r, \
\r
172 xercesc::chLatin_##s, xercesc::chLatin_##t, xercesc::chLatin_##u, xercesc::chLatin_##v, xercesc::chLatin_##w, xercesc::chLatin_##x, xercesc::chLatin_##y, xercesc::chNull}
\r
173 #define UNICODE_LITERAL_26(a,b,c,d,e,f,g,h,i,j,k,l,m,n,o,p,q,r,s,t,u,v,w,x,y,z) \
\r
174 {xercesc::chLatin_##a, xercesc::chLatin_##b, xercesc::chLatin_##c, xercesc::chLatin_##d, xercesc::chLatin_##e, xercesc::chLatin_##f, xercesc::chLatin_##g, xercesc::chLatin_##h, xercesc::chLatin_##i, \
\r
175 xercesc::chLatin_##j, xercesc::chLatin_##k, xercesc::chLatin_##l, xercesc::chLatin_##m, xercesc::chLatin_##n, xercesc::chLatin_##o, xercesc::chLatin_##p, xercesc::chLatin_##q, xercesc::chLatin_##r, \
\r
176 xercesc::chLatin_##s, xercesc::chLatin_##t, xercesc::chLatin_##u, xercesc::chLatin_##v, xercesc::chLatin_##w, xercesc::chLatin_##x, xercesc::chLatin_##y, xercesc::chLatin_##z, xercesc::chNull}
\r
177 #define UNICODE_LITERAL_27(a,b,c,d,e,f,g,h,i,j,k,l,m,n,o,p,q,r,s,t,u,v,w,x,y,z,aa) \
\r
178 {xercesc::chLatin_##a, xercesc::chLatin_##b, xercesc::chLatin_##c, xercesc::chLatin_##d, xercesc::chLatin_##e, xercesc::chLatin_##f, xercesc::chLatin_##g, xercesc::chLatin_##h, xercesc::chLatin_##i, \
\r
179 xercesc::chLatin_##j, xercesc::chLatin_##k, xercesc::chLatin_##l, xercesc::chLatin_##m, xercesc::chLatin_##n, xercesc::chLatin_##o, xercesc::chLatin_##p, xercesc::chLatin_##q, xercesc::chLatin_##r, \
\r
180 xercesc::chLatin_##s, xercesc::chLatin_##t, xercesc::chLatin_##u, xercesc::chLatin_##v, xercesc::chLatin_##w, xercesc::chLatin_##x, xercesc::chLatin_##y, xercesc::chLatin_##z, \
\r
181 xercesc::chLatin_##aa, xercesc::chNull}
\r
182 #define UNICODE_LITERAL_28(a,b,c,d,e,f,g,h,i,j,k,l,m,n,o,p,q,r,s,t,u,v,w,x,y,z,aa,bb) \
\r
183 {xercesc::chLatin_##a, xercesc::chLatin_##b, xercesc::chLatin_##c, xercesc::chLatin_##d, xercesc::chLatin_##e, xercesc::chLatin_##f, xercesc::chLatin_##g, xercesc::chLatin_##h, xercesc::chLatin_##i, \
\r
184 xercesc::chLatin_##j, xercesc::chLatin_##k, xercesc::chLatin_##l, xercesc::chLatin_##m, xercesc::chLatin_##n, xercesc::chLatin_##o, xercesc::chLatin_##p, xercesc::chLatin_##q, xercesc::chLatin_##r, \
\r
185 xercesc::chLatin_##s, xercesc::chLatin_##t, xercesc::chLatin_##u, xercesc::chLatin_##v, xercesc::chLatin_##w, xercesc::chLatin_##x, xercesc::chLatin_##y, xercesc::chLatin_##z, \
\r
186 xercesc::chLatin_##aa, xercesc::chLatin_##bb, xercesc::chNull}
\r
187 #define UNICODE_LITERAL_29(a,b,c,d,e,f,g,h,i,j,k,l,m,n,o,p,q,r,s,t,u,v,w,x,y,z,aa,bb,cc) \
\r
188 {xercesc::chLatin_##a, xercesc::chLatin_##b, xercesc::chLatin_##c, xercesc::chLatin_##d, xercesc::chLatin_##e, xercesc::chLatin_##f, xercesc::chLatin_##g, xercesc::chLatin_##h, xercesc::chLatin_##i, \
\r
189 xercesc::chLatin_##j, xercesc::chLatin_##k, xercesc::chLatin_##l, xercesc::chLatin_##m, xercesc::chLatin_##n, xercesc::chLatin_##o, xercesc::chLatin_##p, xercesc::chLatin_##q, xercesc::chLatin_##r, \
\r
190 xercesc::chLatin_##s, xercesc::chLatin_##t, xercesc::chLatin_##u, xercesc::chLatin_##v, xercesc::chLatin_##w, xercesc::chLatin_##x, xercesc::chLatin_##y, xercesc::chLatin_##z, \
\r
191 xercesc::chLatin_##aa, xercesc::chLatin_##bb, xercesc::chLatin_##cc, xercesc::chNull}
\r
192 #define UNICODE_LITERAL_30(a,b,c,d,e,f,g,h,i,j,k,l,m,n,o,p,q,r,s,t,u,v,w,x,y,z,aa,bb,cc,dd) \
\r
193 {xercesc::chLatin_##a, xercesc::chLatin_##b, xercesc::chLatin_##c, xercesc::chLatin_##d, xercesc::chLatin_##e, xercesc::chLatin_##f, xercesc::chLatin_##g, xercesc::chLatin_##h, xercesc::chLatin_##i, \
\r
194 xercesc::chLatin_##j, xercesc::chLatin_##k, xercesc::chLatin_##l, xercesc::chLatin_##m, xercesc::chLatin_##n, xercesc::chLatin_##o, xercesc::chLatin_##p, xercesc::chLatin_##q, xercesc::chLatin_##r, \
\r
195 xercesc::chLatin_##s, xercesc::chLatin_##t, xercesc::chLatin_##u, xercesc::chLatin_##v, xercesc::chLatin_##w, xercesc::chLatin_##x, xercesc::chLatin_##y, xercesc::chLatin_##z, \
\r
196 xercesc::chLatin_##aa, xercesc::chLatin_##bb, xercesc::chLatin_##cc, xercesc::chLatin_##dd, xercesc::chNull}
\r
197 #define UNICODE_LITERAL_31(a,b,c,d,e,f,g,h,i,j,k,l,m,n,o,p,q,r,s,t,u,v,w,x,y,z,aa,bb,cc,dd,ee) \
\r
198 {xercesc::chLatin_##a, xercesc::chLatin_##b, xercesc::chLatin_##c, xercesc::chLatin_##d, xercesc::chLatin_##e, xercesc::chLatin_##f, xercesc::chLatin_##g, xercesc::chLatin_##h, xercesc::chLatin_##i, \
\r
199 xercesc::chLatin_##j, xercesc::chLatin_##k, xercesc::chLatin_##l, xercesc::chLatin_##m, xercesc::chLatin_##n, xercesc::chLatin_##o, xercesc::chLatin_##p, xercesc::chLatin_##q, xercesc::chLatin_##r, \
\r
200 xercesc::chLatin_##s, xercesc::chLatin_##t, xercesc::chLatin_##u, xercesc::chLatin_##v, xercesc::chLatin_##w, xercesc::chLatin_##x, xercesc::chLatin_##y, xercesc::chLatin_##z, \
\r
201 xercesc::chLatin_##aa, xercesc::chLatin_##bb, xercesc::chLatin_##cc, xercesc::chLatin_##dd, xercesc::chLatin_##ee, xercesc::chNull}
\r
202 #define UNICODE_LITERAL_32(a,b,c,d,e,f,g,h,i,j,k,l,m,n,o,p,q,r,s,t,u,v,w,x,y,z,aa,bb,cc,dd,ee,ff) \
\r
203 {xercesc::chLatin_##a, xercesc::chLatin_##b, xercesc::chLatin_##c, xercesc::chLatin_##d, xercesc::chLatin_##e, xercesc::chLatin_##f, xercesc::chLatin_##g, xercesc::chLatin_##h, xercesc::chLatin_##i, \
\r
204 xercesc::chLatin_##j, xercesc::chLatin_##k, xercesc::chLatin_##l, xercesc::chLatin_##m, xercesc::chLatin_##n, xercesc::chLatin_##o, xercesc::chLatin_##p, xercesc::chLatin_##q, xercesc::chLatin_##r, \
\r
205 xercesc::chLatin_##s, xercesc::chLatin_##t, xercesc::chLatin_##u, xercesc::chLatin_##v, xercesc::chLatin_##w, xercesc::chLatin_##x, xercesc::chLatin_##y, xercesc::chLatin_##z, \
\r
206 xercesc::chLatin_##aa, xercesc::chLatin_##bb, xercesc::chLatin_##cc, xercesc::chLatin_##dd, xercesc::chLatin_##ee, xercesc::chLatin_##ff, xercesc::chNull}
\r
207 #define UNICODE_LITERAL_33(a,b,c,d,e,f,g,h,i,j,k,l,m,n,o,p,q,r,s,t,u,v,w,x,y,z,aa,bb,cc,dd,ee,ff,gg) \
\r
208 {xercesc::chLatin_##a, xercesc::chLatin_##b, xercesc::chLatin_##c, xercesc::chLatin_##d, xercesc::chLatin_##e, xercesc::chLatin_##f, xercesc::chLatin_##g, xercesc::chLatin_##h, xercesc::chLatin_##i, \
\r
209 xercesc::chLatin_##j, xercesc::chLatin_##k, xercesc::chLatin_##l, xercesc::chLatin_##m, xercesc::chLatin_##n, xercesc::chLatin_##o, xercesc::chLatin_##p, xercesc::chLatin_##q, xercesc::chLatin_##r, \
\r
210 xercesc::chLatin_##s, xercesc::chLatin_##t, xercesc::chLatin_##u, xercesc::chLatin_##v, xercesc::chLatin_##w, xercesc::chLatin_##x, xercesc::chLatin_##y, xercesc::chLatin_##z, \
\r
211 xercesc::chLatin_##aa, xercesc::chLatin_##bb, xercesc::chLatin_##cc, xercesc::chLatin_##dd, xercesc::chLatin_##ee, xercesc::chLatin_##ff, xercesc::chLatin_##gg, xercesc::chNull}
\r
212 #define UNICODE_LITERAL_34(a,b,c,d,e,f,g,h,i,j,k,l,m,n,o,p,q,r,s,t,u,v,w,x,y,z,aa,bb,cc,dd,ee,ff,gg,hh) \
\r
213 {xercesc::chLatin_##a, xercesc::chLatin_##b, xercesc::chLatin_##c, xercesc::chLatin_##d, xercesc::chLatin_##e, xercesc::chLatin_##f, xercesc::chLatin_##g, xercesc::chLatin_##h, xercesc::chLatin_##i, \
\r
214 xercesc::chLatin_##j, xercesc::chLatin_##k, xercesc::chLatin_##l, xercesc::chLatin_##m, xercesc::chLatin_##n, xercesc::chLatin_##o, xercesc::chLatin_##p, xercesc::chLatin_##q, xercesc::chLatin_##r, \
\r
215 xercesc::chLatin_##s, xercesc::chLatin_##t, xercesc::chLatin_##u, xercesc::chLatin_##v, xercesc::chLatin_##w, xercesc::chLatin_##x, xercesc::chLatin_##y, xercesc::chLatin_##z, \
\r
216 xercesc::chLatin_##aa, xercesc::chLatin_##bb, xercesc::chLatin_##cc, xercesc::chLatin_##dd, xercesc::chLatin_##ee, xercesc::chLatin_##ff, xercesc::chLatin_##gg, xercesc::chLatin_##hh, xercesc::chNull}
\r
217 #endif /* DOXYGEN_SKIP */
\r
220 * Begins the declaration of an XMLObject specialization for an abstract element/type.
\r
221 * Basic boilerplate includes a protected constructor, empty virtual destructor,
\r
222 * and Unicode constants for the default associated element's name and prefix.
\r
224 * @param linkage linkage specifier for the class
\r
225 * @param cname the name of the class to declare
\r
226 * @param base the base class to derive from using public virtual inheritance
\r
227 * @param desc documentation comment for class
\r
229 #define DECL_XMLOBJECT_ABSTRACT(linkage,cname,base,desc) \
\r
230 XMLTOOLING_DOXYGEN(desc) \
\r
231 class linkage cname : public virtual base { \
\r
235 virtual ~cname() {} \
\r
236 XMLTOOLING_DOXYGEN(Element local name) \
\r
237 static const XMLCh LOCAL_NAME[]; \
\r
241 * Begins the declaration of an XMLObject specialization.
\r
242 * Basic boilerplate includes a protected constructor, empty virtual destructor,
\r
243 * and Unicode constants for the default associated element's name and prefix.
\r
245 * @param linkage linkage specifier for the class
\r
246 * @param cname the name of the class to declare
\r
247 * @param base the base class to derive from using public virtual inheritance
\r
248 * @param desc documentation comment for class
\r
250 #define BEGIN_XMLOBJECT(linkage,cname,base,desc) \
\r
251 XMLTOOLING_DOXYGEN(desc) \
\r
252 class linkage cname : public virtual base { \
\r
256 virtual ~cname() {} \
\r
257 XMLTOOLING_DOXYGEN(Type-specific clone method.) \
\r
258 virtual cname* clone##cname() const=0; \
\r
259 XMLTOOLING_DOXYGEN(Element local name) \
\r
260 static const XMLCh LOCAL_NAME[]
\r
263 * Begins the declaration of an XMLObject specialization with two base classes.
\r
264 * Basic boilerplate includes a protected constructor, empty virtual destructor,
\r
265 * and Unicode constants for the default associated element's name and prefix.
\r
267 * @param linkage linkage specifier for the class
\r
268 * @param cname the name of the class to declare
\r
269 * @param base the first base class to derive from using public virtual inheritance
\r
270 * @param base2 the second base class to derive from using public virtual inheritance
\r
271 * @param desc documentation comment for class
\r
273 #define BEGIN_XMLOBJECT2(linkage,cname,base,base2,desc) \
\r
274 XMLTOOLING_DOXYGEN(desc) \
\r
275 class linkage cname : public virtual base, public virtual base2 { \
\r
279 virtual ~cname() {} \
\r
280 XMLTOOLING_DOXYGEN(Type-specific clone method.) \
\r
281 virtual cname* clone##cname() const=0; \
\r
282 XMLTOOLING_DOXYGEN(Element local name) \
\r
283 static const XMLCh LOCAL_NAME[]
\r
286 * Begins the declaration of an XMLObject specialization with three base classes.
\r
287 * Basic boilerplate includes a protected constructor, empty virtual destructor,
\r
288 * and Unicode constants for the default associated element's name and prefix.
\r
290 * @param linkage linkage specifier for the class
\r
291 * @param cname the name of the class to declare
\r
292 * @param base the first base class to derive from using public virtual inheritance
\r
293 * @param base2 the second base class to derive from using public virtual inheritance
\r
294 * @param base3 the third base class to derive from using public virtual inheritance
\r
295 * @param desc documentation comment for class
\r
297 #define BEGIN_XMLOBJECT3(linkage,cname,base,base2,base3,desc) \
\r
298 XMLTOOLING_DOXYGEN(desc) \
\r
299 class linkage cname : public virtual base, public virtual base2, public virtual base3 { \
\r
303 virtual ~cname() {} \
\r
304 XMLTOOLING_DOXYGEN(Type-specific clone method.) \
\r
305 virtual cname* clone##cname() const=0; \
\r
306 XMLTOOLING_DOXYGEN(Element local name) \
\r
307 static const XMLCh LOCAL_NAME[]
\r
310 * Begins the declaration of an XMLObject specialization with four base classes.
\r
311 * Basic boilerplate includes a protected constructor, empty virtual destructor,
\r
312 * and Unicode constants for the default associated element's name and prefix.
\r
314 * @param linkage linkage specifier for the class
\r
315 * @param cname the name of the class to declare
\r
316 * @param base the first base class to derive from using public virtual inheritance
\r
317 * @param base2 the second base class to derive from using public virtual inheritance
\r
318 * @param base3 the third base class to derive from using public virtual inheritance
\r
319 * @param base4 the fourth base class to derive from using public virtual inheritance
\r
320 * @param desc documentation comment for class
\r
322 #define BEGIN_XMLOBJECT4(linkage,cname,base,base2,base3,base4,desc) \
\r
323 XMLTOOLING_DOXYGEN(desc) \
\r
324 class linkage cname : public virtual base, public virtual base2, public virtual base3, public virtual base4 { \
\r
328 virtual ~cname() {} \
\r
329 XMLTOOLING_DOXYGEN(Type-specific clone method.) \
\r
330 virtual cname* clone##cname() const=0; \
\r
331 XMLTOOLING_DOXYGEN(Element local name) \
\r
332 static const XMLCh LOCAL_NAME[]
\r
335 * Begins the declaration of an XMLObject specialization with five base classes.
\r
336 * Basic boilerplate includes a protected constructor, empty virtual destructor,
\r
337 * and Unicode constants for the default associated element's name and prefix.
\r
339 * @param linkage linkage specifier for the class
\r
340 * @param cname the name of the class to declare
\r
341 * @param base the first base class to derive from using public virtual inheritance
\r
342 * @param base2 the second base class to derive from using public virtual inheritance
\r
343 * @param base3 the third base class to derive from using public virtual inheritance
\r
344 * @param base4 the fourth base class to derive from using public virtual inheritance
\r
345 * @param base5 the fifth base class to derive from using public virtual inheritance
\r
346 * @param desc documentation comment for class
\r
348 #define BEGIN_XMLOBJECT5(linkage,cname,base,base2,base3,base4,base5,desc) \
\r
349 XMLTOOLING_DOXYGEN(desc) \
\r
350 class linkage cname : public virtual base, public virtual base2, public virtual base3, public virtual base4, public virtual base5 { \
\r
354 virtual ~cname() {} \
\r
355 XMLTOOLING_DOXYGEN(Type-specific clone method.) \
\r
356 virtual cname* clone##cname() const=0; \
\r
357 XMLTOOLING_DOXYGEN(Element local name) \
\r
358 static const XMLCh LOCAL_NAME[]
\r
361 * Ends the declaration of an XMLObject specialization.
\r
363 #define END_XMLOBJECT }
\r
366 * Declares a static variable holding the XMLObject's element QName.
\r
368 #define DECL_ELEMENT_QNAME \
\r
370 XMLTOOLING_DOXYGEN(Element QName) \
\r
371 static xmltooling::QName ELEMENT_QNAME
\r
374 * Declares a static variable holding the XMLObject's schema type QName.
\r
376 #define DECL_TYPE_QNAME \
\r
378 XMLTOOLING_DOXYGEN(Type QName) \
\r
379 static xmltooling::QName TYPE_QNAME
\r
382 * Implements a static variable holding an XMLObject's element QName.
\r
384 * @param cname the name of the XMLObject specialization
\r
385 * @param namespaceURI the XML namespace of the default associated element
\r
386 * @param namespacePrefix the XML namespace prefix of the default associated element
\r
388 #define IMPL_ELEMENT_QNAME(cname,namespaceURI,namespacePrefix) \
\r
389 xmltooling::QName cname::ELEMENT_QNAME(namespaceURI,cname::LOCAL_NAME,namespacePrefix)
\r
392 * Implements a static variable holding an XMLObject's schema type QName.
\r
394 * @param cname the name of the XMLObject specialization
\r
395 * @param namespaceURI the XML namespace of the default associated element
\r
396 * @param namespacePrefix the XML namespace prefix of the default associated element
\r
398 #define IMPL_TYPE_QNAME(cname,namespaceURI,namespacePrefix) \
\r
399 xmltooling::QName cname::TYPE_QNAME(namespaceURI,cname::TYPE_NAME,namespacePrefix)
\r
402 * Declares abstract set method for a typed XML attribute.
\r
403 * The get method is omitted.
\r
405 * @param proper the proper name of the attribute
\r
406 * @param upcased the upcased name of the attribute
\r
407 * @param type the attribute's data type
\r
409 #define DECL_INHERITED_XMLOBJECT_ATTRIB(proper,upcased,type) \
\r
411 XMLTOOLING_DOXYGEN(proper attribute name) \
\r
412 static const XMLCh upcased##_ATTRIB_NAME[]; \
\r
413 XMLTOOLING_DOXYGEN(Sets the proper attribute.) \
\r
414 virtual void set##proper(const type* proper)=0
\r
417 * Declares abstract get/set methods for a typed XML attribute.
\r
419 * @param proper the proper name of the attribute
\r
420 * @param upcased the upcased name of the attribute
\r
421 * @param type the attribute's data type
\r
423 #define DECL_XMLOBJECT_ATTRIB(proper,upcased,type) \
\r
425 XMLTOOLING_DOXYGEN(proper attribute name) \
\r
426 static const XMLCh upcased##_ATTRIB_NAME[]; \
\r
427 XMLTOOLING_DOXYGEN(Returns the proper attribute.) \
\r
428 virtual const type* get##proper() const=0; \
\r
429 XMLTOOLING_DOXYGEN(Sets the proper attribute.) \
\r
430 virtual void set##proper(const type* proper)=0
\r
433 * Declares abstract set method for a string XML attribute.
\r
434 * The get method is omitted.
\r
436 * @param proper the proper name of the attribute
\r
437 * @param upcased the upcased name of the attribute
\r
439 #define DECL_INHERITED_STRING_ATTRIB(proper,upcased) \
\r
440 DECL_INHERITED_XMLOBJECT_ATTRIB(proper,upcased,XMLCh)
\r
443 * Declares abstract get/set methods for a string XML attribute.
\r
445 * @param proper the proper name of the attribute
\r
446 * @param upcased the upcased name of the attribute
\r
448 #define DECL_STRING_ATTRIB(proper,upcased) \
\r
449 DECL_XMLOBJECT_ATTRIB(proper,upcased,XMLCh)
\r
452 * Declares abstract set method for a DateTime XML attribute.
\r
453 * The get method is omitted.
\r
455 * @param proper the proper name of the attribute
\r
456 * @param upcased the upcased name of the attribute
\r
458 #define DECL_INHERITED_DATETIME_ATTRIB(proper,upcased) \
\r
459 DECL_INHERITED_XMLOBJECT_ATTRIB(proper,upcased,xmltooling::DateTime); \
\r
460 XMLTOOLING_DOXYGEN(Sets the proper attribute.) \
\r
461 virtual void set##proper(time_t proper)=0; \
\r
462 XMLTOOLING_DOXYGEN(Sets the proper attribute.) \
\r
463 virtual void set##proper(const XMLCh* proper)=0
\r
466 * Declares abstract get/set methods for a DateTime XML attribute.
\r
468 * @param proper the proper name of the attribute
\r
469 * @param upcased the upcased name of the attribute
\r
471 #define DECL_DATETIME_ATTRIB(proper,upcased) \
\r
472 DECL_XMLOBJECT_ATTRIB(proper,upcased,xmltooling::DateTime); \
\r
473 XMLTOOLING_DOXYGEN(Returns the proper attribute in epoch form.) \
\r
474 virtual time_t get##proper##Epoch() const=0; \
\r
475 XMLTOOLING_DOXYGEN(Sets the proper attribute.) \
\r
476 virtual void set##proper(time_t proper)=0; \
\r
477 XMLTOOLING_DOXYGEN(Sets the proper attribute.) \
\r
478 virtual void set##proper(const XMLCh* proper)=0
\r
481 * Declares abstract set method for an integer XML attribute.
\r
482 * The get method is omitted.
\r
484 * @param proper the proper name of the attribute
\r
485 * @param upcased the upcased name of the attribute
\r
487 #define DECL_INHERITED_INTEGER_ATTRIB(proper,upcased) \
\r
489 XMLTOOLING_DOXYGEN(proper attribute name) \
\r
490 static const XMLCh upcased##_ATTRIB_NAME[]; \
\r
491 XMLTOOLING_DOXYGEN(Sets the proper attribute using a string value.) \
\r
492 virtual void set##proper(const XMLCh* proper)=0; \
\r
493 XMLTOOLING_DOXYGEN(Sets the proper attribute.) \
\r
494 virtual void set##proper(int proper)=0
\r
497 * Declares abstract get/set methods for an integer XML attribute.
\r
499 * @param proper the proper name of the attribute
\r
500 * @param upcased the upcased name of the attribute
\r
502 #define DECL_INTEGER_ATTRIB(proper,upcased) \
\r
504 XMLTOOLING_DOXYGEN(proper attribute name) \
\r
505 static const XMLCh upcased##_ATTRIB_NAME[]; \
\r
506 XMLTOOLING_DOXYGEN(Returns the proper attribute after a NULL indicator.) \
\r
507 virtual std::pair<bool,int> get##proper() const=0; \
\r
508 XMLTOOLING_DOXYGEN(Sets the proper attribute using a string value.) \
\r
509 virtual void set##proper(const XMLCh* proper)=0; \
\r
510 XMLTOOLING_DOXYGEN(Sets the proper attribute.) \
\r
511 virtual void set##proper(int proper)=0
\r
514 * Declares abstract get/set methods for a boolean XML attribute.
\r
516 * @param proper the proper name of the attribute
\r
517 * @param upcased the upcased name of the attribute
\r
518 * @param def the default/presumed value, if no explicit value has been set
\r
520 #define DECL_BOOLEAN_ATTRIB(proper,upcased,def) \
\r
522 XMLTOOLING_DOXYGEN(proper attribute name) \
\r
523 static const XMLCh upcased##_ATTRIB_NAME[]; \
\r
524 XMLTOOLING_DOXYGEN(Returns the proper attribute or def if not set.) \
\r
525 bool proper() const { \
\r
526 switch (get##proper()) { \
\r
527 case xmlconstants::XML_BOOL_TRUE: \
\r
528 case xmlconstants::XML_BOOL_ONE: \
\r
530 case xmlconstants::XML_BOOL_FALSE: \
\r
531 case xmlconstants::XML_BOOL_ZERO: \
\r
537 XMLTOOLING_DOXYGEN(Returns the proper attribute as an explicit enumerated value.) \
\r
538 virtual xmlconstants::xmltooling_bool_t get##proper() const=0; \
\r
539 XMLTOOLING_DOXYGEN(Sets the proper attribute using an enumerated value.) \
\r
540 virtual void proper(xmlconstants::xmltooling_bool_t value)=0; \
\r
541 XMLTOOLING_DOXYGEN(Sets the proper attribute.) \
\r
542 void proper(bool value) { \
\r
543 proper(value ? xmlconstants::XML_BOOL_ONE : xmlconstants::XML_BOOL_ZERO); \
\r
545 XMLTOOLING_DOXYGEN(Sets the proper attribute using a string constant.) \
\r
546 void set##proper(const XMLCh* value) { \
\r
548 switch (*value) { \
\r
549 case xercesc::chLatin_t: \
\r
550 proper(xmlconstants::XML_BOOL_TRUE); \
\r
552 case xercesc::chLatin_f: \
\r
553 proper(xmlconstants::XML_BOOL_FALSE); \
\r
555 case xercesc::chDigit_1: \
\r
556 proper(xmlconstants::XML_BOOL_ONE); \
\r
558 case xercesc::chDigit_0: \
\r
559 proper(xmlconstants::XML_BOOL_ZERO); \
\r
562 proper(xmlconstants::XML_BOOL_NULL); \
\r
566 proper(xmlconstants::XML_BOOL_NULL); \
\r
570 * Implements get/set methods and a private member for a typed XML attribute.
\r
572 * @param proper the proper name of the attribute
\r
573 * @param type the attribute's data type
\r
575 #define IMPL_XMLOBJECT_ATTRIB(proper,type) \
\r
577 type* m_##proper; \
\r
579 const type* get##proper() const { \
\r
580 return m_##proper; \
\r
582 void set##proper(const type* proper) { \
\r
583 m_##proper = prepareForAssignment(m_##proper,proper); \
\r
587 * Implements get/set methods and a private member for a string XML attribute.
\r
589 * @param proper the proper name of the attribute
\r
591 #define IMPL_STRING_ATTRIB(proper) \
\r
592 IMPL_XMLOBJECT_ATTRIB(proper,XMLCh)
\r
595 * Implements get/set methods and a private member for a string XML attribute,
\r
596 * plus a getXMLID override.
\r
598 * @param proper the proper name of the attribute
\r
600 #define IMPL_ID_ATTRIB(proper) \
\r
601 IMPL_XMLOBJECT_ATTRIB(proper,XMLCh) \
\r
602 const XMLCh* getXMLID() const { \
\r
603 return m_##proper; \
\r
607 * Implements get/set methods and a private member for a DateTime XML attribute.
\r
609 * @param proper the proper name of the attribute
\r
610 * @param fallback epoch to return when attribute is NULL
\r
612 #define IMPL_DATETIME_ATTRIB(proper,fallback) \
\r
613 IMPL_DATETIME_ATTRIB_EX(proper,fallback,false)
\r
616 * Implements get/set methods and a private member for a duration-valued DateTime XML attribute.
\r
618 * @param proper the proper name of the attribute
\r
619 * @param fallback epoch to return when attribute is NULL
\r
621 #define IMPL_DURATION_ATTRIB(proper,fallback) \
\r
622 IMPL_DATETIME_ATTRIB_EX(proper,fallback,true)
\r
625 * Implements get/set methods and a private member for a DateTime XML attribute.
\r
627 * @param proper the proper name of the attribute
\r
628 * @param fallback epoch to return when attribute is NULL
\r
629 * @param duration true iff the attribute should be handled as a duration
\r
631 #define IMPL_DATETIME_ATTRIB_EX(proper,fallback,duration) \
\r
633 DateTime* m_##proper; \
\r
634 time_t m_##proper##Epoch; \
\r
636 const DateTime* get##proper() const { \
\r
637 return m_##proper; \
\r
639 time_t get##proper##Epoch() const { \
\r
640 return m_##proper ? m_##proper##Epoch : fallback; \
\r
642 void set##proper(const DateTime* proper) { \
\r
643 m_##proper = prepareForAssignment(m_##proper,proper); \
\r
645 m_##proper##Epoch=m_##proper->getEpoch(duration); \
\r
647 void set##proper(time_t proper) { \
\r
648 m_##proper = prepareForAssignment(m_##proper,proper,duration); \
\r
649 m_##proper##Epoch = proper; \
\r
651 void set##proper(const XMLCh* proper) { \
\r
652 m_##proper = prepareForAssignment(m_##proper,proper,duration); \
\r
654 m_##proper##Epoch=m_##proper->getEpoch(duration); \
\r
658 * Implements get/set methods and a private member for an integer XML attribute.
\r
660 * @param proper the proper name of the attribute
\r
662 #define IMPL_INTEGER_ATTRIB(proper) \
\r
664 XMLCh* m_##proper; \
\r
666 pair<bool,int> get##proper() const { \
\r
667 return make_pair((m_##proper!=NULL),(m_##proper!=NULL ? xercesc::XMLString::parseInt(m_##proper): 0)); \
\r
669 void set##proper(const XMLCh* proper) { \
\r
670 m_##proper = prepareForAssignment(m_##proper,proper); \
\r
672 void set##proper(int proper) { \
\r
673 char buf##proper[64]; \
\r
674 sprintf(buf##proper,"%d",proper); \
\r
675 auto_ptr_XMLCh wide##proper(buf##proper); \
\r
676 set##proper(wide##proper.get()); \
\r
680 * Implements get/set methods and a private member for a boolean XML attribute.
\r
682 * @param proper the proper name of the attribute
\r
684 #define IMPL_BOOLEAN_ATTRIB(proper) \
\r
686 xmlconstants::xmltooling_bool_t m_##proper; \
\r
688 xmlconstants::xmltooling_bool_t get##proper() const { \
\r
689 return m_##proper; \
\r
691 void proper(xmlconstants::xmltooling_bool_t value) { \
\r
692 if (m_##proper != value) { \
\r
693 releaseThisandParentDOM(); \
\r
694 m_##proper = value; \
\r
699 * Implements get/set methods and a private member for a typed, qualified XML attribute.
\r
701 * @param proper the proper name of the attribute
\r
702 * @param type the attribute's data type
\r
704 #define IMPL_XMLOBJECT_FOREIGN_ATTRIB(proper,type) \
\r
706 XMLCh* m_##proper##Prefix; \
\r
707 type* m_##proper; \
\r
709 const type* get##proper() const { \
\r
710 return m_##proper; \
\r
712 void set##proper(const type* proper) { \
\r
713 m_##proper = prepareForAssignment(m_##proper,proper); \
\r
714 XMLString::release(&m_##proper##Prefix); \
\r
715 m_##proper##Prefix = NULL; \
\r
719 * Declares abstract set method for a typed XML child object in a foreign namespace.
\r
720 * The get method is omitted.
\r
722 * @param proper the proper name of the child type
\r
723 * @param ns the C++ namespace for the type
\r
725 #define DECL_INHERITED_TYPED_FOREIGN_CHILD(proper,ns) \
\r
727 XMLTOOLING_DOXYGEN(Sets the proper child.) \
\r
728 virtual void set##proper(ns::proper* child)=0
\r
731 * Declares abstract get/set methods for a typed XML child object in a foreign namespace.
\r
733 * @param proper the proper name of the child type
\r
734 * @param ns the C++ namespace for the type
\r
736 #define DECL_TYPED_FOREIGN_CHILD(proper,ns) \
\r
738 XMLTOOLING_DOXYGEN(Returns the proper child.) \
\r
739 virtual ns::proper* get##proper() const=0; \
\r
740 XMLTOOLING_DOXYGEN(Sets the proper child.) \
\r
741 virtual void set##proper(ns::proper* child)=0
\r
744 * Declares abstract set method for a typed XML child object.
\r
745 * The get method is omitted.
\r
747 * @param proper the proper name of the child type
\r
749 #define DECL_INHERITED_TYPED_CHILD(proper) \
\r
751 XMLTOOLING_DOXYGEN(Sets the proper child.) \
\r
752 virtual void set##proper(proper* child)=0
\r
755 * Declares abstract get/set methods for a typed XML child object.
\r
757 * @param proper the proper name of the child type
\r
759 #define DECL_TYPED_CHILD(proper) \
\r
761 XMLTOOLING_DOXYGEN(Returns the proper child.) \
\r
762 virtual proper* get##proper() const=0; \
\r
763 XMLTOOLING_DOXYGEN(Sets the proper child.) \
\r
764 virtual void set##proper(proper* child)=0
\r
767 * Declares abstract get/set methods for a generic XML child object.
\r
769 * @param proper the proper name of the child
\r
771 #define DECL_XMLOBJECT_CHILD(proper) \
\r
773 XMLTOOLING_DOXYGEN(Returns the proper child.) \
\r
774 virtual xmltooling::XMLObject* get##proper() const=0; \
\r
775 XMLTOOLING_DOXYGEN(Sets the proper child.) \
\r
776 virtual void set##proper(xmltooling::XMLObject* child)=0
\r
780 * Implements get/set methods and a private list iterator member for a typed XML child object.
\r
782 * @param proper the proper name of the child type
\r
784 #define IMPL_TYPED_CHILD(proper) \
\r
786 proper* m_##proper; \
\r
787 std::list<xmltooling::XMLObject*>::iterator m_pos_##proper; \
\r
789 proper* get##proper() const { \
\r
790 return m_##proper; \
\r
792 void set##proper(proper* child) { \
\r
793 prepareForAssignment(m_##proper,child); \
\r
794 *m_pos_##proper = m_##proper = child; \
\r
798 * Implements get/set methods and a private list iterator member for
\r
799 * a typed XML child object in a foreign namespace
\r
801 * @param proper the proper name of the child type
\r
802 * @param ns the C++ namespace for the type
\r
804 #define IMPL_TYPED_FOREIGN_CHILD(proper,ns) \
\r
806 ns::proper* m_##proper; \
\r
807 std::list<xmltooling::XMLObject*>::iterator m_pos_##proper; \
\r
809 ns::proper* get##proper() const { \
\r
810 return m_##proper; \
\r
812 void set##proper(ns::proper* child) { \
\r
813 prepareForAssignment(m_##proper,child); \
\r
814 *m_pos_##proper = m_##proper = child; \
\r
818 * Implements get/set methods and a private list iterator member for a generic XML child object.
\r
820 * @param proper the proper name of the child
\r
822 #define IMPL_XMLOBJECT_CHILD(proper) \
\r
824 xmltooling::XMLObject* m_##proper; \
\r
825 std::list<xmltooling::XMLObject*>::iterator m_pos_##proper; \
\r
827 xmltooling::XMLObject* get##proper() const { \
\r
828 return m_##proper; \
\r
830 void set##proper(xmltooling::XMLObject* child) { \
\r
831 prepareForAssignment(m_##proper,child); \
\r
832 *m_pos_##proper = m_##proper = child; \
\r
836 * Declares abstract get/set methods for a typed XML child collection.
\r
838 * @param proper the proper name of the child type
\r
840 #define DECL_TYPED_CHILDREN(proper) \
\r
842 XMLTOOLING_DOXYGEN(Returns modifiable proper collection.) \
\r
843 virtual VectorOf(proper) get##proper##s()=0; \
\r
844 XMLTOOLING_DOXYGEN(Returns reference to immutable proper collection.) \
\r
845 virtual const std::vector<proper*>& get##proper##s() const=0
\r
848 * Declares abstract get/set methods for a typed XML child collection in a foreign namespace.
\r
850 * @param proper the proper name of the child type
\r
851 * @param ns the C++ namespace for the type
\r
853 #define DECL_TYPED_FOREIGN_CHILDREN(proper,ns) \
\r
855 XMLTOOLING_DOXYGEN(Returns modifiable proper collection.) \
\r
856 virtual VectorOf(ns::proper) get##proper##s()=0; \
\r
857 XMLTOOLING_DOXYGEN(Returns reference to immutable proper collection.) \
\r
858 virtual const std::vector<ns::proper*>& get##proper##s() const=0
\r
861 * Declares abstract get/set methods for a generic XML child collection.
\r
863 * @param proper the proper name of the child
\r
865 #define DECL_XMLOBJECT_CHILDREN(proper) \
\r
867 XMLTOOLING_DOXYGEN(Returns modifiable proper collection.) \
\r
868 virtual VectorOf(xmltooling::XMLObject) get##proper##s()=0; \
\r
869 XMLTOOLING_DOXYGEN(Returns reference to immutable proper collection.) \
\r
870 virtual const std::vector<xmltooling::XMLObject*>& get##proper##s() const=0
\r
873 * Implements get method and a private vector member for a typed XML child collection.
\r
875 * @param proper the proper name of the child type
\r
876 * @param fence insertion fence for new objects of the child collection in backing list
\r
878 #define IMPL_TYPED_CHILDREN(proper,fence) \
\r
880 std::vector<proper*> m_##proper##s; \
\r
882 VectorOf(proper) get##proper##s() { \
\r
883 return VectorOf(proper)(this, m_##proper##s, &m_children, fence); \
\r
885 const std::vector<proper*>& get##proper##s() const { \
\r
886 return m_##proper##s; \
\r
890 * Implements get method and a private vector member for a typed XML child collection
\r
891 * in a foreign namespace.
\r
893 * @param proper the proper name of the child type
\r
894 * @param ns the C++ namespace for the type
\r
895 * @param fence insertion fence for new objects of the child collection in backing list
\r
897 #define IMPL_TYPED_FOREIGN_CHILDREN(proper,ns,fence) \
\r
899 std::vector<ns::proper*> m_##proper##s; \
\r
901 VectorOf(ns::proper) get##proper##s() { \
\r
902 return VectorOf(ns::proper)(this, m_##proper##s, &m_children, fence); \
\r
904 const std::vector<ns::proper*>& get##proper##s() const { \
\r
905 return m_##proper##s; \
\r
909 * Implements get method and a private vector member for a generic XML child collection.
\r
911 * @param proper the proper name of the child
\r
912 * @param fence insertion fence for new objects of the child collection in backing list
\r
914 #define IMPL_XMLOBJECT_CHILDREN(proper,fence) \
\r
916 std::vector<xmltooling::XMLObject*> m_##proper##s; \
\r
918 VectorOf(xmltooling::XMLObject) get##proper##s() { \
\r
919 return VectorOf(xmltooling::XMLObject)(this, m_##proper##s, &m_children, fence); \
\r
921 const std::vector<xmltooling::XMLObject*>& get##proper##s() const { \
\r
922 return m_##proper##s; \
\r
926 * Implements marshalling for a string attribute
\r
928 * @param proper the proper name of the attribute
\r
929 * @param ucase the upcased name of the attribute
\r
930 * @param namespaceURI the XML namespace of the attribute
\r
932 #define MARSHALL_STRING_ATTRIB(proper,ucase,namespaceURI) \
\r
933 if (m_##proper && *m_##proper) { \
\r
934 domElement->setAttributeNS(namespaceURI, ucase##_ATTRIB_NAME, m_##proper); \
\r
938 * Implements marshalling for a DateTime attribute
\r
940 * @param proper the proper name of the attribute
\r
941 * @param ucase the upcased name of the attribute
\r
942 * @param namespaceURI the XML namespace of the attribute
\r
944 #define MARSHALL_DATETIME_ATTRIB(proper,ucase,namespaceURI) \
\r
945 if (m_##proper) { \
\r
946 domElement->setAttributeNS(namespaceURI, ucase##_ATTRIB_NAME, m_##proper->getRawData()); \
\r
950 * Implements marshalling for an integer attribute
\r
952 * @param proper the proper name of the attribute
\r
953 * @param ucase the upcased name of the attribute
\r
954 * @param namespaceURI the XML namespace of the attribute
\r
956 #define MARSHALL_INTEGER_ATTRIB(proper,ucase,namespaceURI) \
\r
957 if (m_##proper && *m_##proper) { \
\r
958 domElement->setAttributeNS(namespaceURI, ucase##_ATTRIB_NAME, m_##proper); \
\r
962 * Implements marshalling for a boolean attribute
\r
964 * @param proper the proper name of the attribute
\r
965 * @param ucase the upcased name of the attribute
\r
966 * @param namespaceURI the XML namespace of the attribute
\r
968 #define MARSHALL_BOOLEAN_ATTRIB(proper,ucase,namespaceURI) \
\r
969 switch (m_##proper) { \
\r
970 case xmlconstants::XML_BOOL_TRUE: \
\r
971 domElement->setAttributeNS(namespaceURI, ucase##_ATTRIB_NAME, xmlconstants::XML_TRUE); \
\r
973 case xmlconstants::XML_BOOL_ONE: \
\r
974 domElement->setAttributeNS(namespaceURI, ucase##_ATTRIB_NAME, xmlconstants::XML_ONE); \
\r
976 case xmlconstants::XML_BOOL_FALSE: \
\r
977 domElement->setAttributeNS(namespaceURI, ucase##_ATTRIB_NAME, xmlconstants::XML_FALSE); \
\r
979 case xmlconstants::XML_BOOL_ZERO: \
\r
980 domElement->setAttributeNS(namespaceURI, ucase##_ATTRIB_NAME, xmlconstants::XML_ZERO); \
\r
982 case xmlconstants::XML_BOOL_NULL: \
\r
987 * Implements marshalling for a QName attribute
\r
989 * @param proper the proper name of the attribute
\r
990 * @param ucase the upcased name of the attribute
\r
991 * @param namespaceURI the XML namespace of the attribute
\r
993 #define MARSHALL_QNAME_ATTRIB(proper,ucase,namespaceURI) \
\r
994 if (m_##proper) { \
\r
995 auto_ptr_XMLCh qstr(m_##proper->toString().c_str()); \
\r
996 domElement->setAttributeNS(namespaceURI, ucase##_ATTRIB_NAME, qstr.get()); \
\r
999 #ifdef XMLTOOLING_XERCESC_BOOLSETIDATTRIBUTE
\r
1001 * Implements marshalling for an ID attribute
\r
1003 * @param proper the proper name of the attribute
\r
1004 * @param ucase the upcased name of the attribute
\r
1005 * @param namespaceURI the XML namespace of the attribute
\r
1007 # define MARSHALL_ID_ATTRIB(proper,ucase,namespaceURI) \
\r
1008 if (m_##proper && *m_##proper) { \
\r
1009 domElement->setAttributeNS(namespaceURI, ucase##_ATTRIB_NAME, m_##proper); \
\r
1010 domElement->setIdAttributeNS(namespaceURI, ucase##_ATTRIB_NAME, true); \
\r
1014 * Implements marshalling for an ID attribute
\r
1016 * @param proper the proper name of the attribute
\r
1017 * @param ucase the upcased name of the attribute
\r
1018 * @param namespaceURI the XML namespace of the attribute
\r
1020 # define MARSHALL_ID_ATTRIB(proper,ucase,namespaceURI) \
\r
1021 if (m_##proper && *m_##proper) { \
\r
1022 domElement->setAttributeNS(namespaceURI, ucase##_ATTRIB_NAME, m_##proper); \
\r
1023 domElement->setIdAttributeNS(namespaceURI, ucase##_ATTRIB_NAME); \
\r
1028 * Implements unmarshalling process branch for a string attribute
\r
1030 * @param proper the proper name of the attribute
\r
1031 * @param ucase the upcased name of the attribute
\r
1032 * @param namespaceURI the XML namespace of the attribute
\r
1034 #define PROC_STRING_ATTRIB(proper,ucase,namespaceURI) \
\r
1035 if (xmltooling::XMLHelper::isNodeNamed(attribute, namespaceURI, ucase##_ATTRIB_NAME)) { \
\r
1036 set##proper(attribute->getValue()); \
\r
1040 #ifdef XMLTOOLING_XERCESC_BOOLSETIDATTRIBUTE
\r
1042 * Implements unmarshalling process branch for an ID attribute
\r
1044 * @param proper the proper name of the attribute
\r
1045 * @param ucase the upcased name of the attribute
\r
1046 * @param namespaceURI the XML namespace of the attribute
\r
1048 # define PROC_ID_ATTRIB(proper,ucase,namespaceURI) \
\r
1049 if (xmltooling::XMLHelper::isNodeNamed(attribute, namespaceURI, ucase##_ATTRIB_NAME)) { \
\r
1050 set##proper(attribute->getValue()); \
\r
1051 attribute->getOwnerElement()->setIdAttributeNode(attribute, true); \
\r
1056 * Implements unmarshalling process branch for an ID attribute
\r
1058 * @param proper the proper name of the attribute
\r
1059 * @param ucase the upcased name of the attribute
\r
1060 * @param namespaceURI the XML namespace of the attribute
\r
1062 # define PROC_ID_ATTRIB(proper,ucase,namespaceURI) \
\r
1063 if (xmltooling::XMLHelper::isNodeNamed(attribute, namespaceURI, ucase##_ATTRIB_NAME)) { \
\r
1064 set##proper(attribute->getValue()); \
\r
1065 attribute->getOwnerElement()->setIdAttributeNode(attribute); \
\r
1071 * Implements unmarshalling process branch for a DateTime attribute
\r
1073 * @param proper the proper name of the attribute
\r
1074 * @param ucase the upcased name of the attribute
\r
1075 * @param namespaceURI the XML namespace of the attribute
\r
1077 #define PROC_DATETIME_ATTRIB(proper,ucase,namespaceURI) \
\r
1078 PROC_STRING_ATTRIB(proper,ucase,namespaceURI)
\r
1081 * Implements unmarshalling process branch for a DateTime attribute
\r
1083 * @param proper the proper name of the attribute
\r
1084 * @param ucase the upcased name of the attribute
\r
1085 * @param namespaceURI the XML namespace of the attribute
\r
1087 #define PROC_QNAME_ATTRIB(proper,ucase,namespaceURI) \
\r
1088 if (xmltooling::XMLHelper::isNodeNamed(attribute, namespaceURI, ucase##_ATTRIB_NAME)) { \
\r
1089 set##proper(XMLHelper::getAttributeValueAsQName(attribute)); \
\r
1094 * Implements unmarshalling process branch for an integer attribute
\r
1096 * @param proper the proper name of the attribute
\r
1097 * @param ucase the upcased name of the attribute
\r
1098 * @param namespaceURI the XML namespace of the attribute
\r
1100 #define PROC_INTEGER_ATTRIB(proper,ucase,namespaceURI) \
\r
1101 PROC_STRING_ATTRIB(proper,ucase,namespaceURI)
\r
1104 * Implements unmarshalling process branch for a boolean attribute
\r
1106 * @param proper the proper name of the attribute
\r
1107 * @param ucase the upcased name of the attribute
\r
1108 * @param namespaceURI the XML namespace of the attribute
\r
1110 #define PROC_BOOLEAN_ATTRIB(proper,ucase,namespaceURI) \
\r
1111 PROC_STRING_ATTRIB(proper,ucase,namespaceURI)
\r
1114 * Implements unmarshalling process branch for typed child collection element
\r
1116 * @param proper the proper name of the child type
\r
1117 * @param namespaceURI the XML namespace of the child element
\r
1118 * @param force bypass use of hint and just cast down to check child
\r
1120 #define PROC_TYPED_CHILDREN(proper,namespaceURI,force) \
\r
1121 if (force || xmltooling::XMLHelper::isNodeNamed(root,namespaceURI,proper::LOCAL_NAME)) { \
\r
1122 proper* typesafe=dynamic_cast<proper*>(childXMLObject); \
\r
1124 get##proper##s().push_back(typesafe); \
\r
1130 * Implements unmarshalling process branch for typed child collection element
\r
1131 * in a foreign namespace.
\r
1133 * @param proper the proper name of the child type
\r
1134 * @param ns the C++ namespace for the type
\r
1135 * @param namespaceURI the XML namespace of the child element
\r
1136 * @param force bypass use of hint and just cast down to check child
\r
1138 #define PROC_TYPED_FOREIGN_CHILDREN(proper,ns,namespaceURI,force) \
\r
1139 if (force || xmltooling::XMLHelper::isNodeNamed(root,namespaceURI,ns::proper::LOCAL_NAME)) { \
\r
1140 ns::proper* typesafe=dynamic_cast<ns::proper*>(childXMLObject); \
\r
1142 get##proper##s().push_back(typesafe); \
\r
1148 * Implements unmarshalling process branch for typed child singleton element
\r
1150 * @param proper the proper name of the child type
\r
1151 * @param namespaceURI the XML namespace of the child element
\r
1152 * @param force bypass use of hint and just cast down to check child
\r
1154 #define PROC_TYPED_CHILD(proper,namespaceURI,force) \
\r
1155 if (force || xmltooling::XMLHelper::isNodeNamed(root,namespaceURI,proper::LOCAL_NAME)) { \
\r
1156 proper* typesafe=dynamic_cast<proper*>(childXMLObject); \
\r
1157 if (typesafe && !m_##proper) { \
\r
1158 typesafe->setParent(this); \
\r
1159 *m_pos_##proper = m_##proper = typesafe; \
\r
1165 * Implements unmarshalling process branch for typed child singleton element
\r
1166 * in a foreign namespace.
\r
1168 * @param proper the proper name of the child type
\r
1169 * @param ns the C++ namespace for the type
\r
1170 * @param namespaceURI the XML namespace of the child element
\r
1171 * @param force bypass use of hint and just cast down to check child
\r
1173 #define PROC_TYPED_FOREIGN_CHILD(proper,ns,namespaceURI,force) \
\r
1174 if (force || xmltooling::XMLHelper::isNodeNamed(root,namespaceURI,ns::proper::LOCAL_NAME)) { \
\r
1175 ns::proper* typesafe=dynamic_cast<ns::proper*>(childXMLObject); \
\r
1176 if (typesafe && !m_##proper) { \
\r
1177 typesafe->setParent(this); \
\r
1178 *m_pos_##proper = m_##proper = typesafe; \
\r
1184 * Implements unmarshalling process branch for a generic child singleton element
\r
1186 * @param proper the proper name of the child type
\r
1187 * @param namespaceURI the XML namespace of the child element
\r
1189 #define PROC_XMLOBJECT_CHILD(proper,namespaceURI) \
\r
1190 if (xmltooling::XMLHelper::isNodeNamed(root,namespaceURI,proper::LOCAL_NAME)) { \
\r
1191 if (!m_##proper) { \
\r
1192 childXMLObject->setParent(this); \
\r
1193 *m_pos_##proper = m_##proper = childXMLObject; \
\r
1199 * Declares aliased get/set methods for named XML element simple content.
\r
1201 * @param proper the proper name to label the element's content
\r
1203 #define DECL_SIMPLE_CONTENT(proper) \
\r
1204 XMLTOOLING_DOXYGEN(Returns proper.) \
\r
1205 const XMLCh* get##proper() const { \
\r
1206 return getTextContent(); \
\r
1208 XMLTOOLING_DOXYGEN(Sets or clears proper.) \
\r
1209 void set##proper(const XMLCh* proper) { \
\r
1210 setTextContent(proper); \
\r
1214 * Declares aliased get/set methods for named integer XML element content.
\r
1216 * @param proper the proper name to label the element's content
\r
1218 #define DECL_INTEGER_CONTENT(proper) \
\r
1219 XMLTOOLING_DOXYGEN(Returns proper in integer form after a NULL indicator.) \
\r
1220 std::pair<bool,int> get##proper() const { \
\r
1221 return std::make_pair((getTextContent()!=NULL), (getTextContent()!=NULL ? xercesc::XMLString::parseInt(getTextContent()) : 0)); \
\r
1223 XMLTOOLING_DOXYGEN(Sets proper.) \
\r
1224 void set##proper(int proper) { \
\r
1226 sprintf(buf,"%d",proper); \
\r
1227 xmltooling::auto_ptr_XMLCh widebuf(buf); \
\r
1228 setTextContent(widebuf.get()); \
\r
1230 XMLTOOLING_DOXYGEN(Sets or clears proper.) \
\r
1231 void set##proper(const XMLCh* proper) { \
\r
1232 setTextContent(proper); \
\r
1236 * Implements cloning methods for an XMLObject specialization implementation class.
\r
1238 * @param cname the name of the XMLObject specialization
\r
1240 #define IMPL_XMLOBJECT_CLONE(cname) \
\r
1241 cname* clone##cname() const { \
\r
1242 return dynamic_cast<cname*>(clone()); \
\r
1244 xmltooling::XMLObject* clone() const { \
\r
1245 std::auto_ptr<xmltooling::XMLObject> domClone(xmltooling::AbstractDOMCachingXMLObject::clone()); \
\r
1246 cname##Impl* ret=dynamic_cast<cname##Impl*>(domClone.get()); \
\r
1248 domClone.release(); \
\r
1251 return new cname##Impl(*this); \
\r
1255 * Declares an XMLObject specialization with a simple content model and type,
\r
1256 * handling it as string data.
\r
1258 * @param linkage linkage specifier for the class
\r
1259 * @param cname the name of the XMLObject specialization
\r
1260 * @param proper the proper name to label the element's content
\r
1261 * @param desc documentation for class
\r
1263 #define DECL_XMLOBJECT_SIMPLE(linkage,cname,proper,desc) \
\r
1264 BEGIN_XMLOBJECT(linkage,cname,xmltooling::XMLObject,desc); \
\r
1265 DECL_SIMPLE_CONTENT(proper); \
\r
1269 * Declares and defines an implementation class for an XMLObject with
\r
1270 * a simple content model and type, handling it as string data.
\r
1272 * @param linkage linkage specifier for the class
\r
1273 * @param cname the name of the XMLObject specialization
\r
1275 #define DECL_XMLOBJECTIMPL_SIMPLE(linkage,cname) \
\r
1276 class linkage cname##Impl \
\r
1277 : public virtual cname, \
\r
1278 public xmltooling::AbstractSimpleElement, \
\r
1279 public xmltooling::AbstractDOMCachingXMLObject, \
\r
1280 public xmltooling::AbstractXMLObjectMarshaller, \
\r
1281 public xmltooling::AbstractXMLObjectUnmarshaller \
\r
1284 virtual ~cname##Impl() {} \
\r
1285 cname##Impl(const XMLCh* nsURI, const XMLCh* localName, const XMLCh* prefix, const xmltooling::QName* schemaType) \
\r
1286 : xmltooling::AbstractXMLObject(nsURI, localName, prefix, schemaType) { \
\r
1288 cname##Impl(const cname##Impl& src) \
\r
1289 : xmltooling::AbstractXMLObject(src), \
\r
1290 xmltooling::AbstractSimpleElement(src), \
\r
1291 xmltooling::AbstractDOMCachingXMLObject(src) {} \
\r
1292 IMPL_XMLOBJECT_CLONE(cname) \
\r
1295 #ifdef HAVE_COVARIANT_RETURNS
\r
1298 * Begins the declaration of an XMLObjectBuilder specialization.
\r
1299 * Basic boilerplate includes an empty virtual destructor, and
\r
1300 * a default builder that defaults the element name.
\r
1302 * @param linkage linkage specifier for the class
\r
1303 * @param cname the name of the XMLObject specialization
\r
1304 * @param namespaceURI the XML namespace of the default associated element
\r
1305 * @param namespacePrefix the XML namespace prefix of the default associated element
\r
1307 #define BEGIN_XMLOBJECTBUILDER(linkage,cname,namespaceURI,namespacePrefix) \
\r
1308 XMLTOOLING_DOXYGEN(Builder for cname objects.) \
\r
1309 class linkage cname##Builder : public xmltooling::ConcreteXMLObjectBuilder { \
\r
1311 virtual ~cname##Builder() {} \
\r
1312 XMLTOOLING_DOXYGEN(Default builder.) \
\r
1313 virtual cname* buildObject() const { \
\r
1314 return buildObject(namespaceURI,cname::LOCAL_NAME,namespacePrefix); \
\r
1316 XMLTOOLING_DOXYGEN(Builder that allows element/type override.) \
\r
1317 virtual cname* buildObject( \
\r
1318 const XMLCh* nsURI, const XMLCh* localName, const XMLCh* prefix=NULL, const xmltooling::QName* schemaType=NULL \
\r
1322 * Ends the declaration of an XMLObjectBuilder specialization.
\r
1324 #define END_XMLOBJECTBUILDER }
\r
1327 * Declares a generic XMLObjectBuilder specialization.
\r
1329 * @param linkage linkage specifier for the class
\r
1330 * @param cname the name of the XMLObject specialization
\r
1331 * @param namespaceURI the XML namespace of the default associated element
\r
1332 * @param namespacePrefix the XML namespace prefix of the default associated element
\r
1334 #define DECL_XMLOBJECTBUILDER(linkage,cname,namespaceURI,namespacePrefix) \
\r
1335 BEGIN_XMLOBJECTBUILDER(linkage,cname,namespaceURI,namespacePrefix); \
\r
1336 XMLTOOLING_DOXYGEN(Singleton builder.) \
\r
1337 static cname* build##cname() { \
\r
1338 const cname##Builder* b = dynamic_cast<const cname##Builder*>( \
\r
1339 XMLObjectBuilder::getBuilder(xmltooling::QName(namespaceURI,cname::LOCAL_NAME)) \
\r
1342 return b->buildObject(); \
\r
1343 throw xmltooling::XMLObjectException("Unable to obtain typed builder for "#cname"."); \
\r
1345 END_XMLOBJECTBUILDER
\r
1348 * Implements the standard XMLObjectBuilder specialization function.
\r
1350 * @param cname the name of the XMLObject specialization
\r
1352 #define IMPL_XMLOBJECTBUILDER(cname) \
\r
1353 cname* cname##Builder::buildObject( \
\r
1354 const XMLCh* nsURI, const XMLCh* localName, const XMLCh* prefix, const xmltooling::QName* schemaType \
\r
1357 return new cname##Impl(nsURI,localName,prefix,schemaType); \
\r
1360 #else /* !HAVE_COVARIANT_RETURNS */
\r
1363 * Begins the declaration of an XMLObjectBuilder specialization.
\r
1364 * Basic boilerplate includes an empty virtual destructor, and
\r
1365 * a default builder that defaults the element name.
\r
1367 * @param linkage linkage specifier for the class
\r
1368 * @param cname the name of the XMLObject specialization
\r
1369 * @param namespaceURI the XML namespace of the default associated element
\r
1370 * @param namespacePrefix the XML namespace prefix of the default associated element
\r
1372 #define BEGIN_XMLOBJECTBUILDER(linkage,cname,namespaceURI,namespacePrefix) \
\r
1373 XMLTOOLING_DOXYGEN(Builder for cname objects.) \
\r
1374 class linkage cname##Builder : public xmltooling::ConcreteXMLObjectBuilder { \
\r
1376 virtual ~cname##Builder() {} \
\r
1377 XMLTOOLING_DOXYGEN(Default builder.) \
\r
1378 virtual xmltooling::XMLObject* buildObject() const { \
\r
1379 return buildObject(namespaceURI,cname::LOCAL_NAME,namespacePrefix); \
\r
1381 XMLTOOLING_DOXYGEN(Builder that allows element/type override.) \
\r
1382 virtual xmltooling::XMLObject* buildObject( \
\r
1383 const XMLCh* nsURI, const XMLCh* localName, const XMLCh* prefix=NULL, const xmltooling::QName* schemaType=NULL \
\r
1387 * Ends the declaration of an XMLObjectBuilder specialization.
\r
1389 #define END_XMLOBJECTBUILDER }
\r
1392 * Declares a generic XMLObjectBuilder specialization.
\r
1394 * @param linkage linkage specifier for the class
\r
1395 * @param cname the name of the XMLObject specialization
\r
1396 * @param namespaceURI the XML namespace of the default associated element
\r
1397 * @param namespacePrefix the XML namespace prefix of the default associated element
\r
1399 #define DECL_XMLOBJECTBUILDER(linkage,cname,namespaceURI,namespacePrefix) \
\r
1400 BEGIN_XMLOBJECTBUILDER(linkage,cname,namespaceURI,namespacePrefix); \
\r
1401 XMLTOOLING_DOXYGEN(Singleton builder.) \
\r
1402 static cname* build##cname() { \
\r
1403 const cname##Builder* b = dynamic_cast<const cname##Builder*>( \
\r
1404 XMLObjectBuilder::getBuilder(xmltooling::QName(namespaceURI,cname::LOCAL_NAME)) \
\r
1407 return dynamic_cast<cname*>(b->buildObject()); \
\r
1408 throw xmltooling::XMLObjectException("Unable to obtain typed builder for "#cname"."); \
\r
1410 END_XMLOBJECTBUILDER
\r
1413 * Implements the standard XMLObjectBuilder specialization function.
\r
1415 * @param cname the name of the XMLObject specialization
\r
1417 #define IMPL_XMLOBJECTBUILDER(cname) \
\r
1418 xmltooling::XMLObject* cname##Builder::buildObject( \
\r
1419 const XMLCh* nsURI, const XMLCh* localName, const XMLCh* prefix, const xmltooling::QName* schemaType \
\r
1422 return new cname##Impl(nsURI,localName,prefix,schemaType); \
\r
1425 #endif /* HAVE_COVARIANT_RETURNS */
\r
1428 * Begins the declaration of a Schema Validator specialization.
\r
1430 * @param linkage linkage specifier for the class
\r
1431 * @param cname the base name of the Validator specialization
\r
1433 #define BEGIN_XMLOBJECTVALIDATOR(linkage,cname) \
\r
1434 class linkage cname##SchemaValidator : public xmltooling::Validator \
\r
1437 virtual ~cname##SchemaValidator() {} \
\r
1438 virtual void validate(const xmltooling::XMLObject* xmlObject) const { \
\r
1439 const cname* ptr=dynamic_cast<const cname*>(xmlObject); \
\r
1441 throw xmltooling::ValidationException(#cname"SchemaValidator: unsupported object type ($1).",xmltooling::params(1,typeid(xmlObject).name())); \
\r
1442 if (ptr->nil() && (ptr->hasChildren() || ptr->getTextContent())) \
\r
1443 throw xmltooling::ValidationException("Object has nil property but with children or content.")
\r
1446 * Begins the declaration of a Schema Validator specialization subclass.
\r
1448 * @param linkage linkage specifier for the class
\r
1449 * @param cname the base name of the Validator specialization
\r
1450 * @param base base class for the validator
\r
1452 #define BEGIN_XMLOBJECTVALIDATOR_SUB(linkage,cname,base) \
\r
1453 class linkage cname##SchemaValidator : public base##SchemaValidator \
\r
1456 virtual ~cname##SchemaValidator() {} \
\r
1457 virtual void validate(const xmltooling::XMLObject* xmlObject) const { \
\r
1458 const cname* ptr=dynamic_cast<const cname*>(xmlObject); \
\r
1460 throw xmltooling::ValidationException(#cname"SchemaValidator: unsupported object type ($1).",xmltooling::params(1,typeid(xmlObject).name()));
\r
1463 * Ends the declaration of a Validator specialization.
\r
1465 #define END_XMLOBJECTVALIDATOR } }
\r
1468 * Validator code that checks the object type.
\r
1470 * @param cname the name of the XMLObject specialization
\r
1472 #define XMLOBJECTVALIDATOR_CHECKTYPE(cname) \
\r
1473 const cname* ptr=dynamic_cast<const cname*>(xmlObject); \
\r
1475 throw xmltooling::ValidationException(#cname"SchemaValidator: unsupported object type ($1).",xmltooling::params(1,typeid(xmlObject).name()))
\r
1478 * Validator code that checks for a required attribute, content, or singleton.
\r
1480 * @param cname the name of the XMLObject specialization
\r
1481 * @param proper the proper name of the attribute, content, or singleton member
\r
1483 #define XMLOBJECTVALIDATOR_REQUIRE(cname,proper) \
\r
1484 if (!ptr->get##proper()) \
\r
1485 throw xmltooling::ValidationException(#cname" must have "#proper".")
\r
1488 * Validator code that checks for a required integer attribute
\r
1490 * @param cname the name of the XMLObject specialization
\r
1491 * @param proper the proper name of the attribute, content, or singleton member
\r
1493 #define XMLOBJECTVALIDATOR_REQUIRE_INTEGER(cname,proper) \
\r
1494 if (!ptr->get##proper().first) \
\r
1495 throw xmltooling::ValidationException(#cname" must have "#proper".")
\r
1498 * Validator code that checks for one of a pair of
\r
1499 * required attributes, content, or singletons.
\r
1501 * @param cname the name of the XMLObject specialization
\r
1502 * @param proper1 the proper name of the first attribute, content, or singleton member
\r
1503 * @param proper2 the proper name of the second attribute, content, or singleton member
\r
1505 #define XMLOBJECTVALIDATOR_ONEOF(cname,proper1,proper2) \
\r
1506 if (!ptr->get##proper1() && !ptr->get##proper2()) \
\r
1507 throw xmltooling::ValidationException(#cname" must have "#proper1" or "#proper2".")
\r
1510 * Validator code that checks for one of a pair of
\r
1511 * required attributes, content, or singletons, but disallows both.
\r
1513 * @param cname the name of the XMLObject specialization
\r
1514 * @param proper1 the proper name of the first attribute, content, or singleton member
\r
1515 * @param proper2 the proper name of the second attribute, content, or singleton member
\r
1517 #define XMLOBJECTVALIDATOR_ONLYONEOF(cname,proper1,proper2) \
\r
1518 if ((!ptr->get##proper1() && !ptr->get##proper2()) || (ptr->get##proper1() && ptr->get##proper2())) \
\r
1519 throw xmltooling::ValidationException(#cname" must have "#proper1" or "#proper2" but not both.")
\r
1522 * Validator code that checks for one of a set of three
\r
1523 * required attributes, content, or singletons.
\r
1525 * @param cname the name of the XMLObject specialization
\r
1526 * @param proper1 the proper name of the first attribute, content, or singleton member
\r
1527 * @param proper2 the proper name of the second attribute, content, or singleton member
\r
1528 * @param proper3 the proper name of the third attribute, content, or singleton member
\r
1530 #define XMLOBJECTVALIDATOR_ONEOF3(cname,proper1,proper2,proper3) \
\r
1531 if (!ptr->get##proper1() && !ptr->get##proper2() && !ptr->get##proper3()) \
\r
1532 throw xmltooling::ValidationException(#cname" must have "#proper1", "#proper2", or "#proper3".")
\r
1535 * Validator code that checks for one of a set of three
\r
1536 * required attributes, content, or singletons but disallows more than one.
\r
1538 * @param cname the name of the XMLObject specialization
\r
1539 * @param proper1 the proper name of the first attribute, content, or singleton member
\r
1540 * @param proper2 the proper name of the second attribute, content, or singleton member
\r
1541 * @param proper3 the proper name of the third attribute, content, or singleton member
\r
1543 #define XMLOBJECTVALIDATOR_ONLYONEOF3(cname,proper1,proper2,proper3) \
\r
1544 int c##proper1##proper2##proper3=0; \
\r
1545 if (ptr->get##proper1()!=NULL) \
\r
1546 c##proper1##proper2##proper3++; \
\r
1547 if (ptr->get##proper2()!=NULL) \
\r
1548 c##proper1##proper2##proper3++; \
\r
1549 if (ptr->get##proper3()!=NULL) \
\r
1550 c##proper1##proper2##proper3++; \
\r
1551 if (c##proper1##proper2##proper3 != 1) \
\r
1552 throw xmltooling::ValidationException(#cname" must have only one of "#proper1", "#proper2", or "#proper3".")
\r
1555 * Validator code that checks a co-constraint (if one present, the other must be)
\r
1556 * between a pair of attributes, content, or singletons.
\r
1558 * @param cname the name of the XMLObject specialization
\r
1559 * @param proper1 the proper name of the first attribute, content, or singleton member
\r
1560 * @param proper2 the proper name of the second attribute, content, or singleton member
\r
1562 #define XMLOBJECTVALIDATOR_NONEORBOTH(cname,proper1,proper2) \
\r
1563 if ((ptr->get##proper1() && !ptr->get##proper2()) || (!ptr->get##proper1() && ptr->get##proper2())) \
\r
1564 throw xmltooling::ValidationException(#cname" cannot have "#proper1" without "#proper2".")
\r
1567 * Validator code that checks for a non-empty collection.
\r
1569 * @param cname the name of the XMLObject specialization
\r
1570 * @param proper the proper name of the collection item
\r
1572 #define XMLOBJECTVALIDATOR_NONEMPTY(cname,proper) \
\r
1573 if (ptr->get##proper##s().empty()) \
\r
1574 throw xmltooling::ValidationException(#cname" must have at least one "#proper".")
\r
1577 * Declares/defines a Validator specialization that checks object type and
\r
1578 * a non-empty simple content model.
\r
1580 * @param linkage linkage specifier for the class
\r
1581 * @param cname the name of the XMLObject specialization
\r
1583 #define XMLOBJECTVALIDATOR_SIMPLE(linkage,cname) \
\r
1584 BEGIN_XMLOBJECTVALIDATOR(linkage,cname); \
\r
1585 XMLOBJECTVALIDATOR_REQUIRE(cname,TextContent); \
\r
1586 END_XMLOBJECTVALIDATOR
\r
1588 #include <utility>
\r
1591 * @namespace xmltooling
\r
1592 * Public namespace of XML Tooling library
\r
1594 namespace xmltooling {
\r
1597 * Template function for cloning a sequence of XMLObjects.
\r
1598 * Invokes the clone() member on each element of the input sequence and adds the copy to
\r
1599 * the output sequence. Order is preserved.
\r
1601 * @param in input sequence to clone
\r
1602 * @param out output sequence to copy cloned pointers into
\r
1604 template<class InputSequence,class OutputSequence> void clone(const InputSequence& in, OutputSequence& out) {
\r
1605 for (typename InputSequence::const_iterator i=in.begin(); i!=in.end(); i++) {
\r
1607 out.push_back((*i)->clone());
\r
1609 out.push_back(*i);
\r
1614 * Functor for cleaning up heap objects in containers.
\r
1616 template<class T> struct cleanup
\r
1619 * Function operator to delete an object.
\r
1621 * @param ptr object to delete
\r
1623 void operator()(T* ptr) {delete ptr;}
\r
1626 * Function operator to delete an object stored as const.
\r
1628 * @param ptr object to delete after casting away const
\r
1630 void operator()(const T* ptr) {delete const_cast<T*>(ptr);}
\r
1634 * Functor for cleaning up heap objects in key/value containers.
\r
1636 template<class A,class B> struct cleanup_pair
\r
1639 * Function operator to delete an object.
\r
1641 * @param p a pair in which the second component is the object to delete
\r
1643 void operator()(const std::pair<const A,B*>& p) {delete p.second;}
\r
1647 * Functor for cleaning up const heap objects in key/value containers.
\r
1649 template<class A,class B> struct cleanup_const_pair
\r
1652 * Function operator to delete an object stored as const
\r
1654 * @param p a pair in which the second component is the const object to delete
\r
1656 void operator()(const std::pair<const A,const B*>& p) {delete const_cast<B*>(p.second);}
\r
1660 #endif /* __xmltooling_base_h__ */
\r