-
Notifications
You must be signed in to change notification settings - Fork 3
/
xmlrpc_config.h.in
254 lines (219 loc) · 7.16 KB
/
xmlrpc_config.h.in
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
/* xmlrpc_config.h is generated from xmlrpc_config.h.in by 'configure'.
The purpose of this file is to define stuff particular to the build
environment being used to build Xmlrpc-c. Xmlrpc-c source files can
#include this file and have build-environment-independent source code.
A major goal of this file is to reduce conditional compilation in
the other source files as much as possible. Even more, we want to avoid
having to generate source code particular to a build environment
except in this file.
This file is NOT meant to be used by any code outside of the
Xmlrpc-c source tree. There is a similar file that gets installed
as <xmlrpc-c/config.h> that performs the same function for Xmlrpc-c
interface header files that get compiled as part of a user's program.
This file just uses plain AC_SUBST substitution, the same as
config.mk. Wherever you see @XXX@, that gets replaced by the
value of 'configure' variable XXX.
Logical macros are 0 or 1 instead of the more traditional defined and
undefined. That's so we can distinguish when compiling code between
"false" and some problem with the code.
*/
#ifndef XMLRPC_CONFIG_H_INCLUDED
#define XMLRPC_CONFIG_H_INCLUDED
/* We hope to replace xmlrpc_amconfig.h some day with something that
doesn't require a whole special set of software to build, to make
Xmlrpc-c approachable by dumber developers.
*/
#include "xmlrpc_amconfig.h"
#ifndef HAVE_SETGROUPS
#define HAVE_SETGROUPS 0
#endif
#ifndef HAVE_ASPRINTF
#define HAVE_ASPRINTF 0
#endif
#ifndef HAVE_SETENV
#define HAVE_SETENV 0
#endif
#ifndef HAVE_PSELECT
#define HAVE_PSELECT 0
#endif
#ifndef HAVE_WCSNCMP
#define HAVE_WCSNCMP 1
#endif
#ifndef HAVE_GETTIMEOFDAY
#define HAVE_GETTIMEOFDAY 0
#endif
#ifndef HAVE_LOCALTIME_R
#define HAVE_LOCALTIME_R 0
#endif
#ifndef HAVE_GMTIME_R
#define HAVE_GMTIME_R 0
#endif
#ifndef HAVE_STRCASECMP
#define HAVE_STRCASECMP 0
#endif
#ifndef HAVE_STRICMP
#define HAVE_STRICMP 0
#endif
#ifndef HAVE__STRICMP
#define HAVE__STRICMP 0
#endif
#ifndef HAVE_STRTOLL
#define HAVE_STRTOLL 0
#endif
#ifndef HAVE_STRTOQ
#define HAVE_STRTOQ 0
#endif
#ifndef HAVE___STRTOLL
#define HAVE___STRTOLL 0
#endif
#ifndef HAVE_STRTOUQ
#define HAVE_STRTOUQ 0
#endif
#ifndef HAVE___STRTOULL
#define HAVE___STRTOULL 0
#endif
#ifndef HAVE__STRTOUI64
#define HAVE__STRTOUI64 0
#endif
#define HAVE_WCHAR_H @HAVE_WCHAR_H_DEFINE@
#define HAVE_SYS_FILIO_H @HAVE_SYS_FILIO_H_DEFINE@
#define HAVE_SYS_IOCTL_H @HAVE_SYS_IOCTL_H_DEFINE@
#define HAVE_SYS_SELECT_H @HAVE_SYS_SELECT_H_DEFINE@
#define VA_LIST_IS_ARRAY @VA_LIST_IS_ARRAY_DEFINE@
#define HAVE_LIBWWW_SSL @HAVE_LIBWWW_SSL_DEFINE@
/* Used to mark an unused function parameter */
#define ATTR_UNUSED @ATTR_UNUSED@
#define DIRECTORY_SEPARATOR "@DIRECTORY_SEPARATOR@"
#define HAVE_UNICODE_WCHAR HAVE_WCHAR_H
/* Xmlrpc-c code uses __inline__ to declare functions that should
be compiled as inline code. GNU C recognizes the __inline__ keyword.
Others recognize 'inline' or '__inline' or nothing at all to say
a function should be inlined.
We could make 'configure' simply do a trial compile to figure out
which one, but for now, this approximation is easier:
*/
#if (!defined(__GNUC__))
#if (!defined(__inline__))
#if (defined(__sgi) || defined(_AIX) || defined(_MSC_VER))
#define __inline__ __inline
#else
#define __inline__
#endif
#endif
#endif
/* MSVCRT means we're using the Microsoft Visual C++ runtime library,
msvcrt.dll. Note that there are other DLLs in the suite, but only the
basic msvcrt.dll comes with Windows.
*/
#if defined(_MSC_VER)
/* The compiler is Microsoft Visual C++ */
#define MSVCRT _MSC_VER
#elif defined(__MINGW32__)
/* The compiler is Mingw, which is the Windows version of the GNU
compiler. Programs built with this normally use the Microsoft Visual
C++ runtime library, in addition to a small library with some of the
things a program would expect to find on a GNU system: libmingwex.a.
*/
#define MSVCRT 1
#else
#define MSVCRT 0
#endif
#if MSVCRT
/* The MSVC runtime library _does_ have a 'struct timeval', but it is
part of the Winsock interface (along with select(), which is probably
its intended use), so isn't intended for use for general timekeeping.
*/
#define HAVE_TIMEVAL 0
#define HAVE_TIMESPEC 0
#else
#define HAVE_TIMEVAL 1
/* timespec is Posix.1b. If we need to work on a non-Posix.1b non-Windows
system, we'll have to figure out how to make Configure determine this.
*/
#define HAVE_TIMESPEC 1
#endif
#if MSVCRT
#define HAVE_WINDOWS_THREAD 1
#else
#define HAVE_WINDOWS_THREAD 0
#endif
#define HAVE_PTHREAD 1
/* Note that the return value of XMLRPC_[V]SNPRINTF is int on Windows,
ssize_t on POSIX. On Windows, it is a return code; on POSIX, the size
of the complete string (regardless of how much of it got returned).
*/
#if MSVCRT
#define XMLRPC_SNPRINTF _snprintf
#define XMLRPC_VSNPRINTF _vsnprintf
#else
#define XMLRPC_SNPRINTF snprintf
#define XMLRPC_VSNPRINTF vsnprintf
#endif
#if MSVCRT
#define HAVE_REGEX 0
#else
#define HAVE_REGEX 1
#endif
#if MSVCRT
#define XMLRPC_SOCKETPAIR xmlrpc_win32_socketpair
#define XMLRPC_CLOSESOCKET closesocket
#else
#define XMLRPC_SOCKETPAIR socketpair
#define XMLRPC_CLOSESOCKET close
#endif
#if defined(_MSC_VER) && (_MSC_VER >= 1400)
/* Starting with MSVC 8, the runtime library defines various POSIX functions
such as strdup() whose names violate the ISO C standard (the standard
says the strXXX names are reserved for the standard), but warns you of
the standards violation. That warning is 4996, along with other warnings
that tell you you're using a function that Microsoft thinks you
shouldn't.
Well, POSIX is more important than that element of ISO C, so we disable
that warning.
FYI, msvcrt also defines _strdup(), etc, which doesn't violate the
naming standard. But since other environments don't define _strdup(),
we can't use it in portable code.
*/
#pragma warning(disable:4996)
#endif
#if HAVE_STRTOLL
# define XMLRPC_STRTOLL strtoll
#elif HAVE_STRTOQ
# define XMLRPC_STRTOLL strtoq /* Interix */
#elif HAVE___STRTOLL
# define XMLRPC_STRTOLL __strtoll /* HP-UX <= 11.11 */
#elif HAVE__STRTOUI64
#define XMLRPC_STRTOLL _strtoui64 /* Windows MSVC */
#endif
#if HAVE_STRTOULL
# define XMLRPC_STRTOULL strtoull
#elif HAVE_STRTOUQ
# define XMLRPC_STRTOULL strtouq /* Interix */
#elif HAVE___STRTOULL
# define XMLRPC_STRTOULL __strtoull /* HP-UX <= 11.11 */
#elif HAVE__STRTOUI64
#define XMLRPC_STRTOULL _strtoui64 /* Windows MSVC */
#endif
#if MSVCRT
#define popen _popen
#endif
/* S_IRUSR is POSIX, defined in <sys/stat.h> Some old BSD systems and Windows
systems have S_IREAD instead. Most Unix today (2011) has both. In 2011,
Android has S_IRUSR and not S_IREAD.
Some Windows has _S_IREAD.
We're ignoring S_IREAD now to see if anyone misses it. If there are still
users that need it, we can handle it here.
*/
#if MSVCRT
#define XMLRPC_S_IWUSR _S_IWRITE
#define XMLRPC_S_IRUSR _S_IREAD
#else
#define XMLRPC_S_IWUSR S_IWUSR
#define XMLRPC_S_IRUSR S_IRUSR
#endif
#if MSVCRT
#define XMLRPC_CHDIR _chdir
#else
#define XMLRPC_CHDIR chdir
#endif
#endif