aboutsummaryrefslogtreecommitdiff
path: root/docs/code/tcp-echo-server/main.c
diff options
context:
space:
mode:
authorBernardo Ramos <berna.gensis@gmail.com>2017-05-26 14:14:36 +0000
committercjihrig <cjihrig@gmail.com>2017-05-29 13:24:30 -0400
commitce770a6c3bc88f11913b1a4067b9c026b63723e1 (patch)
tree11aa9f1a0a45edba546ff7e668ffe82b874cf53b /docs/code/tcp-echo-server/main.c
parentdc596109d5a22db1dbf57098630eebd30fce8068 (diff)
downloadlibuv-ce770a6c3bc88f11913b1a4067b9c026b63723e1.tar.gz
libuv-ce770a6c3bc88f11913b1a4067b9c026b63723e1.zip
doc: fix memory leak in tcp-echo-server example
Fixes: https://github.com/libuv/help/issues/4 PR-URL: https://github.com/libuv/libuv/pull/1363 Reviewed-By: Ben Noordhuis <info@bnoordhuis.nl> Reviewed-By: Colin Ihrig <cjihrig@gmail.com>
Diffstat (limited to 'docs/code/tcp-echo-server/main.c')
-rw-r--r--docs/code/tcp-echo-server/main.c8
1 files changed, 6 insertions, 2 deletions
diff --git a/docs/code/tcp-echo-server/main.c b/docs/code/tcp-echo-server/main.c
index 63965bd9..5d7b4993 100644
--- a/docs/code/tcp-echo-server/main.c
+++ b/docs/code/tcp-echo-server/main.c
@@ -25,6 +25,10 @@ void alloc_buffer(uv_handle_t *handle, size_t suggested_size, uv_buf_t *buf) {
buf->len = suggested_size;
}
+void on_close(uv_handle_t* handle) {
+ free(handle);
+}
+
void echo_write(uv_write_t *req, int status) {
if (status) {
fprintf(stderr, "Write error %s\n", uv_strerror(status));
@@ -42,7 +46,7 @@ void echo_read(uv_stream_t *client, ssize_t nread, const uv_buf_t *buf) {
if (nread < 0) {
if (nread != UV_EOF)
fprintf(stderr, "Read error %s\n", uv_err_name(nread));
- uv_close((uv_handle_t*) client, NULL);
+ uv_close((uv_handle_t*) client, on_close);
}
free(buf->base);
@@ -61,7 +65,7 @@ void on_new_connection(uv_stream_t *server, int status) {
uv_read_start((uv_stream_t*) client, alloc_buffer, echo_read);
}
else {
- uv_close((uv_handle_t*) client, NULL);
+ uv_close((uv_handle_t*) client, on_close);
}
}