annotate Renderer/Test/dynamic_create.cc @ 638:671fca057ad3

hmmmm
author Shinji KONO <kono@ie.u-ryukyu.ac.jp>
date Thu, 19 Nov 2009 18:18:20 +0900
parents 529188ae604d
children 000a3bd205d1
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
566
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
1 #include <stdlib.h>
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
2 #include <stdio.h>
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
3 #include <string.h>
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
4 #include <fcntl.h>
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
5 #include <sys/types.h>
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
6 #include <sys/mman.h>
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
7 #include <sys/stat.h>
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
8 #include <unistd.h>
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
9 #include <arpa/inet.h>
610
529188ae604d change htonl to xdr_float (checked working on mac)
kazz@kazzone.st.ie.u-ryukyu.ac.jp
parents: 601
diff changeset
10 #include <rpc/types.h>
529188ae604d change htonl to xdr_float (checked working on mac)
kazz@kazzone.st.ie.u-ryukyu.ac.jp
parents: 601
diff changeset
11 #include <rpc/xdr.h>
566
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
12 #include "SceneGraphRoot.h"
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
13 #include "lindaapi.h"
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
14 #include "dynamic_create.h"
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
15
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
16 #define PORT 10000
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
17
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
18 #define SERIAL_REGIST_TUPLE_NO 1
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
19
610
529188ae604d change htonl to xdr_float (checked working on mac)
kazz@kazzone.st.ie.u-ryukyu.ac.jp
parents: 601
diff changeset
20 #define RECV_DATA_SIZE sizeof(float) * 6
529188ae604d change htonl to xdr_float (checked working on mac)
kazz@kazzone.st.ie.u-ryukyu.ac.jp
parents: 601
diff changeset
21
566
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
22 /*
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
23 typedef struct {
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
24 caddr_t file_mmap;
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
25 off_t size;
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
26 } st_mmap_t;
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
27 */
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
28
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
29 typedef struct client_ {
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
30 int id;
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
31 SceneGraphPtr sgp;
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
32 struct client_ *next;
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
33 } client_t;
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
34
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
35 typedef struct {
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
36 int tid;
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
37 int sid;
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
38 int read_id;
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
39 SceneGraphPtr node;
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
40 TaskManager *manager;
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
41 client_t *clist;
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
42 } callback_arg;
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
43
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
44
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
45 void
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
46 client_list_init(TaskManager* manager, client_t *clist)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
47 {
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
48 clist->id = -1;
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
49 clist->next = clist;
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
50 }
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
51
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
52 void
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
53 client_list_update(TaskManager *manager, client_t *clist, int id, SceneGraphPtr sgp)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
54 {
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
55 }
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
56
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
57 void
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
58 client_list_delete(TaskManager *manager, client_t *clist, int id)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
59 {
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
60 client_t *c, *prev;
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
61 for (c = clist->next, prev = clist; c->next != clist; c = c->next) {
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
62 if (c->id == id) {
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
63 prev->next = c->next;
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
64 return;
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
65 }
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
66 prev = clist;
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
67 }
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
68 if (c->id == id) {
591
7cbffb81e214 send linda not work...
kazz@kazzone.st.ie.u-ryukyu.ac.jp
parents: 587
diff changeset
69 prev->next = c->next;
7cbffb81e214 send linda not work...
kazz@kazzone.st.ie.u-ryukyu.ac.jp
parents: 587
diff changeset
70 return;
566
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
71 }
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
72 }
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
73
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
74
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
75 static void
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
76 earth_collision(SceneGraphPtr node, int screen_w, int screen_h,
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
77 SceneGraphPtr tree)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
78 {
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
79 }
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
80
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
81 static void
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
82 moon_collision(SceneGraphPtr node, int screen_w, int screen_h,
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
83 SceneGraphPtr tree)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
84 {
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
85 }
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
86
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
87 static void
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
88 moon_move(SceneGraphPtr node, int screen_w, int screen_h)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
89 {
591
7cbffb81e214 send linda not work...
kazz@kazzone.st.ie.u-ryukyu.ac.jp
parents: 587
diff changeset
90 // LindaServerから座標データを取得してオブジェクトに反映させる。
600
b480cec5af53 linda not work
kazz@e065701.local
parents: 595
diff changeset
91 unsigned char *reply = psx_reply(node->seq);
591
7cbffb81e214 send linda not work...
kazz@kazzone.st.ie.u-ryukyu.ac.jp
parents: 587
diff changeset
92 if (reply != NULL) {
610
529188ae604d change htonl to xdr_float (checked working on mac)
kazz@kazzone.st.ie.u-ryukyu.ac.jp
parents: 601
diff changeset
93 char *data = (char *)(reply + LINDA_HEADER_SIZE);
529188ae604d change htonl to xdr_float (checked working on mac)
kazz@kazzone.st.ie.u-ryukyu.ac.jp
parents: 601
diff changeset
94 // XDRの準備
529188ae604d change htonl to xdr_float (checked working on mac)
kazz@kazzone.st.ie.u-ryukyu.ac.jp
parents: 601
diff changeset
95 XDR xdrs;
529188ae604d change htonl to xdr_float (checked working on mac)
kazz@kazzone.st.ie.u-ryukyu.ac.jp
parents: 601
diff changeset
96 xdrmem_create(&xdrs, data, RECV_DATA_SIZE, XDR_DECODE);
600
b480cec5af53 linda not work
kazz@e065701.local
parents: 595
diff changeset
97 // ntoh_float(&data[0]); ntoh_float(&data[1]);
591
7cbffb81e214 send linda not work...
kazz@kazzone.st.ie.u-ryukyu.ac.jp
parents: 587
diff changeset
98 for (int i = 0; i < 3; i++) {
610
529188ae604d change htonl to xdr_float (checked working on mac)
kazz@kazzone.st.ie.u-ryukyu.ac.jp
parents: 601
diff changeset
99 xdr_float(&xdrs, &node->xyz[i]);
591
7cbffb81e214 send linda not work...
kazz@kazzone.st.ie.u-ryukyu.ac.jp
parents: 587
diff changeset
100 }
593
6f741ab60749 sending and moving of multi xml work (linda)
kazz@kazzone.st.ie.u-ryukyu.ac.jp
parents: 592
diff changeset
101 node->seq = psx_wait_rd(sgroot->tid, node->id * 10 + 1);
591
7cbffb81e214 send linda not work...
kazz@kazzone.st.ie.u-ryukyu.ac.jp
parents: 587
diff changeset
102 }
566
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
103 }
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
104
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
105
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
106 static void
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
107 earth_move(SceneGraphPtr node, int screen_w, int screen_h)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
108 {
575
0f13810d4492 Linda API worked. (slightly unreliable)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 574
diff changeset
109 // psx_sync_n(); in viewer::MainLoop
566
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
110 }
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
111
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
112 SceneGraphPtr
581
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 580
diff changeset
113 create_sg(TaskManager *manager, SceneGraphPtr parent, unsigned char *data, int len, int serial_id)
566
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
114 {
580
da82a47ece92 add all object in file in dynamic_create
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 579
diff changeset
115 SceneGraphPtr child = sgroot->createSceneGraph();
581
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 580
diff changeset
116 parent->addChild(child);
580
da82a47ece92 add all object in file in dynamic_create
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 579
diff changeset
117 // 読み込んだオブジェクトは、すべて、child の child になる。
da82a47ece92 add all object in file in dynamic_create
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 579
diff changeset
118 sgroot->createFromXMLmemory(sgroot->tmanager, child, (char *)data, len);
581
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 580
diff changeset
119 child->set_move_collision(moon_move, moon_collision);
591
7cbffb81e214 send linda not work...
kazz@kazzone.st.ie.u-ryukyu.ac.jp
parents: 587
diff changeset
120 child->id = serial_id;
593
6f741ab60749 sending and moving of multi xml work (linda)
kazz@kazzone.st.ie.u-ryukyu.ac.jp
parents: 592
diff changeset
121 child->seq = psx_wait_rd(sgroot->tid, serial_id * 10 + 1);
6f741ab60749 sending and moving of multi xml work (linda)
kazz@kazzone.st.ie.u-ryukyu.ac.jp
parents: 592
diff changeset
122
581
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 580
diff changeset
123 return child;
566
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
124 }
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
125
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
126
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
127 static void
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
128 callback_get_xml(unsigned char *xml_tuple, void *arg) {
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
129 int xml_len = psx_get_datalength(xml_tuple);
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
130 callback_arg *carg = (callback_arg *)arg;
591
7cbffb81e214 send linda not work...
kazz@kazzone.st.ie.u-ryukyu.ac.jp
parents: 587
diff changeset
131 unsigned char *xml_data = xml_tuple + LINDA_HEADER_SIZE;
566
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
132 SceneGraphPtr sgp;
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
133 // ここで create
581
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 580
diff changeset
134 // fwrite(xml_data, 1, 10, stdout);
566
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
135 sgp = create_sg(carg->manager, carg->node, xml_data, xml_len, carg->sid);
581
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 580
diff changeset
136 printf("%s size %d loaded\n", sgp->children->name, xml_len);
566
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
137 client_list_update(carg->manager, carg->clist, carg->sid, sgp);
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
138 free(arg);
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
139 free(xml_tuple);
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
140 }
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
141
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
142 static void
591
7cbffb81e214 send linda not work...
kazz@kazzone.st.ie.u-ryukyu.ac.jp
parents: 587
diff changeset
143 callbacker(unsigned char *taple, void *arg) {
566
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
144 int serial_id, xml_id;
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
145
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
146 unsigned char *data;
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
147 callback_arg *carg = (callback_arg *)arg;
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
148
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
149 // 最初の4byteデータは使わない
601
8782cc4171b7 linda work on mac osx
kazz@e065701.local
parents: 600
diff changeset
150 data = taple + LINDA_HEADER_SIZE;
566
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
151 // clientのSerialIDを取得
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
152 serial_id = ntohl(*(int *)data);
610
529188ae604d change htonl to xdr_float (checked working on mac)
kazz@kazzone.st.ie.u-ryukyu.ac.jp
parents: 601
diff changeset
153 printf("serial id = %d\n", serial_id); // タプルを解放
574
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 566
diff changeset
154 //psx_del(carg->tid, SERIAL_REGIST_TUPLE_NO);
566
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
155
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
156 // xml fileを取得する もうすでにxml fileが送信済みである事を期待
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
157 // つまり、送信者がserial_idを送る前にxml fileを送信していなくてはならない
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
158 xml_id = serial_id * 10;
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
159 callback_arg *copy_arg = (callback_arg *)carg->manager->allocate(sizeof(callback_arg));
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
160 *copy_arg = *carg;
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
161 copy_arg->sid = serial_id;
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
162 psx_callback_in(carg->tid, xml_id, callback_get_xml, (void *)copy_arg);
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
163
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
164 /* dataは'\0'で終わっている事を期待 (writerで保証する) */
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
165 //printf("get data[%d]: `%s'\n", len, data);
591
7cbffb81e214 send linda not work...
kazz@kazzone.st.ie.u-ryukyu.ac.jp
parents: 587
diff changeset
166 free(taple);
566
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
167
574
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 566
diff changeset
168 psx_callback_in(carg->tid, carg->read_id, callbacker, arg);
566
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
169 }
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
170
577
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 576
diff changeset
171 static char *linda = "localhost";
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 576
diff changeset
172
566
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
173 void
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
174 linda_init(TaskManager *manager, client_t *clist, SceneGraphPtr node)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
175 {
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
176 init_linda();
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
177 callback_arg *carg = (callback_arg *)manager->allocate(sizeof(callback_arg));
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
178
579
root@localhost.localdomain
parents: 577
diff changeset
179 carg->tid = open_linda_java(linda, PORT);
591
7cbffb81e214 send linda not work...
kazz@kazzone.st.ie.u-ryukyu.ac.jp
parents: 587
diff changeset
180 sgroot->tid = carg->tid;
566
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
181 carg->read_id = SERIAL_REGIST_TUPLE_NO;
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
182 carg->node = node;
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
183 carg->manager = manager;
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
184 carg->clist = clist;
574
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 566
diff changeset
185 psx_callback_in(carg->tid, carg->read_id, callbacker, carg);
566
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
186 }
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
187
593
6f741ab60749 sending and moving of multi xml work (linda)
kazz@kazzone.st.ie.u-ryukyu.ac.jp
parents: 592
diff changeset
188 MainLoopPtr
566
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
189 dynamic_create::init(Viewer *sgroot, int screen_w, int screen_h)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
190 {
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
191 //SceneGraphPtr earth;
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
192 client_t *clist;
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
193 clist = (client_t *)sgroot->manager->allocate(sizeof(client_t));
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
194
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
195 client_list_init(sgroot->manager, clist);
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
196
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
197 SceneGraphPtr parent;
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
198 parent = sgroot->createSceneGraph();
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
199 parent->set_move_collision(earth_move, earth_collision);
593
6f741ab60749 sending and moving of multi xml work (linda)
kazz@kazzone.st.ie.u-ryukyu.ac.jp
parents: 592
diff changeset
200 // parent->xyz[0] += 300;
6f741ab60749 sending and moving of multi xml work (linda)
kazz@kazzone.st.ie.u-ryukyu.ac.jp
parents: 592
diff changeset
201 // parent->xyz[1] += 300;
566
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
202 linda_init(sgroot->manager, clist, parent);
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
203
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
204 // SceneGraphRoot に、使用する SceneGraph を設定する
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
205 // このとき、ユーザーが記述した SceneGraph の root を渡す。
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
206 sgroot->setSceneData(parent);
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
207 return sgroot;
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
208 }
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
209
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
210 extern Application *
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
211 application() {
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
212 return new dynamic_create();
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
213 }
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
214
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
215 const char *usr_help_str = "Usage: ./test_nogl [OPTION]\n";
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
216
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
217 extern int init(TaskManager *manager, int argc, char *argv[]);
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
218 extern void task_initialize();
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
219 static void TMend(TaskManager *manager);
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
220
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
221 int
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
222 TMmain(TaskManager *manager, int argc, char *argv[])
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
223 {
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
224 task_initialize();
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
225 manager->set_TMend(TMend);
577
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 576
diff changeset
226
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 576
diff changeset
227 for(int i=0;i<argc;i++) {
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 576
diff changeset
228 if (strcmp(argv[i],"-linda") == 0 && i+1<=argc) {
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 576
diff changeset
229 linda = argv[i+1];
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 576
diff changeset
230 }
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 576
diff changeset
231 }
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 576
diff changeset
232
566
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
233 return init(manager, argc, argv);
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
234 }
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
235
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
236 void
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
237 TMend(TaskManager *manager)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
238 {
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
239 printf("test_nogl end\n");
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
240 }
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
241
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
242 /* end */
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
243