topical media & game development

talk show tell print

lib-of-vs-libs-Poco-include-Poco-XML-expat-external.h / h



  /* Copyright (c) 1998, 1999, 2000 Thai Open Source Software Center Ltd
     See the file COPYING for copying permission.
  */
  
  ifndef Expat_External_INCLUDED
  define Expat_External_INCLUDED 1
  
  /* External API definitions */
  
  if defined(_MSC_EXTENSIONS) && !defined(__BEOS__) && !defined(__CYGWIN__)
  define XML_USE_MSC_EXTENSIONS 1
  endif
  
  /* Expat tries very hard to make the API boundary very specifically
     defined.  There are two macros defined to control this boundary;
     each of these can be defined before including this header to
     achieve some different behavior, but doing so it not recommended or
     tested frequently.
  
     XMLCALL    - The calling convention to use for all calls across the
                  "library boundary."  This will default to cdecl, and
                  try really hard to tell the compiler that's what we
                  want.
  
     XMLIMPORT  - Whatever magic is needed to note that a function is
                  to be imported from a dynamically loaded library
                  (.dll, .so, or .sl, depending on your platform).
  
     The XMLCALL macro was added in Expat 1.95.7.  The only one which is
     expected to be directly useful in client code is XMLCALL.
  
     Note that on at least some Unix versions, the Expat library must be
     compiled with the cdecl calling convention as the default since
     system headers may assume the cdecl convention.
  */
  ifndef XMLCALL
  if defined(_MSC_VER)
  define XMLCALL __cdecl
  #elif defined(__GNUC__) && defined(__i386) && !defined(__INTEL_COMPILER)
  define XMLCALL __attribute__((cdecl))
  else
  /* For any platform which uses this definition and supports more than
     one calling convention, we need to extend this definition to
     declare the convention used on that platform, if it's possible to
     do so.
  
     If this is the case for your platform, please file a bug report
     with information on how to identify your platform via the C
     pre-processor and how to specify the same calling convention as the
     platform's malloc() implementation.
  */
  define XMLCALL
  endif
  endif  /* not defined XMLCALL */
  
  if !defined(XML_STATIC) && !defined(XMLIMPORT)
  ifndef XML_BUILDING_EXPAT
  /* using Expat from an application */
  
  ifdef XML_USE_MSC_EXTENSIONS
  define XMLIMPORT __declspec(dllimport)
  endif
  
  endif
  endif  /* not defined XML_STATIC */
  
  /* If we didn't define it above, define it away: */
  ifndef XMLIMPORT
  define XMLIMPORT
  endif
  
  define XMLPARSEAPI(type) XMLIMPORT type XMLCALL
  
  ifdef __cplusplus
  extern "C" {
  endif
  
  ifdef XML_UNICODE_WCHAR_T
  define XML_UNICODE
  endif
  
  ifdef XML_UNICODE     /* Information is UTF-16 encoded. */
  ifdef XML_UNICODE_WCHAR_T
  typedef wchar_t XML_Char;
  typedef wchar_t XML_LChar;
  else
  typedef unsigned short XML_Char;
  typedef char XML_LChar;
  endif /* XML_UNICODE_WCHAR_T */
  else                  /* Information is UTF-8 encoded. */
  typedef char XML_Char;
  typedef char XML_LChar;
  endif /* XML_UNICODE */
  
  ifdef XML_LARGE_SIZE  /* Use large integers for file/stream positions. */
  if defined(XML_USE_MSC_EXTENSIONS) && _MSC_VER < 1400
  typedef __int64 XML_Index; 
  typedef unsigned __int64 XML_Size;
  else
  typedef long long XML_Index;
  typedef unsigned long long XML_Size;
  endif
  else
  typedef long XML_Index;
  typedef unsigned long XML_Size;
  endif /* XML_LARGE_SIZE */
  
  ifdef __cplusplus
  }
  endif
  
  endif /* not Expat_External_INCLUDED */
  


(C) Æliens 04/09/2009

You may not copy or print any of this material without explicit permission of the author or the publisher. In case of other copyright issues, contact the author.