From 00dba6082e245d917cb7d6eed3c627211ff41cd7 Mon Sep 17 00:00:00 2001 From: wangzhengquan <wangzhengquan85@126.com> Date: 星期五, 25 九月 2020 15:53:21 +0800 Subject: [PATCH] update --- test_socket/dgram_mod_bus.c | 55 +++++++++++++++++++++++++++++++++++++++++-------------- 1 files changed, 41 insertions(+), 14 deletions(-) diff --git a/test_socket/dgram_mod_bus.c b/test_socket/dgram_mod_bus.c index b016cbc..f800f10 100644 --- a/test_socket/dgram_mod_bus.c +++ b/test_socket/dgram_mod_bus.c @@ -10,8 +10,8 @@ } void server(int port, bool restart) { - // signal(SIGINT, sigint_handler); server_socket = dgram_mod_open_socket(); + if(restart) { dgram_mod_force_bind(server_socket, port); @@ -38,6 +38,8 @@ void client(int port) { void *socket = dgram_mod_open_socket(); + + pthread_t tid; pthread_create(&tid, NULL, run_recv, socket); int size; @@ -48,31 +50,50 @@ long i = 0; while (true) { //printf("Usage: pub <topic> [content] or sub <topic>\n"); - printf("Can I help you? sub, pub or quit\n"); + printf("Can I help you? sub, pub, desub or quit\n"); scanf("%s",action); if(strcmp(action, "sub") == 0) { printf("Please input topic!\n"); scanf("%s", topic); - dgram_mod_sub(socket, topic, strlen(topic), port); - printf("Sub success!\n"); - } - else if(strcmp(action, "pub") == 0) { + if (dgram_mod_sub(socket, topic, strlen(topic), port) == 0) { + printf("%d Sub success!\n", dgram_mod_get_port(socket)); + } else { + printf("Sub failture!\n"); + exit(0); + } + + } else if(strcmp(action, "desub") == 0) { + printf("Please input topic!\n"); + scanf("%s", topic); + if (dgram_mod_desub(socket, topic, strlen(topic), port) == 0) { + printf("%d Desub success!\n", dgram_mod_get_port(socket)); + } else { + printf("Desub failture!\n"); + exit(0); + } + + } else if(strcmp(action, "pub") == 0) { // printf("%s %s %s\n", action, topic, content); printf("Please input topic and content\n"); scanf("%s %s", topic, content); - dgram_mod_pub(socket, topic, strlen(topic)+1, content, strlen(content)+1, port); - printf("Pub success!\n"); + if(dgram_mod_pub(socket, topic, strlen(topic)+1, content, strlen(content)+1, port) == 0){ + printf("%d Pub success!\n", dgram_mod_get_port(socket)); + } else { + printf("Pub failture!\n"); + } + } else if(strcmp(action, "quit") == 0) { + printf("(%d) quit\n", dgram_mod_get_port(socket)); + dgram_mod_close_socket(socket); break; } else { - printf("error input\n"); + printf("error input argument\n"); continue; } } - printf("(%d) quit\n", dgram_mod_get_port(socket)); - dgram_mod_close_socket(socket); + } @@ -81,7 +102,7 @@ shm_init(512); int port; if (argc < 3) { - fprintf(stderr, "Usage: %s %s|%s <PORT> ...\n", argv[0], "server", "client"); + fprintf(stderr, "Usage: %s %s|%s|rmkey <PORT> ...\n", argv[0], "server", "client"); return 1; } @@ -95,10 +116,16 @@ server(port, false); } + } else if (strcmp("client", argv[1]) == 0) { + client(port); + } else if(strcmp("rmkey", argv[1]) == 0) { + for(int i = 2; i < argc; i++) { + port = atoi(argv[i]); + dgram_mod_remove_key(port); + // printf("%d\n", port); + } } - if (strcmp("client", argv[1]) == 0) - client(port); return 0; -- Gitblit v1.8.0