summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--Makefile9
-rw-r--r--client.c11
-rw-r--r--dumbclient.c67
3 files changed, 83 insertions, 4 deletions
diff --git a/Makefile b/Makefile
index e8df2e9..ca64efa 100644
--- a/Makefile
+++ b/Makefile
@@ -7,21 +7,24 @@ TARGETS2=binding
TARGETS3=listen
TARGETS4=connecting
TARGETS5=client
+TARGETS6=dumbclient
TESTTARGET=helloworld-t
TESTTARGET2=binding-t
TESTTARGET3=listen-t
TESTTARGET4=connecting-t
TESTTARGET5=client-t
+TESTTARGET6=dumbclient-t
SRCS=hello.c
SRCS2=binding.c
SRCS3=listen.c
SRCS4=connecting.c
SRCS5=client.c
+SRCS6=dumbclient.c
all: release
clean:
- rm -f bin/$(TARGETS) bin/$(TARGETS2) bin/$(TARGETS3) bin/$(TARGETS4) bin/$(TARGETS5)
- rm -f test/$(TESTTARGET) test/$(TESTTARGET2) test/$(TESTTARGET3) test/$(TESTTARGET4) test/$(TESTTARGET5)
+ rm -f bin/$(TARGETS) bin/$(TARGETS2) bin/$(TARGETS3) bin/$(TARGETS4) bin/$(TARGETS5) bin/$(TARGETS6)
+ rm -f test/$(TESTTARGET) test/$(TESTTARGET2) test/$(TESTTARGET3) test/$(TESTTARGET4) test/$(TESTTARGET5) test/$(TESTTARGET6)
tests:
$(CC) $(CFLAGS_TESTBIN) $(SRCS) -o test/$(TESTTARGET)
@@ -29,6 +32,7 @@ tests:
$(CC) $(CFLAGS_TESTBIN) $(SRCS3) -o test/$(TESTTARGET3)
$(CC) $(CFLAGS_TESTBIN) $(SRCS4) -o test/$(TESTTARGET4)
$(CC) $(CFLAGS_TESTBIN) $(SRCS5) -o test/$(TESTTARGET5)
+ $(CC) $(CFLAGS_TESTBIN) $(SRCS6) -o test/$(TESTTARGET6)
release:
$(CC) $(CFLAGS) $(SRCS) -o bin/$(TARGETS)
@@ -36,3 +40,4 @@ release:
$(CC) $(CFLAGS) $(SRCS3) -o bin/$(TARGETS3)
$(CC) $(CFLAGS) $(SRCS4) -o bin/$(TARGETS4)
$(CC) $(CFLAGS) $(SRCS5) -o bin/$(TARGETS5)
+ $(CC) $(CFLAGS) $(SRCS6) -o bin/$(TARGETS6)
diff --git a/client.c b/client.c
index 3ace3ac..e023465 100644
--- a/client.c
+++ b/client.c
@@ -50,11 +50,18 @@ int main () {
}
}
- if (connect_result == -1 || sockfd == -1) { exit(__FAIL); }
+ if (connect_result == -1 || sockfd == -1) {
+ exit(__FAIL);
+ }
+
char *msg = "Client says hello!\n";
size_t len = strlen(msg);
- send(sockfd, msg, len, 0);
+
+ for (int i = 0 ; i < 10 ; i++) {
+
+ send(sockfd, msg, len, 0);
+ }
freeaddrinfo(res);
return 0;
}
diff --git a/dumbclient.c b/dumbclient.c
new file mode 100644
index 0000000..e023465
--- /dev/null
+++ b/dumbclient.c
@@ -0,0 +1,67 @@
+#include <sys/types.h>
+#include <sys/socket.h>
+#include <netdb.h>
+#include <stdio.h>
+#include <string.h>
+#include <stdint.h>
+#include <unistd.h>
+#include <stdbool.h>
+#include <fcntl.h>
+#include <stdlib.h>
+#include <arpa/inet.h>
+#include <netinet/in.h>
+
+// int listen(int sockfd, int backlog);
+#define __FAIL EXIT_FAILURE
+#define BACKLOG 2
+#define __PORT "62000"
+
+int main () {
+
+ int sockfd = -1;
+ int gai_result;
+ int connect_result = -1;
+ struct addrinfo hints;
+ struct addrinfo *res;
+ struct addrinfo *p;
+ memset(&hints, 0, sizeof(hints));
+ //hints.ai_flags = ;
+ hints.ai_family = AF_INET;
+ hints.ai_socktype = SOCK_STREAM;
+
+ gai_result = getaddrinfo("192.168.1.18", __PORT, &hints, &res);
+ if (gai_result != 0) {
+ fprintf(stderr, "getaddrinfo: %d", gai_result);
+ exit(__FAIL);
+ }
+
+ for (p = res ; p != NULL ; p = p->ai_next) {
+
+ sockfd = socket(p->ai_family, p->ai_socktype, p->ai_protocol);
+ if (sockfd == -1) {
+ fprintf(stderr, "socket fail\n");
+ continue;
+ }
+
+ connect_result = connect(sockfd, p->ai_addr, p->ai_addrlen);
+ if (connect_result == -1) {
+ fprintf(stderr, "connect fail\n");
+ continue;
+ }
+
+ }
+ if (connect_result == -1 || sockfd == -1) {
+ exit(__FAIL);
+ }
+
+
+ char *msg = "Client says hello!\n";
+ size_t len = strlen(msg);
+
+ for (int i = 0 ; i < 10 ; i++) {
+
+ send(sockfd, msg, len, 0);
+ }
+ freeaddrinfo(res);
+ return 0;
+}