xref: /reactos/sdk/lib/3rdparty/libxml2/libxml.h (revision d6d1efe7)
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@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 #if defined(__clang__) || \
64     (defined(__GNUC__) && (__GNUC__ * 100 + __GNUC_MINOR__ >= 406))
65 #define XML_IGNORE_PEDANTIC_WARNINGS \
66     _Pragma("GCC diagnostic push") \
67     _Pragma("GCC diagnostic ignored \"-Wpedantic\"")
68 #define XML_POP_WARNINGS \
69     _Pragma("GCC diagnostic pop")
70 #else
71 #define XML_IGNORE_PEDANTIC_WARNINGS
72 #define XML_POP_WARNINGS
73 #endif
74 
75 /*
76  * Internal variable indicating if a callback has been registered for
77  * node creation/destruction. It avoids spending a lot of time in locking
78  * function while checking if the callback exists.
79  */
80 extern int __xmlRegisterCallbacks;
81 /*
82  * internal error reporting routines, shared but not partof the API.
83  */
84 void __xmlIOErr(int domain, int code, const char *extra);
85 void __xmlLoaderErr(void *ctx, const char *msg, const char *filename) LIBXML_ATTR_FORMAT(2,0);
86 #ifdef LIBXML_HTML_ENABLED
87 /*
88  * internal function of HTML parser needed for xmlParseInNodeContext
89  * but not part of the API
90  */
91 void __htmlParseContent(void *ctx);
92 #endif
93 
94 /*
95  * internal global initialization critical section routines.
96  */
97 void __xmlGlobalInitMutexLock(void);
98 void __xmlGlobalInitMutexUnlock(void);
99 void __xmlGlobalInitMutexDestroy(void);
100 
101 int __xmlInitializeDict(void);
102 
103 #if defined(HAVE_RAND) && defined(HAVE_SRAND) && defined(HAVE_TIME)
104 /*
105  * internal thread safe random function
106  */
107 int __xmlRandom(void);
108 #endif
109 
110 XMLPUBFUN xmlChar * XMLCALL xmlEscapeFormatString(xmlChar **msg);
111 int xmlInputReadCallbackNop(void *context, char *buffer, int len);
112 
113 #ifdef IN_LIBXML
114 #ifdef __GNUC__
115 #ifdef PIC
116 #ifdef __linux__
117 #if (__GNUC__ == 3 && __GNUC_MINOR__ >= 3) || (__GNUC__ > 3)
118 #include "elfgcchack.h"
119 #endif
120 #endif
121 #endif
122 #endif
123 #endif
124 #if !defined(PIC) && !defined(NOLIBTOOL) && !defined(LIBXML_STATIC)
125 #  define LIBXML_STATIC
126 #endif
127 #endif /* ! __XML_LIBXML_H__ */
128