apu.h 4.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146
  1. /* Licensed to the Apache Software Foundation (ASF) under one or more
  2. * contributor license agreements. See the NOTICE file distributed with
  3. * this work for additional information regarding copyright ownership.
  4. * The ASF licenses this file to You under the Apache License, Version 2.0
  5. * (the "License"); you may not use this file except in compliance with
  6. * the License. You may obtain a copy of the License at
  7. *
  8. * http://www.apache.org/licenses/LICENSE-2.0
  9. *
  10. * Unless required by applicable law or agreed to in writing, software
  11. * distributed under the License is distributed on an "AS IS" BASIS,
  12. * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  13. * See the License for the specific language governing permissions and
  14. * limitations under the License.
  15. */
  16. /*
  17. * apu.h is duplicated from apu.hw at build time -- do not edit apu.h
  18. */
  19. /* @file apu.h
  20. * @brief APR-Utility main file
  21. */
  22. /**
  23. * @defgroup APR_Util APR Utility Functions
  24. * @{
  25. */
  26. #ifndef APU_H
  27. #define APU_H
  28. /**
  29. * APU_DECLARE_EXPORT is defined when building the APR-UTIL dynamic library,
  30. * so that all public symbols are exported.
  31. *
  32. * APU_DECLARE_STATIC is defined when including the APR-UTIL public headers,
  33. * to provide static linkage when the dynamic library may be unavailable.
  34. *
  35. * APU_DECLARE_STATIC and APU_DECLARE_EXPORT are left undefined when
  36. * including the APR-UTIL public headers, to import and link the symbols from
  37. * the dynamic APR-UTIL library and assure appropriate indirection and calling
  38. * conventions at compile time.
  39. */
  40. /* Make sure we have our platform identifier macro defined we ask for later.
  41. */
  42. #if defined(_WIN32) && !defined(WIN32)
  43. #define WIN32 1
  44. #endif
  45. #if defined(DOXYGEN) || !defined(WIN32)
  46. /**
  47. * The public APR-UTIL functions are declared with APU_DECLARE(), so they may
  48. * use the most appropriate calling convention. Public APR functions with
  49. * variable arguments must use APU_DECLARE_NONSTD().
  50. *
  51. * @fn APU_DECLARE(rettype) apr_func(args);
  52. */
  53. #define APU_DECLARE(type) type
  54. /**
  55. * The public APR-UTIL functions using variable arguments are declared with
  56. * APU_DECLARE_NONSTD(), as they must use the C language calling convention.
  57. *
  58. * @fn APU_DECLARE_NONSTD(rettype) apr_func(args, ...);
  59. */
  60. #define APU_DECLARE_NONSTD(type) type
  61. /**
  62. * The public APR-UTIL variables are declared with APU_DECLARE_DATA.
  63. * This assures the appropriate indirection is invoked at compile time.
  64. *
  65. * @fn APU_DECLARE_DATA type apr_variable;
  66. * @note extern APU_DECLARE_DATA type apr_variable; syntax is required for
  67. * declarations within headers to properly import the variable.
  68. */
  69. #define APU_DECLARE_DATA
  70. #elif defined(APU_DECLARE_STATIC)
  71. #define APU_DECLARE(type) type __stdcall
  72. #define APU_DECLARE_NONSTD(type) type __cdecl
  73. #define APU_DECLARE_DATA
  74. #elif defined(APU_DECLARE_EXPORT)
  75. #define APU_DECLARE(type) __declspec(dllexport) type __stdcall
  76. #define APU_DECLARE_NONSTD(type) __declspec(dllexport) type __cdecl
  77. #define APU_DECLARE_DATA __declspec(dllexport)
  78. #else
  79. #define APU_DECLARE(type) __declspec(dllimport) type __stdcall
  80. #define APU_DECLARE_NONSTD(type) __declspec(dllimport) type __cdecl
  81. #define APU_DECLARE_DATA __declspec(dllimport)
  82. #endif
  83. #if !defined(WIN32) || defined(APU_MODULE_DECLARE_STATIC)
  84. /**
  85. * Declare a dso module's exported module structure as APU_MODULE_DECLARE_DATA.
  86. *
  87. * Unless APU_MODULE_DECLARE_STATIC is defined at compile time, symbols
  88. * declared with APU_MODULE_DECLARE_DATA are always exported.
  89. * @code
  90. * module APU_MODULE_DECLARE_DATA mod_tag
  91. * @endcode
  92. */
  93. #define APU_MODULE_DECLARE_DATA
  94. #else
  95. #define APU_MODULE_DECLARE_DATA __declspec(dllexport)
  96. #endif
  97. /*
  98. * we always have SDBM (it's in our codebase)
  99. */
  100. #define APU_HAVE_SDBM 1
  101. #ifndef APU_DSO_MODULE_BUILD
  102. #define APU_HAVE_GDBM 0
  103. #define APU_HAVE_NDBM 0
  104. #define APU_HAVE_DB 0
  105. #if APU_HAVE_DB
  106. #define APU_HAVE_DB_VERSION 0
  107. #endif
  108. #endif
  109. /*
  110. * we always enable dynamic driver loads within apr_dbd
  111. * Win32 always has odbc (it's always installed)
  112. */
  113. #ifndef APU_DSO_MODULE_BUILD
  114. #define APU_HAVE_PGSQL 0
  115. #define APU_HAVE_MYSQL 0
  116. #define APU_HAVE_SQLITE3 0
  117. #define APU_HAVE_SQLITE2 0
  118. #define APU_HAVE_ORACLE 0
  119. #define APU_HAVE_ODBC 1
  120. #endif
  121. #define APU_HAVE_CRYPTO 1
  122. #ifndef APU_DSO_MODULE_BUILD
  123. #define APU_HAVE_OPENSSL 1
  124. #define APU_HAVE_NSS 0
  125. #define APU_HAVE_COMMONCRYPTO 0
  126. #endif
  127. #define APU_HAVE_APR_ICONV 1
  128. #define APU_HAVE_ICONV 0
  129. #define APR_HAS_XLATE (APU_HAVE_APR_ICONV || APU_HAVE_ICONV)
  130. #endif /* APU_H */
  131. /** @} */