curl_setup.h 24 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883
  1. #ifndef HEADER_CURL_SETUP_H
  2. #define HEADER_CURL_SETUP_H
  3. /***************************************************************************
  4. * _ _ ____ _
  5. * Project ___| | | | _ \| |
  6. * / __| | | | |_) | |
  7. * | (__| |_| | _ <| |___
  8. * \___|\___/|_| \_\_____|
  9. *
  10. * Copyright (C) Daniel Stenberg, <[email protected]>, et al.
  11. *
  12. * This software is licensed as described in the file COPYING, which
  13. * you should have received as part of this distribution. The terms
  14. * are also available at https://curl.se/docs/copyright.html.
  15. *
  16. * You may opt to use, copy, modify, merge, publish, distribute and/or sell
  17. * copies of the Software, and permit persons to whom the Software is
  18. * furnished to do so, under the terms of the COPYING file.
  19. *
  20. * This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
  21. * KIND, either express or implied.
  22. *
  23. * SPDX-License-Identifier: curl
  24. *
  25. ***************************************************************************/
  26. #if defined(BUILDING_LIBCURL) && !defined(CURL_NO_OLDIES)
  27. #define CURL_NO_OLDIES
  28. #endif
  29. /* FIXME: Delete this once the warnings have been fixed. */
  30. #if !defined(CURL_WARN_SIGN_CONVERSION)
  31. #ifdef __GNUC__
  32. #pragma GCC diagnostic ignored "-Wsign-conversion"
  33. #endif
  34. #endif
  35. /* Set default _WIN32_WINNT */
  36. #ifdef __MINGW32__
  37. #include <_mingw.h>
  38. #endif
  39. /*
  40. * Disable Visual Studio warnings:
  41. * 4127 "conditional expression is constant"
  42. */
  43. #ifdef _MSC_VER
  44. #pragma warning(disable:4127)
  45. #endif
  46. #ifdef _WIN32
  47. /*
  48. * Don't include unneeded stuff in Windows headers to avoid compiler
  49. * warnings and macro clashes.
  50. * Make sure to define this macro before including any Windows headers.
  51. */
  52. # ifndef WIN32_LEAN_AND_MEAN
  53. # define WIN32_LEAN_AND_MEAN
  54. # endif
  55. # ifndef NOGDI
  56. # define NOGDI
  57. # endif
  58. /* Detect Windows App environment which has a restricted access
  59. * to the Win32 APIs. */
  60. # if (defined(_WIN32_WINNT) && (_WIN32_WINNT >= 0x0602)) || \
  61. defined(WINAPI_FAMILY)
  62. # include <winapifamily.h>
  63. # if WINAPI_FAMILY_PARTITION(WINAPI_PARTITION_APP) && \
  64. !WINAPI_FAMILY_PARTITION(WINAPI_PARTITION_DESKTOP)
  65. # define CURL_WINDOWS_APP
  66. # endif
  67. # endif
  68. #endif
  69. /*
  70. * Include configuration script results or hand-crafted
  71. * configuration file for platforms which lack config tool.
  72. */
  73. #ifdef HAVE_CONFIG_H
  74. #include "curl_config.h"
  75. #else /* HAVE_CONFIG_H */
  76. #ifdef _WIN32_WCE
  77. # include "config-win32ce.h"
  78. #else
  79. # ifdef _WIN32
  80. # include "config-win32.h"
  81. # endif
  82. #endif
  83. #ifdef macintosh
  84. # include "config-mac.h"
  85. #endif
  86. #ifdef __riscos__
  87. # include "config-riscos.h"
  88. #endif
  89. #ifdef __AMIGA__
  90. # include "config-amigaos.h"
  91. #endif
  92. #ifdef __OS400__
  93. # include "config-os400.h"
  94. #endif
  95. #ifdef __PLAN9__
  96. # include "config-plan9.h"
  97. #endif
  98. #ifdef MSDOS
  99. # include "config-dos.h"
  100. #endif
  101. #endif /* HAVE_CONFIG_H */
  102. #if defined(_MSC_VER)
  103. # pragma warning(push,1)
  104. #endif
  105. /* ================================================================ */
  106. /* Definition of preprocessor macros/symbols which modify compiler */
  107. /* behavior or generated code characteristics must be done here, */
  108. /* as appropriate, before any system header file is included. It is */
  109. /* also possible to have them defined in the config file included */
  110. /* before this point. As a result of all this we frown inclusion of */
  111. /* system header files in our config files, avoid this at any cost. */
  112. /* ================================================================ */
  113. /*
  114. * AIX 4.3 and newer needs _THREAD_SAFE defined to build
  115. * proper reentrant code. Others may also need it.
  116. */
  117. #ifdef NEED_THREAD_SAFE
  118. # ifndef _THREAD_SAFE
  119. # define _THREAD_SAFE
  120. # endif
  121. #endif
  122. /*
  123. * Tru64 needs _REENTRANT set for a few function prototypes and
  124. * things to appear in the system header files. Unixware needs it
  125. * to build proper reentrant code. Others may also need it.
  126. */
  127. #ifdef NEED_REENTRANT
  128. # ifndef _REENTRANT
  129. # define _REENTRANT
  130. # endif
  131. #endif
  132. /* Solaris needs this to get a POSIX-conformant getpwuid_r */
  133. #if defined(sun) || defined(__sun)
  134. # ifndef _POSIX_PTHREAD_SEMANTICS
  135. # define _POSIX_PTHREAD_SEMANTICS 1
  136. # endif
  137. #endif
  138. /* ================================================================ */
  139. /* If you need to include a system header file for your platform, */
  140. /* please, do it beyond the point further indicated in this file. */
  141. /* ================================================================ */
  142. /*
  143. * Disable other protocols when http is the only one desired.
  144. */
  145. #ifdef HTTP_ONLY
  146. # ifndef CURL_DISABLE_DICT
  147. # define CURL_DISABLE_DICT
  148. # endif
  149. # ifndef CURL_DISABLE_FILE
  150. # define CURL_DISABLE_FILE
  151. # endif
  152. # ifndef CURL_DISABLE_FTP
  153. # define CURL_DISABLE_FTP
  154. # endif
  155. # ifndef CURL_DISABLE_GOPHER
  156. # define CURL_DISABLE_GOPHER
  157. # endif
  158. # ifndef CURL_DISABLE_IMAP
  159. # define CURL_DISABLE_IMAP
  160. # endif
  161. # ifndef CURL_DISABLE_LDAP
  162. # define CURL_DISABLE_LDAP
  163. # endif
  164. # ifndef CURL_DISABLE_LDAPS
  165. # define CURL_DISABLE_LDAPS
  166. # endif
  167. # ifndef CURL_DISABLE_MQTT
  168. # define CURL_DISABLE_MQTT
  169. # endif
  170. # ifndef CURL_DISABLE_POP3
  171. # define CURL_DISABLE_POP3
  172. # endif
  173. # ifndef CURL_DISABLE_RTSP
  174. # define CURL_DISABLE_RTSP
  175. # endif
  176. # ifndef CURL_DISABLE_SMB
  177. # define CURL_DISABLE_SMB
  178. # endif
  179. # ifndef CURL_DISABLE_SMTP
  180. # define CURL_DISABLE_SMTP
  181. # endif
  182. # ifndef CURL_DISABLE_TELNET
  183. # define CURL_DISABLE_TELNET
  184. # endif
  185. # ifndef CURL_DISABLE_TFTP
  186. # define CURL_DISABLE_TFTP
  187. # endif
  188. #endif
  189. /*
  190. * When http is disabled rtsp is not supported.
  191. */
  192. #if defined(CURL_DISABLE_HTTP) && !defined(CURL_DISABLE_RTSP)
  193. # define CURL_DISABLE_RTSP
  194. #endif
  195. /*
  196. * When HTTP is disabled, disable HTTP-only features
  197. */
  198. #if defined(CURL_DISABLE_HTTP)
  199. # define CURL_DISABLE_ALTSVC 1
  200. # define CURL_DISABLE_COOKIES 1
  201. # define CURL_DISABLE_BASIC_AUTH 1
  202. # define CURL_DISABLE_BEARER_AUTH 1
  203. # define CURL_DISABLE_AWS 1
  204. # define CURL_DISABLE_DOH 1
  205. # define CURL_DISABLE_FORM_API 1
  206. # define CURL_DISABLE_HEADERS_API 1
  207. # define CURL_DISABLE_HSTS 1
  208. # define CURL_DISABLE_HTTP_AUTH 1
  209. #endif
  210. /* ================================================================ */
  211. /* No system header file shall be included in this file before this */
  212. /* point. */
  213. /* ================================================================ */
  214. /*
  215. * OS/400 setup file includes some system headers.
  216. */
  217. #ifdef __OS400__
  218. # include "setup-os400.h"
  219. #endif
  220. /*
  221. * VMS setup file includes some system headers.
  222. */
  223. #ifdef __VMS
  224. # include "setup-vms.h"
  225. #endif
  226. /*
  227. * Windows setup file includes some system headers.
  228. */
  229. #ifdef _WIN32
  230. # include "setup-win32.h"
  231. #endif
  232. #include <curl/system.h>
  233. /* curl uses its own printf() function internally. It understands the GNU
  234. * format. Use this format, so that is matches the GNU format attribute we
  235. * use with the mingw compiler, allowing it to verify them at compile-time.
  236. */
  237. #ifdef __MINGW32__
  238. # undef CURL_FORMAT_CURL_OFF_T
  239. # undef CURL_FORMAT_CURL_OFF_TU
  240. # define CURL_FORMAT_CURL_OFF_T "lld"
  241. # define CURL_FORMAT_CURL_OFF_TU "llu"
  242. #endif
  243. /* based on logic in "curl/mprintf.h" */
  244. #if (defined(__GNUC__) || defined(__clang__)) && \
  245. defined(__STDC_VERSION__) && (__STDC_VERSION__ >= 199901L) && \
  246. !defined(CURL_NO_FMT_CHECKS)
  247. #if defined(__MINGW32__) && !defined(__clang__)
  248. #define CURL_PRINTF(fmt, arg) \
  249. __attribute__((format(gnu_printf, fmt, arg)))
  250. #else
  251. #define CURL_PRINTF(fmt, arg) \
  252. __attribute__((format(__printf__, fmt, arg)))
  253. #endif
  254. #else
  255. #define CURL_PRINTF(fmt, arg)
  256. #endif
  257. /*
  258. * Use getaddrinfo to resolve the IPv4 address literal. If the current network
  259. * interface doesn't support IPv4, but supports IPv6, NAT64, and DNS64,
  260. * performing this task will result in a synthesized IPv6 address.
  261. */
  262. #if defined(__APPLE__) && !defined(USE_ARES)
  263. #include <TargetConditionals.h>
  264. #define USE_RESOLVE_ON_IPS 1
  265. # if TARGET_OS_MAC && !(defined(TARGET_OS_IPHONE) && TARGET_OS_IPHONE) && \
  266. defined(ENABLE_IPV6)
  267. # define CURL_MACOS_CALL_COPYPROXIES 1
  268. # endif
  269. #endif
  270. #ifdef USE_LWIPSOCK
  271. # include <lwip/init.h>
  272. # include <lwip/sockets.h>
  273. # include <lwip/netdb.h>
  274. #endif
  275. #ifdef HAVE_EXTRA_STRICMP_H
  276. # include <extra/stricmp.h>
  277. #endif
  278. #ifdef HAVE_EXTRA_STRDUP_H
  279. # include <extra/strdup.h>
  280. #endif
  281. #ifdef __AMIGA__
  282. # ifdef __amigaos4__
  283. # define __USE_INLINE__
  284. /* use our own resolver which uses runtime feature detection */
  285. # define CURLRES_AMIGA
  286. /* getaddrinfo() currently crashes bsdsocket.library, so disable */
  287. # undef HAVE_GETADDRINFO
  288. # if !(defined(__NEWLIB__) || \
  289. (defined(__CLIB2__) && defined(__THREAD_SAFE)))
  290. /* disable threaded resolver with clib2 - requires newlib or clib-ts */
  291. # undef USE_THREADS_POSIX
  292. # endif
  293. # endif
  294. # include <exec/types.h>
  295. # include <exec/execbase.h>
  296. # include <proto/exec.h>
  297. # include <proto/dos.h>
  298. # include <unistd.h>
  299. # if defined(HAVE_PROTO_BSDSOCKET_H) && \
  300. (!defined(__amigaos4__) || defined(USE_AMISSL))
  301. /* use bsdsocket.library directly, instead of libc networking functions */
  302. # define _SYS_MBUF_H /* m_len define clashes with curl */
  303. # include <proto/bsdsocket.h>
  304. # ifdef __amigaos4__
  305. int Curl_amiga_select(int nfds, fd_set *readfds, fd_set *writefds,
  306. fd_set *errorfds, struct timeval *timeout);
  307. # define select(a,b,c,d,e) Curl_amiga_select(a,b,c,d,e)
  308. # else
  309. # define select(a,b,c,d,e) WaitSelect(a,b,c,d,e,0)
  310. # endif
  311. /* must not use libc's fcntl() on bsdsocket.library sockfds! */
  312. # undef HAVE_FCNTL
  313. # undef HAVE_FCNTL_O_NONBLOCK
  314. # else
  315. /* use libc networking and hence close() and fnctl() */
  316. # undef HAVE_CLOSESOCKET_CAMEL
  317. # undef HAVE_IOCTLSOCKET_CAMEL
  318. # endif
  319. /*
  320. * In clib2 arpa/inet.h warns that some prototypes may clash
  321. * with bsdsocket.library. This avoids the definition of those.
  322. */
  323. # define __NO_NET_API
  324. #endif
  325. #include <stdio.h>
  326. #include <assert.h>
  327. #ifdef __TANDEM /* for ns*-tandem-nsk systems */
  328. # if ! defined __LP64
  329. # include <floss.h> /* FLOSS is only used for 32-bit builds. */
  330. # endif
  331. #endif
  332. #ifndef STDC_HEADERS /* no standard C headers! */
  333. #include <curl/stdcheaders.h>
  334. #endif
  335. /* Default Windows file API selection. */
  336. #ifdef _WIN32
  337. # if defined(_MSC_VER) && (_INTEGRAL_MAX_BITS >= 64)
  338. # define USE_WIN32_LARGE_FILES
  339. # elif defined(__MINGW32__)
  340. # define USE_WIN32_LARGE_FILES
  341. # else
  342. # define USE_WIN32_SMALL_FILES
  343. # endif
  344. #endif
  345. /*
  346. * Large file (>2Gb) support using WIN32 functions.
  347. */
  348. #ifdef USE_WIN32_LARGE_FILES
  349. # include <io.h>
  350. # include <sys/types.h>
  351. # include <sys/stat.h>
  352. # undef lseek
  353. # define lseek(fdes,offset,whence) _lseeki64(fdes, offset, whence)
  354. # undef fstat
  355. # define fstat(fdes,stp) _fstati64(fdes, stp)
  356. # undef stat
  357. # define stat(fname,stp) curlx_win32_stat(fname, stp)
  358. # define struct_stat struct _stati64
  359. # define LSEEK_ERROR (__int64)-1
  360. # define open curlx_win32_open
  361. # define fopen(fname,mode) curlx_win32_fopen(fname, mode)
  362. # define access(fname,mode) curlx_win32_access(fname, mode)
  363. int curlx_win32_open(const char *filename, int oflag, ...);
  364. int curlx_win32_stat(const char *path, struct_stat *buffer);
  365. FILE *curlx_win32_fopen(const char *filename, const char *mode);
  366. int curlx_win32_access(const char *path, int mode);
  367. #endif
  368. /*
  369. * Small file (<2Gb) support using WIN32 functions.
  370. */
  371. #ifdef USE_WIN32_SMALL_FILES
  372. # include <io.h>
  373. # include <sys/types.h>
  374. # include <sys/stat.h>
  375. # ifndef _WIN32_WCE
  376. # undef lseek
  377. # define lseek(fdes,offset,whence) _lseek(fdes, (long)offset, whence)
  378. # define fstat(fdes,stp) _fstat(fdes, stp)
  379. # define stat(fname,stp) curlx_win32_stat(fname, stp)
  380. # define struct_stat struct _stat
  381. # define open curlx_win32_open
  382. # define fopen(fname,mode) curlx_win32_fopen(fname, mode)
  383. # define access(fname,mode) curlx_win32_access(fname, mode)
  384. int curlx_win32_stat(const char *path, struct_stat *buffer);
  385. int curlx_win32_open(const char *filename, int oflag, ...);
  386. FILE *curlx_win32_fopen(const char *filename, const char *mode);
  387. int curlx_win32_access(const char *path, int mode);
  388. # endif
  389. # define LSEEK_ERROR (long)-1
  390. #endif
  391. #ifndef struct_stat
  392. # define struct_stat struct stat
  393. #endif
  394. #ifndef LSEEK_ERROR
  395. # define LSEEK_ERROR (off_t)-1
  396. #endif
  397. #ifndef SIZEOF_TIME_T
  398. /* assume default size of time_t to be 32 bit */
  399. #define SIZEOF_TIME_T 4
  400. #endif
  401. #ifndef SIZEOF_CURL_SOCKET_T
  402. /* configure and cmake check and set the define */
  403. # ifdef _WIN64
  404. # define SIZEOF_CURL_SOCKET_T 8
  405. # else
  406. /* default guess */
  407. # define SIZEOF_CURL_SOCKET_T 4
  408. # endif
  409. #endif
  410. #if SIZEOF_CURL_SOCKET_T < 8
  411. # define CURL_FORMAT_SOCKET_T "d"
  412. #elif defined(__MINGW32__)
  413. # define CURL_FORMAT_SOCKET_T "zd"
  414. #else
  415. # define CURL_FORMAT_SOCKET_T "qd"
  416. #endif
  417. /*
  418. * Default sizeof(off_t) in case it hasn't been defined in config file.
  419. */
  420. #ifndef SIZEOF_OFF_T
  421. # if defined(__VMS) && !defined(__VAX)
  422. # if defined(_LARGEFILE)
  423. # define SIZEOF_OFF_T 8
  424. # endif
  425. # elif defined(__OS400__) && defined(__ILEC400__)
  426. # if defined(_LARGE_FILES)
  427. # define SIZEOF_OFF_T 8
  428. # endif
  429. # elif defined(__MVS__) && defined(__IBMC__)
  430. # if defined(_LP64) || defined(_LARGE_FILES)
  431. # define SIZEOF_OFF_T 8
  432. # endif
  433. # elif defined(__370__) && defined(__IBMC__)
  434. # if defined(_LP64) || defined(_LARGE_FILES)
  435. # define SIZEOF_OFF_T 8
  436. # endif
  437. # endif
  438. # ifndef SIZEOF_OFF_T
  439. # define SIZEOF_OFF_T 4
  440. # endif
  441. #endif
  442. #if (SIZEOF_CURL_OFF_T < 8)
  443. #error "too small curl_off_t"
  444. #else
  445. /* assume SIZEOF_CURL_OFF_T == 8 */
  446. # define CURL_OFF_T_MAX CURL_OFF_T_C(0x7FFFFFFFFFFFFFFF)
  447. #endif
  448. #define CURL_OFF_T_MIN (-CURL_OFF_T_MAX - CURL_OFF_T_C(1))
  449. #if (SIZEOF_TIME_T == 4)
  450. # ifdef HAVE_TIME_T_UNSIGNED
  451. # define TIME_T_MAX UINT_MAX
  452. # define TIME_T_MIN 0
  453. # else
  454. # define TIME_T_MAX INT_MAX
  455. # define TIME_T_MIN INT_MIN
  456. # endif
  457. #else
  458. # ifdef HAVE_TIME_T_UNSIGNED
  459. # define TIME_T_MAX 0xFFFFFFFFFFFFFFFF
  460. # define TIME_T_MIN 0
  461. # else
  462. # define TIME_T_MAX 0x7FFFFFFFFFFFFFFF
  463. # define TIME_T_MIN (-TIME_T_MAX - 1)
  464. # endif
  465. #endif
  466. #ifndef SIZE_T_MAX
  467. /* some limits.h headers have this defined, some don't */
  468. #if defined(SIZEOF_SIZE_T) && (SIZEOF_SIZE_T > 4)
  469. #define SIZE_T_MAX 18446744073709551615U
  470. #else
  471. #define SIZE_T_MAX 4294967295U
  472. #endif
  473. #endif
  474. #ifndef SSIZE_T_MAX
  475. /* some limits.h headers have this defined, some don't */
  476. #if defined(SIZEOF_SIZE_T) && (SIZEOF_SIZE_T > 4)
  477. #define SSIZE_T_MAX 9223372036854775807
  478. #else
  479. #define SSIZE_T_MAX 2147483647
  480. #endif
  481. #endif
  482. /*
  483. * Arg 2 type for gethostname in case it hasn't been defined in config file.
  484. */
  485. #ifndef GETHOSTNAME_TYPE_ARG2
  486. # ifdef USE_WINSOCK
  487. # define GETHOSTNAME_TYPE_ARG2 int
  488. # else
  489. # define GETHOSTNAME_TYPE_ARG2 size_t
  490. # endif
  491. #endif
  492. /* Below we define some functions. They should
  493. 4. set the SIGALRM signal timeout
  494. 5. set dir/file naming defines
  495. */
  496. #ifdef _WIN32
  497. # define DIR_CHAR "\\"
  498. #else /* _WIN32 */
  499. # ifdef MSDOS /* Watt-32 */
  500. # include <sys/ioctl.h>
  501. # define select(n,r,w,x,t) select_s(n,r,w,x,t)
  502. # define ioctl(x,y,z) ioctlsocket(x,y,(char *)(z))
  503. # include <tcp.h>
  504. # ifdef word
  505. # undef word
  506. # endif
  507. # ifdef byte
  508. # undef byte
  509. # endif
  510. # endif /* MSDOS */
  511. # ifdef __minix
  512. /* Minix 3 versions up to at least 3.1.3 are missing these prototypes */
  513. extern char *strtok_r(char *s, const char *delim, char **last);
  514. extern struct tm *gmtime_r(const time_t * const timep, struct tm *tmp);
  515. # endif
  516. # define DIR_CHAR "/"
  517. #endif /* _WIN32 */
  518. /* ---------------------------------------------------------------- */
  519. /* resolver specialty compile-time defines */
  520. /* CURLRES_* defines to use in the host*.c sources */
  521. /* ---------------------------------------------------------------- */
  522. /*
  523. * MSVC threads support requires a multi-threaded runtime library.
  524. * _beginthreadex() is not available in single-threaded ones.
  525. */
  526. #if defined(_MSC_VER) && !defined(_MT)
  527. # undef USE_THREADS_POSIX
  528. # undef USE_THREADS_WIN32
  529. #endif
  530. /*
  531. * Mutually exclusive CURLRES_* definitions.
  532. */
  533. #if defined(ENABLE_IPV6) && defined(HAVE_GETADDRINFO)
  534. # define CURLRES_IPV6
  535. #elif defined(ENABLE_IPV6) && (defined(_WIN32) || defined(__CYGWIN__))
  536. /* assume on Windows that IPv6 without getaddrinfo is a broken build */
  537. # error "Unexpected build: IPv6 is enabled but getaddrinfo was not found."
  538. #else
  539. # define CURLRES_IPV4
  540. #endif
  541. #ifdef USE_ARES
  542. # define CURLRES_ASYNCH
  543. # define CURLRES_ARES
  544. /* now undef the stock libc functions just to avoid them being used */
  545. # undef HAVE_GETADDRINFO
  546. # undef HAVE_FREEADDRINFO
  547. #elif defined(USE_THREADS_POSIX) || defined(USE_THREADS_WIN32)
  548. # define CURLRES_ASYNCH
  549. # define CURLRES_THREADED
  550. #else
  551. # define CURLRES_SYNCH
  552. #endif
  553. /* ---------------------------------------------------------------- */
  554. #if defined(HAVE_LIBIDN2) && defined(HAVE_IDN2_H) && !defined(USE_WIN32_IDN)
  555. /* The lib and header are present */
  556. #define USE_LIBIDN2
  557. #endif
  558. #if defined(USE_LIBIDN2) && defined(USE_WIN32_IDN)
  559. #error "Both libidn2 and WinIDN are enabled, choose one."
  560. #endif
  561. #define LIBIDN_REQUIRED_VERSION "0.4.1"
  562. #if defined(USE_GNUTLS) || defined(USE_OPENSSL) || defined(USE_MBEDTLS) || \
  563. defined(USE_WOLFSSL) || defined(USE_SCHANNEL) || defined(USE_SECTRANSP) || \
  564. defined(USE_BEARSSL) || defined(USE_RUSTLS)
  565. #define USE_SSL /* SSL support has been enabled */
  566. #endif
  567. /* Single point where USE_SPNEGO definition might be defined */
  568. #if !defined(CURL_DISABLE_NEGOTIATE_AUTH) && \
  569. (defined(HAVE_GSSAPI) || defined(USE_WINDOWS_SSPI))
  570. #define USE_SPNEGO
  571. #endif
  572. /* Single point where USE_KERBEROS5 definition might be defined */
  573. #if !defined(CURL_DISABLE_KERBEROS_AUTH) && \
  574. (defined(HAVE_GSSAPI) || defined(USE_WINDOWS_SSPI))
  575. #define USE_KERBEROS5
  576. #endif
  577. /* Single point where USE_NTLM definition might be defined */
  578. #if !defined(CURL_DISABLE_NTLM)
  579. # if defined(USE_OPENSSL) || defined(USE_MBEDTLS) || \
  580. defined(USE_GNUTLS) || defined(USE_SECTRANSP) || \
  581. defined(USE_OS400CRYPTO) || defined(USE_WIN32_CRYPTO) || \
  582. (defined(USE_WOLFSSL) && defined(HAVE_WOLFSSL_DES_ECB_ENCRYPT))
  583. # define USE_CURL_NTLM_CORE
  584. # endif
  585. # if defined(USE_CURL_NTLM_CORE) || defined(USE_WINDOWS_SSPI)
  586. # define USE_NTLM
  587. # endif
  588. #endif
  589. #ifdef CURL_WANTS_CA_BUNDLE_ENV
  590. #error "No longer supported. Set CURLOPT_CAINFO at runtime instead."
  591. #endif
  592. #if defined(USE_LIBSSH2) || defined(USE_LIBSSH) || defined(USE_WOLFSSH)
  593. #define USE_SSH
  594. #endif
  595. /*
  596. * Provide a mechanism to silence picky compilers, such as gcc 4.6+.
  597. * Parameters should of course normally not be unused, but for example when
  598. * we have multiple implementations of the same interface it may happen.
  599. */
  600. #if defined(__GNUC__) && ((__GNUC__ >= 3) || \
  601. ((__GNUC__ == 2) && defined(__GNUC_MINOR__) && (__GNUC_MINOR__ >= 7)))
  602. # define UNUSED_PARAM __attribute__((__unused__))
  603. # define WARN_UNUSED_RESULT __attribute__((warn_unused_result))
  604. #else
  605. # define UNUSED_PARAM /* NOTHING */
  606. # define WARN_UNUSED_RESULT
  607. #endif
  608. /* noreturn attribute */
  609. #if !defined(CURL_NORETURN)
  610. #if (defined(__GNUC__) && (__GNUC__ >= 3)) || defined(__clang__)
  611. # define CURL_NORETURN __attribute__((__noreturn__))
  612. #elif defined(_MSC_VER) && (_MSC_VER >= 1200)
  613. # define CURL_NORETURN __declspec(noreturn)
  614. #else
  615. # define CURL_NORETURN
  616. #endif
  617. #endif
  618. /* fallthrough attribute */
  619. #if !defined(FALLTHROUGH)
  620. #if (defined(__GNUC__) && __GNUC__ >= 7) || \
  621. (defined(__clang__) && __clang_major__ >= 10)
  622. # define FALLTHROUGH() __attribute__((fallthrough))
  623. #else
  624. # define FALLTHROUGH() do {} while (0)
  625. #endif
  626. #endif
  627. /*
  628. * Include macros and defines that should only be processed once.
  629. */
  630. #ifndef HEADER_CURL_SETUP_ONCE_H
  631. #include "curl_setup_once.h"
  632. #endif
  633. /*
  634. * Definition of our NOP statement Object-like macro
  635. */
  636. #ifndef Curl_nop_stmt
  637. # define Curl_nop_stmt do { } while(0)
  638. #endif
  639. /*
  640. * Ensure that Winsock and lwIP TCP/IP stacks are not mixed.
  641. */
  642. #if defined(__LWIP_OPT_H__) || defined(LWIP_HDR_OPT_H)
  643. # if defined(SOCKET) || defined(USE_WINSOCK)
  644. # error "WinSock and lwIP TCP/IP stack definitions shall not coexist!"
  645. # endif
  646. #endif
  647. /*
  648. * shutdown() flags for systems that don't define them
  649. */
  650. #ifndef SHUT_RD
  651. #define SHUT_RD 0x00
  652. #endif
  653. #ifndef SHUT_WR
  654. #define SHUT_WR 0x01
  655. #endif
  656. #ifndef SHUT_RDWR
  657. #define SHUT_RDWR 0x02
  658. #endif
  659. /* Define S_ISREG if not defined by system headers, e.g. MSVC */
  660. #if !defined(S_ISREG) && defined(S_IFMT) && defined(S_IFREG)
  661. #define S_ISREG(m) (((m) & S_IFMT) == S_IFREG)
  662. #endif
  663. /* Define S_ISDIR if not defined by system headers, e.g. MSVC */
  664. #if !defined(S_ISDIR) && defined(S_IFMT) && defined(S_IFDIR)
  665. #define S_ISDIR(m) (((m) & S_IFMT) == S_IFDIR)
  666. #endif
  667. /* In Windows the default file mode is text but an application can override it.
  668. Therefore we specify it explicitly. https://github.com/curl/curl/pull/258
  669. */
  670. #if defined(_WIN32) || defined(MSDOS)
  671. #define FOPEN_READTEXT "rt"
  672. #define FOPEN_WRITETEXT "wt"
  673. #define FOPEN_APPENDTEXT "at"
  674. #elif defined(__CYGWIN__)
  675. /* Cygwin has specific behavior we need to address when WIN32 is not defined.
  676. https://cygwin.com/cygwin-ug-net/using-textbinary.html
  677. For write we want our output to have line endings of LF and be compatible with
  678. other Cygwin utilities. For read we want to handle input that may have line
  679. endings either CRLF or LF so 't' is appropriate.
  680. */
  681. #define FOPEN_READTEXT "rt"
  682. #define FOPEN_WRITETEXT "w"
  683. #define FOPEN_APPENDTEXT "a"
  684. #else
  685. #define FOPEN_READTEXT "r"
  686. #define FOPEN_WRITETEXT "w"
  687. #define FOPEN_APPENDTEXT "a"
  688. #endif
  689. /* for systems that don't detect this in configure */
  690. #ifndef CURL_SA_FAMILY_T
  691. # if defined(HAVE_SA_FAMILY_T)
  692. # define CURL_SA_FAMILY_T sa_family_t
  693. # elif defined(HAVE_ADDRESS_FAMILY)
  694. # define CURL_SA_FAMILY_T ADDRESS_FAMILY
  695. # else
  696. /* use a sensible default */
  697. # define CURL_SA_FAMILY_T unsigned short
  698. # endif
  699. #endif
  700. /* Some convenience macros to get the larger/smaller value out of two given.
  701. We prefix with CURL to prevent name collisions. */
  702. #define CURLMAX(x,y) ((x)>(y)?(x):(y))
  703. #define CURLMIN(x,y) ((x)<(y)?(x):(y))
  704. /* A convenience macro to provide both the string literal and the length of
  705. the string literal in one go, useful for functions that take "string,len"
  706. as their argument */
  707. #define STRCONST(x) x,sizeof(x)-1
  708. /* Some versions of the Android SDK is missing the declaration */
  709. #if defined(HAVE_GETPWUID_R) && defined(HAVE_DECL_GETPWUID_R_MISSING)
  710. struct passwd;
  711. int getpwuid_r(uid_t uid, struct passwd *pwd, char *buf,
  712. size_t buflen, struct passwd **result);
  713. #endif
  714. #ifdef DEBUGBUILD
  715. #define UNITTEST
  716. #else
  717. #define UNITTEST static
  718. #endif
  719. /* Hyper supports HTTP2 also, but Curl's integration with Hyper does not */
  720. #if defined(USE_NGHTTP2)
  721. #define USE_HTTP2
  722. #endif
  723. #if (defined(USE_NGTCP2) && defined(USE_NGHTTP3)) || \
  724. (defined(USE_OPENSSL_QUIC) && defined(USE_NGHTTP3)) || \
  725. defined(USE_QUICHE) || defined(USE_MSH3)
  726. #ifdef CURL_WITH_MULTI_SSL
  727. #error "Multi-SSL combined with QUIC is not supported"
  728. #endif
  729. #define ENABLE_QUIC
  730. #define USE_HTTP3
  731. #endif
  732. /* Certain Windows implementations are not aligned with what curl expects,
  733. so always use the local one on this platform. E.g. the mingw-w64
  734. implementation can return wrong results for non-ASCII inputs. */
  735. #if defined(HAVE_BASENAME) && defined(_WIN32)
  736. #undef HAVE_BASENAME
  737. #endif
  738. #if defined(USE_UNIX_SOCKETS) && defined(_WIN32)
  739. # if !defined(UNIX_PATH_MAX)
  740. /* Replicating logic present in afunix.h
  741. (distributed with newer Windows 10 SDK versions only) */
  742. # define UNIX_PATH_MAX 108
  743. /* !checksrc! disable TYPEDEFSTRUCT 1 */
  744. typedef struct sockaddr_un {
  745. ADDRESS_FAMILY sun_family;
  746. char sun_path[UNIX_PATH_MAX];
  747. } SOCKADDR_UN, *PSOCKADDR_UN;
  748. # define WIN32_SOCKADDR_UN
  749. # endif
  750. #endif
  751. /* OpenSSLv3 marks DES, MD5 and ENGINE functions deprecated but we have no
  752. replacements (yet) so tell the compiler to not warn for them. */
  753. #ifdef USE_OPENSSL
  754. #define OPENSSL_SUPPRESS_DEPRECATED
  755. #endif
  756. #endif /* HEADER_CURL_SETUP_H */