From 1554c587b348f7ff957ad8b1d3023237a1c17fdd Mon Sep 17 00:00:00 2001 From: Benjamin Sergeant Date: Sun, 24 Mar 2019 21:48:14 -0700 Subject: [PATCH] update doc --- README.md | 9 +++++---- ws/README.md | 2 ++ 2 files changed, 7 insertions(+), 4 deletions(-) diff --git a/README.md b/README.md index b1035ce5..c6481931 100644 --- a/README.md +++ b/README.md @@ -4,14 +4,15 @@ ## Introduction -[*WebSocket*](https://en.wikipedia.org/wiki/WebSocket) is a computer communications protocol, providing full-duplex -communication channels over a single TCP connection. *IXWebSocket* is a C++ library for client and server Websocket communication, and for client HTTP communication. The code is derived from [easywsclient](https://github.com/dhbaird/easywsclient) and from the [Satori C SDK](https://github.com/satori-com/satori-rtm-sdk-c). It has been tested on the following platforms. +[*WebSocket*](https://en.wikipedia.org/wiki/WebSocket) is a computer communications protocol, providing full-duplex and bi-directionnal communication channels over a single TCP connection. *IXWebSocket* is a C++ library for client and server Websocket communication, and for client HTTP communication. The code is derived from [easywsclient](https://github.com/dhbaird/easywsclient) and from the [Satori C SDK](https://github.com/satori-com/satori-rtm-sdk-c). It has been tested on the following platforms. * macOS * iOS * Linux * Android +The code was made to compile once on Windows but support is currently broken on this platform. + ## Examples The [*ws*](https://github.com/machinezone/IXWebSocket/tree/master/ws) folder countains many interactive programs for chat, [file transfers](https://github.com/machinezone/IXWebSocket/blob/master/ws/ws_send.cpp), [curl like](https://github.com/machinezone/IXWebSocket/blob/master/ws/ws_http_client.cpp) http clients, demonstrating client and server usage. @@ -217,11 +218,11 @@ If the remote end (server) breaks the connection, the code will try to perpetual ### Large messages -Large frames are broken up into smaller chunks or messages to avoid filling up the os tcp buffers, which is permitted thanks to WebSocket [fragmentation](https://tools.ietf.org/html/rfc6455#section-5.4). Messages up to 500M were sent and received succesfully. +Large frames are broken up into smaller chunks or messages to avoid filling up the os tcp buffers, which is permitted thanks to WebSocket [fragmentation](https://tools.ietf.org/html/rfc6455#section-5.4). Messages up to 1G were sent and received succesfully. ## Limitations -* There is no text support for sending data, only the binary protocol is supported. Sending json or text over the binary protocol works well. +* No utf-8 validation is made when sending TEXT message with sendText() * Automatic reconnection works at the TCP socket level, and will detect remote end disconnects. However, if the device/computer network become unreachable (by turning off wifi), it is quite hard to reliably and timely detect it at the socket level using `recv` and `send` error codes. [Here](https://stackoverflow.com/questions/14782143/linux-socket-how-to-detect-disconnected-network-in-a-client-program) is a good discussion on the subject. This behavior is consistent with other runtimes such as node.js. One way to detect a disconnected device with low level C code is to do a name resolution with DNS but this can be expensive. Mobile devices have good and reliable API to do that. * The server code is using select to detect incoming data, and creates one OS thread per connection. This is not as scalable as strategies using epoll or kqueue. diff --git a/ws/README.md b/ws/README.md index 909e1438..c89ced06 100644 --- a/ws/README.md +++ b/ws/README.md @@ -20,6 +20,8 @@ Subcommands: broadcast_server Broadcasting server ping Ping pong curl HTTP Client + redis_publish Redis publisher + redis_subscribe Redis subscriber ``` ## file transfer