aboutsummaryrefslogtreecommitdiff
path: root/template/c
diff options
context:
space:
mode:
authormattn <mattn.jp@gmail.com>2013-09-12 16:50:41 +0900
committermattn <mattn.jp@gmail.com>2013-09-12 16:50:41 +0900
commit1c9e7729fb8845088ed9e223581dd37bd8e502cc (patch)
treee7025592a96163a5454b216f4b479cd36f7a0817 /template/c
parentd1b69d9a9b9372ef56ae7ee91799e23f2ee9703b (diff)
downloadvim-sonictemplate-1c9e7729fb8845088ed9e223581dd37bd8e502cc.tar.gz
vim-sonictemplate-1c9e7729fb8845088ed9e223581dd37bd8e502cc.tar.bz2
vim-sonictemplate-1c9e7729fb8845088ed9e223581dd37bd8e502cc.zip
Add templates that I use often
Diffstat (limited to 'template/c')
-rw-r--r--template/c/base-socket-server.c79
1 files changed, 79 insertions, 0 deletions
diff --git a/template/c/base-socket-server.c b/template/c/base-socket-server.c
new file mode 100644
index 0000000..c4f4cf4
--- /dev/null
+++ b/template/c/base-socket-server.c
@@ -0,0 +1,79 @@
+#ifdef _WIN32
+# include <ws2tcpip.h>
+#else
+# include <sys/fcntl.h>
+# include <sys/types.h>
+# include <sys/socket.h>
+# include <netinet/in.h>
+# include <netdb.h>
+# include <stdio.h>
+#define closesocket(fd) close(fd)
+#endif
+
+int
+main(int argc, char* argv[]) {
+ int server_fd;
+ int client_fd;
+ int writer_len;
+ struct sockaddr_in reader_addr;
+ struct sockaddr_in writer_addr;
+
+#ifdef _WIN32
+ WSADATA wsa;
+ WSAStartup(MAKEWORD(2, 0), &wsa);
+#endif
+
+ if ((server_fd = socket(PF_INET, SOCK_STREAM, 0)) < 0) {
+ perror("reader: socket");
+ exit(1);
+ }
+
+ memset((char *) &reader_addr, 0, sizeof(reader_addr));
+ reader_addr.sin_family = PF_INET;
+ reader_addr.sin_addr.s_addr = htonl(INADDR_ANY);
+ //reader_addr.sin_port = htons(8000);
+ reader_addr.sin_port = 0;
+
+ if (bind(server_fd, (struct sockaddr *)&reader_addr, sizeof(reader_addr)) < 0) {
+ perror("reader: bind");
+ exit(1);
+ }
+ printf("%d\n", reader_addr.sin_port);
+ size_t socklen = sizeof(reader_addr);
+ if (getsockname(server_fd, (struct sockaddr *)&reader_addr, &socklen) < 0) {
+ perror("reader: bind");
+ exit(1);
+ }
+ printf("%d\n", reader_addr.sin_port);
+
+ if (listen(server_fd, 5) < 0) {
+ perror("reader: listen");
+ close(server_fd);
+ exit(1);
+ }
+
+ if ((client_fd = accept(server_fd,(struct sockaddr *)&writer_addr, &writer_len)) < 0) {
+ perror("reader: accept");
+ exit(1);
+ }
+
+ while (1) {
+ char buf[256];
+ size_t n = recv(client_fd, buf, sizeof(buf), 0);
+ puts(buf);
+ if (n == 0) {
+ break;
+ } else if (n == -1) {
+ perror("recv");
+ exit(EXIT_FAILURE);
+ } else {
+ send(client_fd, buf, n, 0);
+ }
+ }
+
+ closesocket(server_fd);
+
+#ifdef _WIN32
+ WSACleanup();
+#endif
+}