Mercurial > hg > Game > Cerium
changeset 584:6dfd8e6bdef3 draft
fix writer.c
author | Shinji KONO <kono@ie.u-ryukyu.ac.jp> |
---|---|
date | Sun, 25 Oct 2009 20:24:53 +0900 |
parents | 537a14d1956b |
children | 083883af1c9c |
files | Renderer/Test/writer.c |
diffstat | 1 files changed, 51 insertions(+), 54 deletions(-) [+] |
line wrap: on
line diff
--- a/Renderer/Test/writer.c Sun Oct 25 20:11:38 2009 +0900 +++ b/Renderer/Test/writer.c Sun Oct 25 20:24:53 2009 +0900 @@ -2,83 +2,80 @@ #include <stdlib.h> #include <string.h> #include <unistd.h> -#include <pthread.h> #include <arpa/inet.h> +#include <sys/stat.h> +#include <sys/mman.h> #include "lindaapi.h" #define PORT 10000 -void -del_callback(unsigned char *data, void *arg) -{ - free(data); -} -void -psx_del(int t, int id) -{ - psx_callback_in(t, id, del_callback, NULL); -} - +#define SERIAL_REGIST_TUPLE_NO 1 void -mainLoop(int tid, int write_id) +mainLoop(int tid, int write_id, int fd) { - int size=BUFSIZ; - char *buff = (char *)malloc(size); - int len; - uint32_t line_id=0; + void *addr; + struct stat sb; - if ( (buff=(char*)malloc(size))==NULL ) { - perror("malloc"); - exit(EXIT_FAILURE); + if (fstat(fd, &sb) == -1) { + perror("fstat"); + exit(1); + } + addr = mmap(NULL, sb.st_size, PROT_READ, MAP_PRIVATE, fd, 0); + if (addr==NULL) { + perror("mmap"); + exit(1); } - /* '\0'も含めて送信 */ - psx_out(tid, write_id, (unsigned char *)"\0\0\0\0aiueo", 10); - psx_sync_n(); - - while (1) { - char *data = buff+4; - /* 標準入力から読み込み、改行を削除 */ - fgets(data, size-4, stdin); - len = strlen(data); - if (data[len-1]=='\n') { - data[--len] = '\0'; - } - ((uint32_t*)buff)[0] = htonl(line_id); + printf("file size=%lld\n", sb.st_size); - if (len==size) { - /* realloc */ - } - - /* まえのデータを消す */ - psx_del(tid, write_id); - /* '\0'も含めて送信 */ - psx_out(tid, write_id, (unsigned char *)buff, len+4+1); - - psx_sync_n(); - printf("send data[%d] line_id=%d, `%s'\n", len, line_id, data); - printf("line_id =%d\n", ntohl(((uint32_t*)buff)[0])); - - line_id++; - } + psx_out(tid, write_id, (unsigned char *)addr, sb.st_size); + psx_sync_n(); return; } +int get_serial_id(int tid) { + char *data; + int serial; + int seq; + + seq = psx_in(tid, 65535); + do { + psx_sync_n(); + data = (char *)psx_reply(seq); + } while(data==0); + serial = atoi(data + LINDA_HEADER_SIZE); + psx_free(data); + + return serial; +} + +void send_serial_id(int tid, int serial_id) { + int safe_id = htonl(serial_id); + + psx_out(tid, SERIAL_REGIST_TUPLE_NO, (unsigned char *)&safe_id, sizeof(safe_id)); + psx_sync_n(); +} int main(int argc, char *argv[]) { int tspace; - + int serial; + int xml_id; + char *linda_serv = "localhost"; + if (argc > 1) + linda_serv = argv[1]; init_linda(); - tspace = open_linda_java("localhost", PORT); + tspace = open_linda_java(linda_serv, PORT); printf("open socket (tupple space id) = %d\n", tspace); - - mainLoop(tspace, 10); - - printf("mainLoop finished\n"); + serial = get_serial_id(tspace); + xml_id = serial * 10; + mainLoop(tspace, xml_id, fileno(stdin)); + sleep(1); + send_serial_id(tspace, serial); + printf("send xml_id = %d, seciral = %d\n",xml_id, serial); exit(EXIT_SUCCESS); }