[c5c522c] | 1 | From: Aron Xu <aron@debian.org> |
---|
| 2 | Date: Tue, 14 Feb 2012 23:02:00 +0800 |
---|
| 3 | Subject: serialized handling multiple clients |
---|
| 4 | |
---|
| 5 | --- |
---|
| 6 | netcat.c | 39 +++++++++++++++++++-------------------- |
---|
| 7 | 1 file changed, 19 insertions(+), 20 deletions(-) |
---|
| 8 | |
---|
| 9 | diff --git a/netcat.c b/netcat.c |
---|
| 10 | index 56cc15e..bf9940f 100644 |
---|
| 11 | --- a/netcat.c |
---|
| 12 | +++ b/netcat.c |
---|
| 13 | @@ -447,26 +447,24 @@ main(int argc, char *argv[]) |
---|
| 14 | s = unix_bind(host); |
---|
| 15 | else |
---|
| 16 | s = unix_listen(host); |
---|
| 17 | - } |
---|
| 18 | + } else |
---|
| 19 | + s = local_listen(host, uport, hints); |
---|
| 20 | + if (s < 0) |
---|
| 21 | + err(1, NULL); |
---|
| 22 | + |
---|
| 23 | + char* local; |
---|
| 24 | + if (family == AF_INET6) |
---|
| 25 | + local = ":::"; |
---|
| 26 | + else |
---|
| 27 | + local = "0.0.0.0"; |
---|
| 28 | + fprintf(stderr, "Listening on [%s] (family %d, port %d)\n", |
---|
| 29 | + host ?: local, |
---|
| 30 | + family, |
---|
| 31 | + *uport); |
---|
| 32 | |
---|
| 33 | /* Allow only one connection at a time, but stay alive. */ |
---|
| 34 | for (;;) { |
---|
| 35 | - if (family != AF_UNIX) |
---|
| 36 | - s = local_listen(host, uport, hints); |
---|
| 37 | - if (s < 0) |
---|
| 38 | - err(1, NULL); |
---|
| 39 | |
---|
| 40 | - char* local; |
---|
| 41 | - if (family == AF_INET6 ) |
---|
| 42 | - local = "0.0.0.0"; |
---|
| 43 | - else if (family == AF_INET) |
---|
| 44 | - local = ":::"; |
---|
| 45 | - else |
---|
| 46 | - local = "unknown"; |
---|
| 47 | - fprintf(stderr, "Listening on [%s] (family %d, port %d)\n", |
---|
| 48 | - host ?: local, |
---|
| 49 | - family, |
---|
| 50 | - *uport); |
---|
| 51 | /* |
---|
| 52 | * For UDP, we will use recvfrom() initially |
---|
| 53 | * to wait for a caller, then use the regular |
---|
| 54 | @@ -536,15 +534,16 @@ main(int argc, char *argv[]) |
---|
| 55 | close(connfd); |
---|
| 56 | } |
---|
| 57 | |
---|
| 58 | - if (family != AF_UNIX) |
---|
| 59 | + if (kflag) |
---|
| 60 | + continue; |
---|
| 61 | + if (family != AF_UNIX) { |
---|
| 62 | close(s); |
---|
| 63 | + } |
---|
| 64 | else if (uflag) { |
---|
| 65 | if (connect(s, NULL, 0) < 0) |
---|
| 66 | err(1, "connect"); |
---|
| 67 | } |
---|
| 68 | - |
---|
| 69 | - if (!kflag) |
---|
| 70 | - break; |
---|
| 71 | + break; |
---|
| 72 | } |
---|
| 73 | } else if (family == AF_UNIX) { |
---|
| 74 | ret = 0; |
---|
| 75 | -- |
---|