mirror of
https://git.tartarus.org/simon/putty.git
synced 2025-01-10 09:58:01 +00:00
Fixes for winelib building (used by our Coverity build).
Avoided referring to some functions and header files that aren't there in the winelib world (_vsnprintf, _stricmp, SecureZeroMemory, multimon.h), and worked around a really amazingly annoying issue in which Winelib objects to you using the type 'fd_set' unless you included winsock2.h before stdlib.h.
This commit is contained in:
parent
bec33b2311
commit
991d30412d
2
misc.c
2
misc.c
@ -406,7 +406,7 @@ static char *dupvprintf_inner(char *buf, int oldlen, int oldsize,
|
|||||||
}
|
}
|
||||||
|
|
||||||
while (1) {
|
while (1) {
|
||||||
#if defined _WINDOWS && _MSC_VER < 1900 /* 1900 == VS2015 has real snprintf */
|
#if defined _WINDOWS && !defined __WINE__ && _MSC_VER < 1900 /* 1900 == VS2015 has real snprintf */
|
||||||
#define vsnprintf _vsnprintf
|
#define vsnprintf _vsnprintf
|
||||||
#endif
|
#endif
|
||||||
#ifdef va_copy
|
#ifdef va_copy
|
||||||
|
@ -10,6 +10,10 @@
|
|||||||
#include <limits.h>
|
#include <limits.h>
|
||||||
#include <assert.h>
|
#include <assert.h>
|
||||||
|
|
||||||
|
#ifdef __WINE__
|
||||||
|
#define NO_MULTIMON /* winelib doesn't have this */
|
||||||
|
#endif
|
||||||
|
|
||||||
#ifndef NO_MULTIMON
|
#ifndef NO_MULTIMON
|
||||||
#define COMPILE_MULTIMON_STUBS
|
#define COMPILE_MULTIMON_STUBS
|
||||||
#endif
|
#endif
|
||||||
|
@ -5,11 +5,15 @@
|
|||||||
* unfix.org.
|
* unfix.org.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#include <winsock2.h> /* need to put this first, for winelib builds */
|
||||||
|
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include <assert.h>
|
#include <assert.h>
|
||||||
|
|
||||||
#define DEFINE_PLUG_METHOD_MACROS
|
#define DEFINE_PLUG_METHOD_MACROS
|
||||||
|
#define NEED_DECLARATION_OF_SELECT /* in order to initialise it */
|
||||||
|
|
||||||
#include "putty.h"
|
#include "putty.h"
|
||||||
#include "network.h"
|
#include "network.h"
|
||||||
#include "tree234.h"
|
#include "tree234.h"
|
||||||
@ -236,6 +240,13 @@ int sk_startup(int hi, int lo)
|
|||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* Actually define this function pointer, which won't have been
|
||||||
|
* defined alongside all the others by PUTTY_DO_GLOBALS because of the
|
||||||
|
* annoying winelib header-ordering issue. (See comment in winstuff.h.) */
|
||||||
|
DECL_WINDOWS_FUNCTION(/* empty */, int, select,
|
||||||
|
(int, fd_set FAR *, fd_set FAR *,
|
||||||
|
fd_set FAR *, const struct timeval FAR *));
|
||||||
|
|
||||||
void sk_init(void)
|
void sk_init(void)
|
||||||
{
|
{
|
||||||
#ifndef NO_IPV6
|
#ifndef NO_IPV6
|
||||||
|
@ -2,8 +2,11 @@
|
|||||||
* winsftp.c: the Windows-specific parts of PSFTP and PSCP.
|
* winsftp.c: the Windows-specific parts of PSFTP and PSCP.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#include <winsock2.h> /* need to put this first, for winelib builds */
|
||||||
#include <assert.h>
|
#include <assert.h>
|
||||||
|
|
||||||
|
#define NEED_DECLARATION_OF_SELECT
|
||||||
|
|
||||||
#include "putty.h"
|
#include "putty.h"
|
||||||
#include "psftp.h"
|
#include "psftp.h"
|
||||||
#include "ssh.h"
|
#include "ssh.h"
|
||||||
|
@ -89,14 +89,25 @@ struct FontSpec *fontspec_new(const char *name,
|
|||||||
#define BOXRESULT (DLGWINDOWEXTRA + sizeof(LONG_PTR))
|
#define BOXRESULT (DLGWINDOWEXTRA + sizeof(LONG_PTR))
|
||||||
#define DF_END 0x0001
|
#define DF_END 0x0001
|
||||||
|
|
||||||
|
#ifdef __WINE__
|
||||||
|
#define NO_SECUREZEROMEMORY /* winelib doesn't have this */
|
||||||
|
#endif
|
||||||
|
|
||||||
#ifndef NO_SECUREZEROMEMORY
|
#ifndef NO_SECUREZEROMEMORY
|
||||||
#define PLATFORM_HAS_SMEMCLR /* inhibit cross-platform one in misc.c */
|
#define PLATFORM_HAS_SMEMCLR /* inhibit cross-platform one in misc.c */
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#ifndef __WINE__
|
||||||
/* Up-to-date Windows headers warn that the unprefixed versions of
|
/* Up-to-date Windows headers warn that the unprefixed versions of
|
||||||
* these names are deprecated. */
|
* these names are deprecated. */
|
||||||
#define stricmp _stricmp
|
#define stricmp _stricmp
|
||||||
#define strnicmp _strnicmp
|
#define strnicmp _strnicmp
|
||||||
|
#else
|
||||||
|
/* Compiling with winegcc, _neither_ version of these functions
|
||||||
|
* exists. Use the POSIX names. */
|
||||||
|
#define stricmp strcasecmp
|
||||||
|
#define strnicmp strncasecmp
|
||||||
|
#endif
|
||||||
|
|
||||||
#define BROKEN_PIPE_ERROR_CODE ERROR_BROKEN_PIPE /* used in sshshare.c */
|
#define BROKEN_PIPE_ERROR_CODE ERROR_BROKEN_PIPE /* used in sshshare.c */
|
||||||
|
|
||||||
@ -276,12 +287,21 @@ DECL_WINDOWS_FUNCTION(GLOBAL, int, WSAAsyncSelect,
|
|||||||
(SOCKET, HWND, u_int, long));
|
(SOCKET, HWND, u_int, long));
|
||||||
DECL_WINDOWS_FUNCTION(GLOBAL, int, WSAEventSelect,
|
DECL_WINDOWS_FUNCTION(GLOBAL, int, WSAEventSelect,
|
||||||
(SOCKET, WSAEVENT, long));
|
(SOCKET, WSAEVENT, long));
|
||||||
DECL_WINDOWS_FUNCTION(GLOBAL, int, select,
|
|
||||||
(int, fd_set FAR *, fd_set FAR *,
|
|
||||||
fd_set FAR *, const struct timeval FAR *));
|
|
||||||
DECL_WINDOWS_FUNCTION(GLOBAL, int, WSAGetLastError, (void));
|
DECL_WINDOWS_FUNCTION(GLOBAL, int, WSAGetLastError, (void));
|
||||||
DECL_WINDOWS_FUNCTION(GLOBAL, int, WSAEnumNetworkEvents,
|
DECL_WINDOWS_FUNCTION(GLOBAL, int, WSAEnumNetworkEvents,
|
||||||
(SOCKET, WSAEVENT, LPWSANETWORKEVENTS));
|
(SOCKET, WSAEVENT, LPWSANETWORKEVENTS));
|
||||||
|
#ifdef NEED_DECLARATION_OF_SELECT
|
||||||
|
/* This declaration is protected by an ifdef for the sake of building
|
||||||
|
* against winelib, in which you have to include winsock2.h before
|
||||||
|
* stdlib.h so that the right fd_set type gets defined. It would be a
|
||||||
|
* pain to do that throughout this codebase, so instead I arrange that
|
||||||
|
* only a modules actually needing to use (or define, or initialise)
|
||||||
|
* this function pointer will see its declaration, and _those_ modules
|
||||||
|
* - which will be Windows-specific anyway - can take more care. */
|
||||||
|
DECL_WINDOWS_FUNCTION(GLOBAL, int, select,
|
||||||
|
(int, fd_set FAR *, fd_set FAR *,
|
||||||
|
fd_set FAR *, const struct timeval FAR *));
|
||||||
|
#endif
|
||||||
|
|
||||||
extern int socket_writable(SOCKET skt);
|
extern int socket_writable(SOCKET skt);
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user