[or-cvs] r10889: Bufferevent working on windows. Todo: Test Unix part of cros (in libevent-urz/trunk: . loaders sample)
Urz at seul.org
Urz at seul.org
Fri Jul 20 03:30:38 UTC 2007
Author: Urz
Date: 2007-07-19 23:30:38 -0400 (Thu, 19 Jul 2007)
New Revision: 10889
Modified:
libevent-urz/trunk/evbuffer.c
libevent-urz/trunk/event.h
libevent-urz/trunk/loaders/IOCPloader.c
libevent-urz/trunk/sample/crossplat-bufferevent-test.c
libevent-urz/trunk/win_evbuffer.c
Log:
Bufferevent working on windows. Todo: Test Unix part of cross platform socket implementation, Close/Free&Close implementations
Modified: libevent-urz/trunk/evbuffer.c
===================================================================
--- libevent-urz/trunk/evbuffer.c 2007-07-19 20:47:18 UTC (rev 10888)
+++ libevent-urz/trunk/evbuffer.c 2007-07-20 03:30:38 UTC (rev 10889)
@@ -56,8 +56,8 @@
return socket(AF_INET, SOCK_STREAM, 0);
}
// connect
-int bufev_socket_connect(struct bufferevent *bufev, struct sockaddr_in *addr) {
- return connect(bufev->fd, (struct sockaddr*)addr, sizeof(addr));
+int bufev_socket_connect(int sock, struct sockaddr_in *addr) {
+ return connect(sock, (struct sockaddr*)addr, sizeof(addr));
}
// accept
struct bufferevent *bufev_socket_accept(int listen_sock, evbuffercb readcb, evbuffercb writecb, everrorcb errorcb, void *cbarg) {
Modified: libevent-urz/trunk/event.h
===================================================================
--- libevent-urz/trunk/event.h 2007-07-19 20:47:18 UTC (rev 10888)
+++ libevent-urz/trunk/event.h 2007-07-20 03:30:38 UTC (rev 10889)
@@ -276,10 +276,39 @@
short enabled; /* events that are currently enabled */
};
+/*
+ * Documentation for the below is rough, but should be complete
+ *
+ * int bufev_socket_new(void);
+ * Creates a new socket which is compatible with the local implementation
+ * of bufferevents. The return value is only required to fit in the same
+ * space as an int, it is not required to actually *be* an int.
+ * Regardless the true return type, (int) -1 is a reserved value which
+ * means creating a new socket failed.
+ *
+ * int bufev_socket_connect(int sock, struct sockaddr_in *addr);
+ * Connects a socket to an internet address. Returns -1 on failure,
+ * 0 on success.
+ *
+ * struct bufferevent *bufev_socket_accept(int listen_sock, evbuffercb readcb, evbuffercb writecb, everrorcb errorcb, void *cbarg);
+ * listen_sock is a listening socket (see bufev_socket_listen).
+ * all other arguments are as bufferevent_new().
+ * Takes one connection off the pending connection queue for a listening socket and
+ * creates a new bufferevent based on the connection.
+ *
+ * int bufev_socket_listen(int sock, int backlog);
+ * Sets a socket (created with bufev_socket_new()) to listen. The socket must first be bound
+ * (with bufev_socket_bind()). Returns 0 on success, -1 on failure.
+ *
+ * int bufev_socket_bind(int sock, struct sockaddr_in *bind_to);
+ * Binds a socket (created with bufev_socket_new()) to a particular internet address.
+ * returns 0 on success, -1 on failure.
+ */
+
//socket
int bufev_socket_new(void);
// connect
-int bufev_socket_connect(struct bufferevent *bufev, struct sockaddr_in *addr);
+int bufev_socket_connect(int sock, struct sockaddr_in *addr);
// accept
struct bufferevent *bufev_socket_accept(int listen_sock, evbuffercb readcb, evbuffercb writecb, everrorcb errorcb, void *cbarg);
// listen
@@ -287,6 +316,11 @@
// bind
int bufev_socket_bind(int sock, struct sockaddr_in *bind_to);
+/*
+ * Note: bufferevent_new must only be called with *connected* bufev_sockets.
+ * attempting to create a new bufferevent with a disconnected bufev_socket may
+ * fail and it may fail silently.
+ */
struct bufferevent *bufferevent_new(int fd,
evbuffercb readcb, evbuffercb writecb, everrorcb errorcb, void *cbarg);
int bufferevent_base_set(struct event_base *base, struct bufferevent *bufev);
Modified: libevent-urz/trunk/loaders/IOCPloader.c
===================================================================
--- libevent-urz/trunk/loaders/IOCPloader.c 2007-07-19 20:47:18 UTC (rev 10888)
+++ libevent-urz/trunk/loaders/IOCPloader.c 2007-07-20 03:30:38 UTC (rev 10889)
@@ -270,7 +270,7 @@
if(CompletedOverlapped->op == OP_SEND) {
// the connection has sent all data and is ready for more
SendComplete(Conn, CompleteSize);
- printf("s");
+ //printf("s");
} else if(CompletedOverlapped->op == OP_RECV) {
// Now we have a completed read event, perform the operations
// required on the read data.
@@ -279,7 +279,7 @@
// Now the data has been removed from the WSABUF, we can reset the
// read to continue reading.
ResetRead(Conn);
- printf("r");
+ //printf("r");
}
ev_unlock(Conn->lock);
}
Modified: libevent-urz/trunk/sample/crossplat-bufferevent-test.c
===================================================================
--- libevent-urz/trunk/sample/crossplat-bufferevent-test.c 2007-07-19 20:47:18 UTC (rev 10888)
+++ libevent-urz/trunk/sample/crossplat-bufferevent-test.c 2007-07-20 03:30:38 UTC (rev 10889)
@@ -221,12 +221,13 @@
Connect = bufev_socket_new();
printf("Connect = %d\n", (int) Connect);
+
+ printf("Connecting...\n");
+ bufev_socket_connect(Connect, &socketAddr);
printf("Creating Bufferevent\n");
csabe = bufferevent_new(Connect, connector_on_read, NULL, NULL, NULL);
- printf("Connecting...\n");
- bufev_socket_connect(csabe, &socketAddr);
printf("Connected.\n");
Modified: libevent-urz/trunk/win_evbuffer.c
===================================================================
--- libevent-urz/trunk/win_evbuffer.c 2007-07-19 20:47:18 UTC (rev 10888)
+++ libevent-urz/trunk/win_evbuffer.c 2007-07-20 03:30:38 UTC (rev 10889)
@@ -23,10 +23,10 @@
return (int) ret;
}
// connect
-int bufev_socket_connect(struct bufferevent *bufev, struct sockaddr_in *addr) {
+int bufev_socket_connect(int sock, struct sockaddr_in *addr) {
int ret;
- printf("Connecting with %d\n", (SOCKET)(((struct sa_bufferevent *)bufev)->connection_handle));
- ret = connect((SOCKET)(((struct sa_bufferevent *)bufev)->connection_handle), (struct sockaddr*)addr, sizeof(struct sockaddr_in));
+ printf("Connecting with %d\n", sock);
+ ret = connect((SOCKET) sock, (struct sockaddr*)addr, sizeof(struct sockaddr_in));
if(ret == SOCKET_ERROR) {
printf("Connecting failed with error %d\n", (int) GetLastError());
return -1;
More information about the tor-commits
mailing list