Skip to content

Commit

Permalink
Return actual socket errors on Windows.
Browse files Browse the repository at this point in the history
  • Loading branch information
gitlarryf committed Dec 15, 2023
1 parent e98b114 commit 8734c6a
Show file tree
Hide file tree
Showing 3 changed files with 45 additions and 9 deletions.
24 changes: 20 additions & 4 deletions exec/cnex/lib/net.c
Original file line number Diff line number Diff line change
Expand Up @@ -250,9 +250,15 @@ void net_socket_recv(TExecutor *exec)
fatal_error("Could not allocate %d bytes for socket_recv().", n);
}
int r = recv(s, (char*)buf, n, 0);
if (r == SOCKET_ERROR) {
if (WSAGetLastError() == WSAEWOULDBLOCK) {
assert("Socket would block!");
}
}
if (r < 0) {

perror("recv");
int err = errno;
int err = WSAGetLastError();
Cell *ret = cell_createArrayCell(2);
Cell *t = cell_arrayIndexForWrite(ret, 0);
t->type = cNumber;
Expand Down Expand Up @@ -308,6 +314,11 @@ void net_socket_select(TExecutor *exec)
Cell *write = peek(exec->stack, 1)->address;
Cell *read = peek(exec->stack, 2)->address;

//Cell *error = top(exec->stack)->address; pop(exec->stack);
//Cell *write = top(exec->stack)->address; pop(exec->stack);
//Cell *read = top(exec->stack)->address; pop(exec->stack);


fd_set rfds, wfds, efds;
FD_ZERO(&rfds);
FD_ZERO(&wfds);
Expand Down Expand Up @@ -375,6 +386,9 @@ void net_socket_select(TExecutor *exec)
array_clearArray(read->array);
array_clearArray(write->array);
array_clearArray(error->array);
pop(exec->stack);
pop(exec->stack);
pop(exec->stack);
push(exec->stack, cell_fromBoolean(FALSE));
return;
}
Expand All @@ -392,7 +406,7 @@ void net_socket_select(TExecutor *exec)
for (size_t i = 0; i < write->array->size; ) {
SOCKET *ps = check_socket(exec, write->array->data[i].array->data[0].object);
SOCKET fd = *ps;
if (FD_ISSET(fd, &rfds)) {
if (FD_ISSET(fd, &wfds)) {
++i;
} else {
array_removeItem(write->array, i);
Expand All @@ -402,12 +416,14 @@ void net_socket_select(TExecutor *exec)
for (size_t i = 0; i < error->array->size; ) {
SOCKET *ps = check_socket(exec, error->array->data[i].array->data[0].object);
SOCKET fd = *ps;
if (FD_ISSET(fd, &rfds)) {
if (FD_ISSET(fd, &efds)) {
++i;
} else {
array_removeItem(error->array, i);
}
}

//pop(exec->stack);
//pop(exec->stack);
//pop(exec->stack);
push(exec->stack, cell_fromBoolean(TRUE));
}
28 changes: 23 additions & 5 deletions lib/net.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,26 @@

// https://wiki.openssl.org/index.php/SSL/TLS_Client

static std::string socket_error(int err)
{
static char msgbuf[256] = { '\0' };
#ifdef _WIN32
FormatMessage(FORMAT_MESSAGE_FROM_SYSTEM | FORMAT_MESSAGE_IGNORE_INSERTS,
NULL,
err,
MAKELANGID(LANG_NEUTRAL, SUBLANG_DEFAULT),
msgbuf,
sizeof(msgbuf),
NULL);
#else
snprintf(msgbuf, sizeof(msgbuf), "%s", strerror(err));
#endif
if (msgbuf[0] == '\0') {
snprintf(msgbuf, sizeof(msgbuf), "(No Error Text) - %d", err);
}
return std::string(msgbuf);
}

class SocketObject: public Object {
public:
SocketObject() {}
Expand Down Expand Up @@ -133,9 +153,8 @@ class RawSocketObject: public SocketObject {
std::vector<unsigned char> buffer(n);
int r = ::recv(handle, reinterpret_cast<char *>(const_cast<unsigned char *>(buffer.data())), n, 0);
if (r < 0) {
int err = errno;
perror("recv");
return Cell(std::vector<Cell> {Cell(number_from_uint32(CHOICE_RecvResult_error)), Cell(utf8string(strerror(err)))});
int err = socketerror;
return Cell(std::vector<Cell> {Cell(number_from_uint32(CHOICE_RecvResult_error)), Cell(utf8string(socket_error(err)))});
}
if (r == 0) {
return Cell(std::vector<Cell> {Cell(number_from_uint32(CHOICE_RecvResult_eof))});
Expand All @@ -150,8 +169,7 @@ class RawSocketObject: public SocketObject {
socklen_t sin_len = sizeof(sin);
int r = ::recvfrom(handle, reinterpret_cast<char *>(const_cast<unsigned char *>(buffer.data())), n, 0, reinterpret_cast<sockaddr *>(&sin), &sin_len);
if (r < 0) {
int err = errno;
perror("recvfrom");
int err = socketerror;
return Cell(std::vector<Cell> {Cell(number_from_uint32(CHOICE_RecvFromResult_error)), Cell(utf8string(strerror(err)))});
}
if (r == 0) {
Expand Down
2 changes: 2 additions & 0 deletions src/socketx.h
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,7 @@
#include <winsock.h>
typedef int socklen_t;
#pragma warning(disable: 4127) // incompatible with FD_SET()
#define socketerror WSAGetLastError()

#else

Expand All @@ -15,5 +16,6 @@ typedef int socklen_t;
typedef int SOCKET;
const int INVALID_SOCKET = -1;
inline void closesocket(int x) { close(x); }
#define socketerror errno

#endif

0 comments on commit 8734c6a

Please sign in to comment.