Home | History | Annotate | Download | only in libxml2
      1 /*
      2  * libxml.h: internal header only used during the compilation of libxml
      3  *
      4  * See COPYRIGHT for the status of this software
      5  *
      6  * Author: breese (at) users.sourceforge.net
      7  */
      8 
      9 #ifndef __XML_LIBXML_H__
     10 #define __XML_LIBXML_H__
     11 
     12 #include <libxml/xmlstring.h>
     13 
     14 #ifndef NO_LARGEFILE_SOURCE
     15 #ifndef _LARGEFILE_SOURCE
     16 #define _LARGEFILE_SOURCE
     17 #endif
     18 #ifndef _FILE_OFFSET_BITS
     19 #define _FILE_OFFSET_BITS 64
     20 #endif
     21 #endif
     22 
     23 #if defined(macintosh)
     24 #include "config-mac.h"
     25 #elif defined(_WIN32_WCE)
     26 /*
     27  * Windows CE compatibility definitions and functions
     28  * This is needed to compile libxml2 for Windows CE.
     29  * At least I tested it with WinCE 5.0 for Emulator and WinCE 4.2/SH4 target
     30  */
     31 #include <win32config.h>
     32 #include <libxml/xmlversion.h>
     33 #else
     34 /*
     35  * Currently supported platforms use either autoconf or
     36  * copy to config.h own "preset" configuration file.
     37  * As result ifdef HAVE_CONFIG_H is omited here.
     38  */
     39 #include "config.h"
     40 #include <libxml/xmlversion.h>
     41 #endif
     42 
     43 #if defined(__Lynx__)
     44 #include <stdio.h> /* pull definition of size_t */
     45 #include <varargs.h>
     46 int snprintf(char *, size_t, const char *, ...);
     47 int vfprintf(FILE *, const char *, va_list);
     48 #endif
     49 
     50 #ifndef WITH_TRIO
     51 #include <stdio.h>
     52 #else
     53 /**
     54  * TRIO_REPLACE_STDIO:
     55  *
     56  * This macro is defined if teh trio string formatting functions are to
     57  * be used instead of the default stdio ones.
     58  */
     59 #define TRIO_REPLACE_STDIO
     60 #include "trio.h"
     61 #endif
     62 
     63 /*
     64  * Internal variable indicating if a callback has been registered for
     65  * node creation/destruction. It avoids spending a lot of time in locking
     66  * function while checking if the callback exists.
     67  */
     68 extern int __xmlRegisterCallbacks;
     69 /*
     70  * internal error reporting routines, shared but not partof the API.
     71  */
     72 void __xmlIOErr(int domain, int code, const char *extra);
     73 void __xmlLoaderErr(void *ctx, const char *msg, const char *filename) LIBXML_ATTR_FORMAT(2,0);
     74 #ifdef LIBXML_HTML_ENABLED
     75 /*
     76  * internal function of HTML parser needed for xmlParseInNodeContext
     77  * but not part of the API
     78  */
     79 void __htmlParseContent(void *ctx);
     80 #endif
     81 
     82 /*
     83  * internal global initialization critical section routines.
     84  */
     85 void __xmlGlobalInitMutexLock(void);
     86 void __xmlGlobalInitMutexUnlock(void);
     87 void __xmlGlobalInitMutexDestroy(void);
     88 
     89 int __xmlInitializeDict(void);
     90 
     91 #if defined(HAVE_RAND) && defined(HAVE_SRAND) && defined(HAVE_TIME)
     92 /*
     93  * internal thread safe random function
     94  */
     95 int __xmlRandom(void);
     96 #endif
     97 
     98 XMLPUBFUN xmlChar * XMLCALL xmlEscapeFormatString(xmlChar **msg);
     99 int xmlNop(void);
    100 
    101 #ifdef IN_LIBXML
    102 #ifdef __GNUC__
    103 #ifdef PIC
    104 #ifdef linux
    105 #if (__GNUC__ == 3 && __GNUC_MINOR__ >= 3) || (__GNUC__ > 3)
    106 #include "elfgcchack.h"
    107 #endif
    108 #endif
    109 #endif
    110 #endif
    111 #endif
    112 #if !defined(PIC) && !defined(NOLIBTOOL)
    113 #  define LIBXML_STATIC
    114 #endif
    115 #endif /* ! __XML_LIBXML_H__ */
    116