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>
46int snprintf(char *, size_t, const char *, ...);
47int 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 */
80extern int __xmlRegisterCallbacks;
81/*
82 * internal error reporting routines, shared but not partof the API.
83 */
84void __xmlIOErr(int domain, int code, const char *extra);
85void __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 */
91void __htmlParseContent(void *ctx);
92#endif
93
94/*
95 * internal global initialization critical section routines.
96 */
97void __xmlGlobalInitMutexLock(void);
98void __xmlGlobalInitMutexUnlock(void);
99void __xmlGlobalInitMutexDestroy(void);
100
101int __xmlInitializeDict(void);
102
103#if defined(HAVE_RAND) && defined(HAVE_SRAND) && defined(HAVE_TIME)
104/*
105 * internal thread safe random function
106 */
107int __xmlRandom(void);
108#endif
109
110XMLPUBFUN xmlChar * XMLCALL xmlEscapeFormatString(xmlChar **msg);
111int 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