defs.h 7.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224
  1. /*
  2. * defs.h: initial definitions for PuTTY.
  3. *
  4. * The rule about this header file is that it can't depend on any
  5. * other header file in this code base. This is where we define
  6. * things, as much as we can, that other headers will want to refer
  7. * to, such as opaque structure types and their associated typedefs,
  8. * or macros that are used by other headers.
  9. */
  10. #ifndef PUTTY_DEFS_H
  11. #define PUTTY_DEFS_H
  12. #include <stddef.h>
  13. #include <stdint.h>
  14. #include <stdio.h> /* for __MINGW_PRINTF_FORMAT */
  15. #include <stdbool.h>
  16. #if (!defined WINSCP) && defined _MSC_VER && _MSC_VER < 1800
  17. /* Work around lack of inttypes.h and strtoumax in older MSVC */
  18. #define PRIx32 "x"
  19. #define PRIu32 "u"
  20. #define PRIu64 "I64u"
  21. #define PRIdMAX "I64d"
  22. #define PRIXMAX "I64X"
  23. #define SCNu64 "I64u"
  24. #define SIZEx "Ix"
  25. #define SIZEu "Iu"
  26. uintmax_t strtoumax(const char *nptr, char **endptr, int base);
  27. #else
  28. #ifndef WINSCP
  29. // Not needed by the code WinSCP uses
  30. #include <inttypes.h>
  31. #endif
  32. /* Because we still support older MSVC libraries which don't recognise the
  33. * standard C "z" modifier for size_t-sized integers, we must use an
  34. * inttypes.h-style macro for those */
  35. #define SIZEx "zx"
  36. #define SIZEu "zu"
  37. #endif
  38. #if defined __GNUC__ || defined __clang__
  39. /*
  40. * On MinGW, the correct compiler format checking for vsnprintf() etc
  41. * can depend on compile-time flags; these control whether you get
  42. * ISO C or Microsoft's non-standard format strings.
  43. * We sometimes use __attribute__ ((format)) for our own printf-like
  44. * functions, which are ultimately interpreted by the toolchain-chosen
  45. * printf, so we need to take that into account to get correct warnings.
  46. */
  47. #ifdef __MINGW_PRINTF_FORMAT
  48. #define PRINTF_LIKE(fmt_index, ellipsis_index) \
  49. __attribute__ ((format (__MINGW_PRINTF_FORMAT, fmt_index, ellipsis_index)))
  50. #else
  51. #define PRINTF_LIKE(fmt_index, ellipsis_index) \
  52. __attribute__ ((format (printf, fmt_index, ellipsis_index)))
  53. #endif
  54. #else /* __GNUC__ */
  55. #define PRINTF_LIKE(fmt_index, ellipsis_index)
  56. #endif /* __GNUC__ */
  57. typedef struct conf_tag Conf;
  58. typedef struct terminal_tag Terminal;
  59. typedef struct term_utf8_decode term_utf8_decode;
  60. typedef struct Filename Filename;
  61. typedef struct FontSpec FontSpec;
  62. typedef struct bufchain_tag bufchain;
  63. typedef struct strbuf strbuf;
  64. typedef struct LoadedFile LoadedFile;
  65. typedef struct RSAKey RSAKey;
  66. typedef struct BinarySink BinarySink;
  67. typedef struct BinarySource BinarySource;
  68. typedef struct stdio_sink stdio_sink;
  69. typedef struct bufchain_sink bufchain_sink;
  70. typedef struct handle_sink handle_sink;
  71. typedef struct IdempotentCallback IdempotentCallback;
  72. typedef struct SockAddr SockAddr;
  73. typedef struct Socket Socket;
  74. typedef struct Plug Plug;
  75. typedef struct SocketPeerInfo SocketPeerInfo;
  76. typedef struct Backend Backend;
  77. typedef struct BackendVtable BackendVtable;
  78. typedef struct Ldisc_tag Ldisc;
  79. typedef struct LogContext LogContext;
  80. typedef struct LogPolicy LogPolicy;
  81. typedef struct LogPolicyVtable LogPolicyVtable;
  82. typedef struct Seat Seat;
  83. typedef struct SeatVtable SeatVtable;
  84. typedef struct TermWin TermWin;
  85. typedef struct TermWinVtable TermWinVtable;
  86. typedef struct Ssh Ssh;
  87. typedef struct mp_int mp_int;
  88. typedef struct MontyContext MontyContext;
  89. typedef struct WeierstrassCurve WeierstrassCurve;
  90. typedef struct WeierstrassPoint WeierstrassPoint;
  91. typedef struct MontgomeryCurve MontgomeryCurve;
  92. typedef struct MontgomeryPoint MontgomeryPoint;
  93. typedef struct EdwardsCurve EdwardsCurve;
  94. typedef struct EdwardsPoint EdwardsPoint;
  95. typedef struct SshServerConfig SshServerConfig;
  96. typedef struct SftpServer SftpServer;
  97. typedef struct SftpServerVtable SftpServerVtable;
  98. typedef struct Channel Channel;
  99. typedef struct SshChannel SshChannel;
  100. typedef struct mainchan mainchan;
  101. typedef struct ssh_sharing_state ssh_sharing_state;
  102. typedef struct ssh_sharing_connstate ssh_sharing_connstate;
  103. typedef struct share_channel share_channel;
  104. typedef struct PortFwdManager PortFwdManager;
  105. typedef struct PortFwdRecord PortFwdRecord;
  106. typedef struct ConnectionLayer ConnectionLayer;
  107. typedef struct prng prng;
  108. typedef struct ssh_hashalg ssh_hashalg;
  109. typedef struct ssh_hash ssh_hash;
  110. typedef struct ssh_kex ssh_kex;
  111. typedef struct ssh_kexes ssh_kexes;
  112. typedef struct ssh_keyalg ssh_keyalg;
  113. typedef struct ssh_key ssh_key;
  114. typedef struct ssh_compressor ssh_compressor;
  115. typedef struct ssh_decompressor ssh_decompressor;
  116. typedef struct ssh_compression_alg ssh_compression_alg;
  117. typedef struct ssh2_userkey ssh2_userkey;
  118. typedef struct ssh2_macalg ssh2_macalg;
  119. typedef struct ssh2_mac ssh2_mac;
  120. typedef struct ssh_cipheralg ssh_cipheralg;
  121. typedef struct ssh_cipher ssh_cipher;
  122. typedef struct ssh2_ciphers ssh2_ciphers;
  123. typedef struct dh_ctx dh_ctx;
  124. typedef struct ecdh_key ecdh_key;
  125. typedef struct dlgparam dlgparam;
  126. typedef struct settings_w settings_w;
  127. typedef struct settings_r settings_r;
  128. typedef struct settings_e settings_e;
  129. typedef struct SessionSpecial SessionSpecial;
  130. typedef struct StripCtrlChars StripCtrlChars;
  131. /*
  132. * A small structure wrapping up a (pointer, length) pair so that it
  133. * can be conveniently passed to or from a function.
  134. */
  135. typedef struct ptrlen {
  136. const void *ptr;
  137. size_t len;
  138. } ptrlen;
  139. typedef struct logblank_t logblank_t;
  140. typedef struct BinaryPacketProtocol BinaryPacketProtocol;
  141. typedef struct PacketProtocolLayer PacketProtocolLayer;
  142. /* Do a compile-time type-check of 'to_check' (without evaluating it),
  143. * as a side effect of returning the value 'to_return'. Note that
  144. * although this macro double-*expands* to_return, it always
  145. * *evaluates* exactly one copy of it, so it's side-effect safe. */
  146. #define TYPECHECK(to_check, to_return) \
  147. (sizeof(to_check) ? (to_return) : (to_return))
  148. /* Return a pointer to the object of structure type 'type' whose field
  149. * with name 'field' is pointed at by 'object'. */
  150. #define container_of(object, type, field) \
  151. TYPECHECK(object == &((type *)0)->field, \
  152. ((type *)(((char *)(object)) - offsetof(type, field))))
  153. #if defined __GNUC__ || defined __clang__
  154. #define NORETURN __attribute__((__noreturn__))
  155. #elif defined _MSC_VER
  156. #define NORETURN __declspec(noreturn)
  157. #else
  158. #define NORETURN
  159. #endif
  160. /* ----------------------------------------------------------------------
  161. * Platform-specific definitions.
  162. *
  163. * Most of these live in the per-platform header files, of which
  164. * puttyps.h selects the appropriate one. But some of the sources
  165. * (particularly standalone test applications) would prefer not to
  166. * have to include a per-platform header at all, because that makes it
  167. * more portable to platforms not supported by the code base as a
  168. * whole (for example, compiling purely computational parts of the
  169. * code for specialist platforms for test and analysis purposes). So
  170. * any definition that has to affect even _those_ modules will have to
  171. * go here, with the key constraint being that this code has to come
  172. * to _some_ decision even if the compilation platform is not a
  173. * recognised one at all.
  174. */
  175. /* Purely computational code uses smemclr(), so we have to make the
  176. * decision here about whether that's provided by utils.c or by a
  177. * platform implementation. We define PLATFORM_HAS_SMEMCLR to suppress
  178. * utils.c's definition. */
  179. #ifdef _WINDOWS
  180. /* Windows provides the API function 'SecureZeroMemory', which we use
  181. * unless the user has told us not to by defining NO_SECUREZEROMEMORY. */
  182. #ifndef NO_SECUREZEROMEMORY
  183. #define PLATFORM_HAS_SMEMCLR
  184. #endif
  185. #endif
  186. #endif /* PUTTY_DEFS_H */