X-Git-Url: http://git.meshlink.io/?a=blobdiff_plain;f=src%2Fcompat%2Fwindows%2Fwincompat.c;h=63f3e7de1469a6cc71a348c796aee6b7655763be;hb=f195c1bda3616129bc28d33aae71f9d2dd9047ce;hp=3e6417ef2d2115acf87b3fdc6640938393c076c3;hpb=5f7ef478c0571c3b833b4486bae73bd4b7ddbb3d;p=catta diff --git a/src/compat/windows/wincompat.c b/src/compat/windows/wincompat.c index 3e6417e..63f3e7d 100644 --- a/src/compat/windows/wincompat.c +++ b/src/compat/windows/wincompat.c @@ -3,6 +3,7 @@ #include #include #include +#include #include @@ -50,8 +51,10 @@ char *errnostrsocket(void) { static char buf[256]; + int err = WSAGetLastError(); + int len = snprintf(buf, sizeof(buf), "[%i] ", err); FormatMessage(FORMAT_MESSAGE_FROM_SYSTEM | FORMAT_MESSAGE_IGNORE_INSERTS, - NULL, WSAGetLastError(), 0, buf, sizeof(buf), NULL); + NULL, err, 0, buf + len, sizeof(buf) - len, NULL); return buf; } @@ -219,7 +222,7 @@ ssize_t sendmsg(int sockfd, const struct msghdr *msg, int flags) int ioctl(int d, unsigned long request, int *p) { - u_long arg = 0; + u_long arg = *p; if(ioctlsocket(d, request, &arg) == SOCKET_ERROR) { errno = wsa_errno(); @@ -237,11 +240,11 @@ int ioctl(int d, unsigned long request, int *p) int pipe(int pipefd[2]) { - int lsock = INVALID_SOCKET; + int lsock = (int)INVALID_SOCKET; struct sockaddr_in laddr; socklen_t laddrlen = sizeof(laddr); - pipefd[0] = pipefd[1] = INVALID_SOCKET; + pipefd[0] = pipefd[1] = (int)INVALID_SOCKET; // bind a listening socket to a TCP port on localhost laddr.sin_family = AF_INET; @@ -294,7 +297,8 @@ int uname(struct utsname *buf) strncpy(buf->version, "unknown", sizeof(buf->sysname)-1); // we don't need it // computer (node) name - if(GetComputerName(buf->nodename, sizeof(buf->nodename)-1) == 0) { + DWORD nodename_size = sizeof(buf->nodename)-1; + if(GetComputerName(buf->nodename, &nodename_size) == 0) { errno = EFAULT; return -1; }