curl_setup.h 28 KB

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