/* * The Apache Software License, Version 1.1 * * Copyright (c) 1999-2001 The Apache Software Foundation. All rights * reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: * * 1. Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * * 2. Redistributions in binary form must reproduce the above copyright * notice, this list of conditions and the following disclaimer in * the documentation and/or other materials provided with the * distribution. * * 3. The end-user documentation included with the redistribution, * if any, must include the following acknowledgment: * "This product includes software developed by the * Apache Software Foundation (http://www.apache.org/)." * Alternately, this acknowledgment may appear in the software itself, * if and wherever such third-party acknowledgments normally appear. * * 4. The names "Xerces" and "Apache Software Foundation" must * not be used to endorse or promote products derived from this * software without prior written permission. For written * permission, please contact apache\@apache.org. * * 5. Products derived from this software may not be called "Apache", * nor may "Apache" appear in their name, without prior written * permission of the Apache Software Foundation. * * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE * DISCLAIMED. IN NO EVENT SHALL THE APACHE SOFTWARE FOUNDATION OR * ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF * USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF * SUCH DAMAGE. * ==================================================================== * * This software consists of voluntary contributions made by many * individuals on behalf of the Apache Software Foundation, and was * originally based on software copyright (c) 1999, International * Business Machines, Inc., http://www.ibm.com . For more information * on the Apache Software Foundation, please see * . */ /* * $Log: XercesDefs.hpp,v $ * Revision 1.16 2004/02/04 13:26:44 amassari * Added support for the Interix platform (Windows Services for Unix 3.5) * * Revision 1.15 2003/05/29 11:18:37 gareth * Added macros in so we can determine whether to do things like iostream as opposed to iostream.h and whether to use std:: or not. * * Revision 1.14 2003/05/12 09:44:19 gareth * Port to NetBSD. Patch by Hiramatsu Yoshifumi. * * Revision 1.13 2003/03/13 22:11:46 tng * [Bug 17858] Support for QNX/Neutrino. Patch from Chris McKillop. * * Revision 1.12 2003/02/23 05:44:12 jberry * Ripple through changes of BeOSDefs.h name change * * Revision 1.11 2002/12/31 19:31:07 tng * [Bug 15590] BeOSDefs.hpp has wrong case in CVS. * * Revision 1.10 2002/12/02 20:40:49 tng * [Bug 12490] Patches required to build Xerces-C++ on BeOS R5. Patch from Andrew Bachmann. * * Revision 1.9 2002/11/05 21:44:21 tng * Do not code using namespace in a global header. * * Revision 1.8 2002/11/04 14:40:12 tng * C++ Namespace Support. * * Revision 1.7 2002/07/12 16:48:49 jberry * Remove reliance on XML_MACOSX. XML_MACOS is used solely. Where qualification * by compiler is required, look for the compiler explicitly such as with * XML_METROWERKS or __APPLE__ (for the Apple GCC compiler). * * Add a few tweaks for compatibility with GCC3.1. * * This change may address Bug 10649. * * Revision 1.6 2002/07/10 12:56:45 tng * [Bug 9154] Requesting Xerces Version Macro. * * Revision 1.5 2002/05/21 19:35:08 tng * Update from 1.7 to 2.0 * * Revision 1.4 2002/02/27 22:38:34 peiyongz * Bug# 6445 Caldera (SCO) OpenServer Port : patch from Martin Kalen * * Revision 1.3 2002/02/20 21:41:54 tng * project files changes for Xerces-C++ 1.7. * * Revision 1.2 2002/02/17 21:12:06 jberry * Adjust "sane includes" include path for Mac OS. * * I've also changed this path for XML_AS400, XML_TRU64, XML_PTX_CC, and XML_DECCXX * 'cause it looks like the right thing to do...hope that's not a mistake. * * Revision 1.1.1.1 2002/02/01 22:22:13 peiyongz * sane_include * * Revision 1.18 2001/11/29 18:25:18 tng * FreeBSD support by Michael Huedepohl. * * Revision 1.17 2001/11/23 17:19:33 tng * Change from 1.5.2 to 1.6.0 * * Revision 1.16 2001/10/15 16:27:35 tng * Changes for Xerces-C 1.5.2 * * Revision 1.15 2001/07/13 20:16:38 tng * Update for release 1.5.1. * * Revision 1.14 2001/06/05 13:52:25 tng * Change Version number from Xerces 1.4 to 1.5. By Pei Yong Zhang. * * Revision 1.13 2001/05/11 13:26:32 tng * Copyright update. * * Revision 1.12 2001/02/08 14:15:33 tng * enable COMPAQ Tru64 UNIX machines to build xerces-c with gcc (tested using COMPAQ gcc version2.95.2 19991024 (release) and Tru64 V5.0 1094). Added by Martin Kalen. * * Revision 1.11 2001/01/25 19:17:06 tng * const should be used instead of static const. Fixed by Khaled Noaman. * * Revision 1.10 2001/01/12 22:09:07 tng * Various update for Xerces 1.4 * * Revision 1.9 2000/11/07 18:14:39 andyh * Fix incorrect version number in gXercesMinVersion. * From Pieter Van-Dyck * * Revision 1.8 2000/11/02 07:23:27 roddey * Just a test of checkin access * * Revision 1.7 2000/08/18 21:29:14 andyh * Change version to 1.3 in preparation for upcoming Xerces 1.3 * and XML4C 3.3 stable releases * * Revision 1.6 2000/08/07 20:31:34 jpolast * include SAX2_EXPORT module * * Revision 1.5 2000/08/01 18:26:02 aruna1 * Tru64 support added * * Revision 1.4 2000/07/29 05:36:37 jberry * Fix misspelling in Mac OS port * * Revision 1.3 2000/07/19 18:20:12 andyh * Macintosh port: fix problems with yesterday's code checkin. A couple * of the changes were mangled or missed. * * Revision 1.2 2000/04/04 20:11:29 abagchi * Added PTX support * * Revision 1.1 2000/03/02 19:54:50 roddey * This checkin includes many changes done while waiting for the * 1.1.0 code to be finished. I can't list them all here, but a list is * available elsewhere. * * Revision 1.13 2000/03/02 01:51:00 aruna1 * Sun CC 5.0 related changes * * Revision 1.12 2000/02/24 20:05:26 abagchi * Swat for removing Log from API docs * * Revision 1.11 2000/02/22 01:00:10 aruna1 * GNUGDefs references removed. Now only GCCDefs is used instead * * Revision 1.10 2000/02/06 07:48:05 rahulj * Year 2K copyright swat. * * Revision 1.9 2000/02/01 23:43:32 abagchi * AS/400 related change * * Revision 1.8 2000/01/21 22:12:29 abagchi * OS390 Change: changed OE390 to OS390 * * Revision 1.7 2000/01/14 01:18:35 roddey * Added a macro, XMLStrL(), which is defined one way or another according * to whether the per-compiler file defines XML_LSTRSUPPORT or not. This * allows conditional support of L"" type prefixes. * * Revision 1.6 2000/01/14 00:52:06 roddey * Updated the version information for the next release, i.e. 1.1.0 * * Revision 1.5 1999/12/17 01:28:53 rahulj * Merged in changes submitted for UnixWare 7 port. Platform * specific files are still missing. * * Revision 1.4 1999/12/16 23:47:10 rahulj * Updated for version 1.0.1 * * Revision 1.3 1999/12/01 17:16:16 rahulj * Added support for IRIX 6.5.5 using SGI MIPSpro C++ 7.3 and 7.21 generating 32 bit objects. Changes submitted by Marc Stuessel * * Revision 1.2 1999/11/10 02:02:51 abagchi * Changed version numbers * * Revision 1.1.1.1 1999/11/09 01:05:35 twl * Initial checkin * * Revision 1.3 1999/11/08 20:45:19 rahul * Swat for adding in Product name and CVS comment log variable. * */ #if !defined(XERCESDEFS_HPP) #define XERCESDEFS_HPP // --------------------------------------------------------------------------- // Include the Xerces version information; this is kept in a separate file to // make modification simple and obvious. Updates to the version header file // --------------------------------------------------------------------------- #include // --------------------------------------------------------------------------- // Include the header that does automatic sensing of the current platform // and compiler. // --------------------------------------------------------------------------- #include // --------------------------------------------------------------------------- // According to the platform we include a platform specific file. This guy // will set up any platform specific stuff, such as character mode. // --------------------------------------------------------------------------- #if defined(XML_WIN32) #include #endif #if defined(XML_AIX) #include #endif #if defined(XML_SOLARIS) #include #endif #if defined(XML_OPENSERVER) #include #endif #if defined(XML_UNIXWARE) #include #endif #if defined(XML_HPUX) #include #endif #if defined(XML_IRIX) #include #endif #if defined(XML_INTERIX) #include #endif #if defined(XML_TANDEM) #include #endif #if defined(XML_BEOS) #include #endif #if defined(XML_LINUX) #include #endif #if defined(XML_FREEBSD) #include #endif #if defined(XML_OS390) #include #endif #if defined(XML_PTX) #include #endif #if defined(XML_OS2) #include #endif #if defined(XML_MACOS) #include #endif #if defined(XML_AS400) #include #endif #if defined(XML_TRU64) #include #endif #if defined(XML_QNX) #include #endif // --------------------------------------------------------------------------- // And now we subinclude a header according to the development environment // we are on. This guy defines for each platform some basic stuff that is // specific to the development environment. // --------------------------------------------------------------------------- #if defined(XML_VISUALCPP) #include #endif #if defined(XML_CSET) #include #endif #if defined(XML_BORLAND) #include #endif #if defined(XML_SUNCC) || defined(XML_SUNCC5) #include #endif #if defined(XML_SCOCC) #include #endif #if defined(XML_SOLARIS_KAICC) #include #endif #if defined(XML_HPUX_CC) || defined(XML_HPUX_aCC) || defined(XML_HPUX_KAICC) #include #endif #if defined(XML_MIPSPRO_CC) #include #endif #if defined(XML_TANDEMCC) #include #endif #if defined(XML_GCC) #include #endif #if defined(XML_MVSCPP) #include #endif #if defined(XML_IBMVAW32) #include #endif #if defined(XML_IBMVAOS2) #include #endif #if defined(XML_METROWERKS) #include #endif #if defined(XML_PTX_CC) #include #endif #if defined(XML_AS400) #include #endif #if defined(XML_DECCXX) #include #endif #if defined(XML_QCC) #include #endif // --------------------------------------------------------------------------- // Some general typedefs that are defined for internal flexibility. // // Note that UTF16Ch is fixed at 16 bits, whereas XMLCh floats in size per // platform, to whatever is the native wide char format there. UCS4Ch is // fixed at 32 bits. The types we defined them in terms of are defined per // compiler, using whatever types are the right ones for them to get these // 16/32 bit sizes. // // --------------------------------------------------------------------------- typedef unsigned char XMLByte; typedef XMLUInt16 UTF16Ch; typedef XMLUInt32 UCS4Ch; // --------------------------------------------------------------------------- // Handle boolean. If the platform can handle booleans itself, then we // map our boolean type to the native type. Otherwise we create a default // one as an int and define const values for true and false. // // This flag will be set in the per-development environment stuff above. // --------------------------------------------------------------------------- #if defined(NO_NATIVE_BOOL) #ifndef bool typedef int bool; #endif #ifndef true #define true 1 #endif #ifndef false #define false 0 #endif #endif #if defined(XML_NETBSD) #include #endif // --------------------------------------------------------------------------- // According to whether the compiler suports L"" type strings, we define // the XMLStrL() macro one way or another. // --------------------------------------------------------------------------- #if defined(XML_LSTRSUPPORT) #define XMLStrL(str) L##str #else #define XMLStrL(str) str #endif // --------------------------------------------------------------------------- // Define namespace symbols if the compiler supports it. // --------------------------------------------------------------------------- #if defined(XERCES_HAS_CPP_NAMESPACE) #define XERCES_CPP_NAMESPACE_BEGIN namespace XERCES_CPP_NAMESPACE { #define XERCES_CPP_NAMESPACE_END } #define XERCES_CPP_NAMESPACE_USE using namespace XERCES_CPP_NAMESPACE; #define XERCES_CPP_NAMESPACE_QUALIFIER XERCES_CPP_NAMESPACE:: namespace XERCES_CPP_NAMESPACE { } namespace xercesc = XERCES_CPP_NAMESPACE; #else #define XERCES_CPP_NAMESPACE_BEGIN #define XERCES_CPP_NAMESPACE_END #define XERCES_CPP_NAMESPACE_USE #define XERCES_CPP_NAMESPACE_QUALIFIER #endif #if defined(XERCES_STD_NAMESPACE) #define XERCES_USING_STD(NAME) using std :: NAME; #define XERCES_STD_QUALIFIER std :: #else #define XERCES_USING_STD(NAME) #define XERCES_STD_QUALIFIER #endif // --------------------------------------------------------------------------- // Set up the import/export keyword for our core projects. The // PLATFORM_XXXX keywords are set in the per-development environment // include above. // --------------------------------------------------------------------------- #if defined(PROJ_XMLUTIL) #define XMLUTIL_EXPORT PLATFORM_EXPORT #else #define XMLUTIL_EXPORT PLATFORM_IMPORT #endif #if defined(PROJ_XMLPARSER) #define XMLPARSER_EXPORT PLATFORM_EXPORT #else #define XMLPARSER_EXPORT PLATFORM_IMPORT #endif #if defined(PROJ_SAX4C) #define SAX_EXPORT PLATFORM_EXPORT #else #define SAX_EXPORT PLATFORM_IMPORT #endif #if defined(PROJ_SAX2) #define SAX2_EXPORT PLATFORM_EXPORT #else #define SAX2_EXPORT PLATFORM_IMPORT #endif #if defined(PROJ_DOM) #define CDOM_EXPORT PLATFORM_EXPORT #else #define CDOM_EXPORT PLATFORM_IMPORT #endif #if defined(PROJ_PARSERS) #define PARSERS_EXPORT PLATFORM_EXPORT #else #define PARSERS_EXPORT PLATFORM_IMPORT #endif #if defined(PROJ_VALIDATORS) #define VALIDATORS_EXPORT PLATFORM_EXPORT #else #define VALIDATORS_EXPORT PLATFORM_IMPORT #endif #endif