annotate src/fdl/TupleSpace.java @ 16:cccf34386cad

*** empty log message ***
author kono
date Mon, 18 Aug 2008 06:17:54 +0900
parents
children 609b288f47f9
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
16
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
1 package fdl;
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
2
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
3 import java.io.IOException;
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
4 import java.nio.ByteBuffer;
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
5 import java.nio.CharBuffer;
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
6 import java.nio.channels.SelectionKey;
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
7 import java.nio.channels.SocketChannel;
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
8 import java.nio.charset.CharacterCodingException;
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
9 import java.nio.charset.Charset;
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
10 import java.nio.charset.CharsetDecoder;
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
11
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
12 public class TupleSpace implements PSXQueueInterface{
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
13 static final boolean debug = true;
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
14 static final int CAPSIZE = 4194304;
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
15 public Tuple[] tuple_space;
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
16
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
17 public TupleSpace(Tuple[] _tuple_space) {
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
18 super();
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
19 // 読みこんだデータを格納するためのリストの初期化
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
20 tuple_space = _tuple_space;
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
21 }
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
22
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
23 public TupleSpace() {
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
24 // TODO Auto-generated constructor stub
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
25 }
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
26
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
27 protected String Out(ByteBuffer command, ByteBuffer data) throws IOException {
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
28 Tuple tmpTuple;
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
29 int id;
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
30 int datasize;
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
31 char idc = (char)command.getShort(LINDA_ID_OFFSET);
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
32 command.rewind();
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
33 id = (int)idc;
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
34 String sendtext = "none";
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
35
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
36 datasize = command.getInt(LINDA_DATA_LENGTH_OFFSET);
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
37 command.rewind();
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
38
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
39 System.out.println("*** out command : id = "+id +" ***");
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
40
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
41 while((tuple_space[id] != null) &&
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
42 ((tuple_space[id].mode == PSX_WAIT_RD)||(tuple_space[id].mode == PSX_RD))) {
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
43 command.put(LINDA_MODE_OFFSET, (byte)'a');
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
44 command.rewind();
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
45 command.putInt(LINDA_SEQ_OFFSET, tuple_space[id].getSeq());
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
46 command.rewind();
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
47 //if(debug){
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
48 //int sendsize = tmpTuple.getdataLength()+LINDA_HEADER_SIZE;
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
49 //System.out.println("send size "+sendsize+" : mode = "+(char)mode);
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
50 //}
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
51 //ByteBuffer sendcommand = tmpTuple.getCommand();
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
52 //ByteBuffer senddata = tmpTuple.getData();
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
53 send(tuple_space[id].ch, command, data);
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
54
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
55 sendtext = getdataString(data);
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
56
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
57
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
58 //後処理
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
59 tmpTuple = tuple_space[id];
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
60 tuple_space[id] = tmpTuple.next;
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
61 tmpTuple = null;
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
62 }
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
63 if(tuple_space[id] != null && tuple_space[id].mode == PSX_IN) {
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
64 command.put(LINDA_MODE_OFFSET, (byte)'a');
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
65 command.rewind();
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
66 command.putInt(LINDA_SEQ_OFFSET, tuple_space[id].getSeq());
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
67 command.rewind();
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
68
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
69 if(debug){
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
70 int sendsize = datasize+LINDA_HEADER_SIZE;
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
71 System.out.println("send size "+sendsize+" : mode = "+(char)'a');
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
72 }
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
73 //ByteBuffer sendcommand = tmpTuple.getCommand();
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
74 //ByteBuffer senddata = tmpTuple.getData();
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
75 send(tuple_space[id].ch, command, data);
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
76
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
77 sendtext = getdataString(data);
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
78
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
79 //後処理
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
80 tmpTuple = tuple_space[id];
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
81 tuple_space[id] = tmpTuple.next;
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
82 tmpTuple = null;
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
83 } else if ((tuple_space[id] == null)|| (tuple_space[id].getMode() == PSX_OUT)) {
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
84 if((tmpTuple = tuple_space[id]) == null) {
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
85 tmpTuple = tuple_space[id] = new Tuple();
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
86 tmpTuple.next = null;
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
87 }
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
88 else {
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
89 while(tmpTuple.next != null) tmpTuple = tmpTuple.next;
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
90 tmpTuple.next = new Tuple();
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
91 tmpTuple = tmpTuple.next;
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
92 tmpTuple.next = null;
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
93 }
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
94
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
95 tmpTuple.setMode('o');
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
96 int seq = command.getInt(LINDA_SEQ_OFFSET);
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
97 command.rewind();
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
98 tmpTuple.setSeq(seq);
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
99 tmpTuple.setData(data);
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
100 tmpTuple.setDataLength(datasize);
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
101 if(debug){
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
102 System.out.println("data inserted len = "+tmpTuple.getdataLength()+" : id = "+id);
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
103 }
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
104 }
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
105 else {
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
106 System.out.println("Incorrect mode :"+(char)tuple_space[id].getMode());
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
107 command.clear();
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
108 data.clear();
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
109 System.exit(1);
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
110 }
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
111 return sendtext;
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
112 }
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
113
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
114 protected void Wait_Rd(SelectionKey key, ByteBuffer command, int mode) {
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
115 Tuple tmpTuple;
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
116 int id;
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
117
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
118 char idc = (char)command.getShort(LINDA_ID_OFFSET);
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
119 command.rewind();
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
120 id = (int)idc;
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
121
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
122 if (debug)
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
123 System.out.println("*** "+(char)mode+" command : id = "+ id +" ***\n");
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
124
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
125 tmpTuple = new Tuple();
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
126 tmpTuple.setMode(mode);
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
127 int seq = command.getInt(LINDA_SEQ_OFFSET);
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
128 command.rewind();
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
129 tmpTuple.setSeq(seq);
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
130 tmpTuple.ch = (SocketChannel) key.channel();
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
131 tmpTuple.setDataLength(0);
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
132 ByteBuffer buff = ByteBuffer.allocate(0);
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
133 tmpTuple.setData(buff);
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
134 tmpTuple.next = tuple_space[id];
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
135 tuple_space[id] = tmpTuple;
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
136 if(debug){
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
137 System.out.println("data inserted insert seq = "+seq +", id = "+id);
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
138 }
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
139 }
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
140
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
141 protected String In_Rd(SelectionKey key, ByteBuffer command, int mode)
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
142 throws IOException {
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
143 Tuple tmpTuple = read_in_1(key, command, mode);
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
144
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
145 if (tmpTuple!=null) {
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
146 //send
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
147 ByteBuffer sendcommand = tmpTuple.getCommand();
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
148 ByteBuffer senddata = tmpTuple.getData();
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
149 send(key,sendcommand, senddata);
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
150 }
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
151 String sendtext = getdataString(tmpTuple.getData());
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
152 return sendtext;
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
153 }
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
154
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
155 private Tuple read_in_1(SelectionKey key, ByteBuffer command, int mode) {
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
156 Tuple tmpTuple;
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
157 int id;
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
158 //id = command.getInt(LINDA_ID_OFFSET);
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
159 //int mode = command.getInt(LINDA_MODE_OFFSET);
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
160 Tuple temp = null;
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
161
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
162 char idc = (char)command.getShort(LINDA_ID_OFFSET);
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
163 command.rewind();
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
164 id = (int)idc;
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
165
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
166
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
167 System.out.println("*** "+(char)mode+" command : id = "+ id +" ***\n");
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
168
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
169 tmpTuple = tuple_space[id];
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
170
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
171 //wを無視
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
172 while(tmpTuple != null && tmpTuple.next != null && (tmpTuple.mode == 'w')){
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
173 temp = tmpTuple;
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
174 tmpTuple = tmpTuple.next;
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
175 }
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
176
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
177 if (tmpTuple != null && (tmpTuple.mode == 'o')){
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
178 //tmpTuple = new Tuple((SocketChannel)key.channel());
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
179 int seq = command.getInt(LINDA_SEQ_OFFSET);
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
180 command.rewind();
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
181 tmpTuple.setCommand('a', seq);
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
182
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
183 if(debug){
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
184 int sendsize = tmpTuple.getdataLength()+LINDA_HEADER_SIZE;
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
185 System.out.println("send size "+sendsize+" : mode = "+(char)tmpTuple.getMode());
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
186 }
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
187
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
188
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
189
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
190 //INの場合はremoveする
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
191 if(mode == PSX_IN) {
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
192 if(tmpTuple.data != null){
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
193 //ByteBuffer buff = ByteBuffer.allocate(0);
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
194 //tmpTuple.setData(buff);
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
195 tmpTuple.data = null;
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
196 }
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
197 if(temp != null){
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
198 temp.next = tmpTuple.next;
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
199 }
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
200 else {
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
201 tuple_space[id] = tmpTuple.next;
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
202 }
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
203 }
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
204 } else {
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
205 if(tmpTuple == null) {
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
206 //ServerSocketChannel sc = (ServerSocketChannel)key.channel();
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
207 tmpTuple = tuple_space[id] = new Tuple((SocketChannel)key.channel());
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
208 tmpTuple.next = null;
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
209 }else {
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
210 while(tmpTuple.next !=null) tmpTuple =tmpTuple.next;
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
211 tmpTuple.next= new Tuple((SocketChannel)key.channel());
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
212 tmpTuple = tmpTuple.next;
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
213 tmpTuple.next = null;
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
214 }
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
215
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
216 tmpTuple.setMode(mode);
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
217 int seq2 = command.getInt(LINDA_SEQ_OFFSET);
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
218 command.rewind();
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
219 tmpTuple.setSeq(seq2);
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
220 tmpTuple.ch = (SocketChannel) key.channel();
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
221 tmpTuple.setDataLength(0);
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
222 ByteBuffer buff = ByteBuffer.allocate(0);
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
223 buff.rewind();
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
224 tmpTuple.setData(buff);
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
225 tmpTuple = null;
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
226
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
227 if(debug){
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
228 System.out.println("data inserted insert seq = "+seq2 +", id = "+id);
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
229 }
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
230 }
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
231 return tmpTuple;
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
232 }
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
233
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
234 protected String Check(SelectionKey key, ByteBuffer command) throws IOException {
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
235 String sendtext;
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
236 ByteBuffer data = check1(command);
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
237 send(key, command, data);
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
238
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
239 sendtext = getdataString(data);
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
240
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
241 return sendtext;
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
242 }
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
243
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
244 private ByteBuffer check1(ByteBuffer command) {
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
245 ByteBuffer data;
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
246 Tuple tmpTuple;
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
247 int id;
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
248 char idc = (char)command.getShort(LINDA_ID_OFFSET);
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
249 command.rewind();
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
250 id = (int)idc;
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
251
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
252 tmpTuple = tuple_space[id];
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
253 while(tmpTuple != null && tmpTuple.next != null && (tmpTuple.mode == 'w')){
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
254 tmpTuple = tmpTuple.next;
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
255 }
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
256 if (tmpTuple != null && (tmpTuple.mode == 'o')) {
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
257 command.putInt(LINDA_DATA_LENGTH_OFFSET, tmpTuple.datalen);
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
258 command.rewind();
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
259 data = tmpTuple.getData();
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
260 }else {
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
261 //means no out tuple
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
262 command.putInt(LINDA_DATA_LENGTH_OFFSET, 0);
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
263 command.rewind();
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
264 data = ByteBuffer.allocate(0);
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
265 }
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
266 return data;
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
267 }
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
268
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
269 public void send(SocketChannel ch, ByteBuffer command, ByteBuffer data)
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
270 throws IOException {
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
271 if (debug) {
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
272 if (command == null) {
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
273 System.out.println("Manager_run: command is null");
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
274 }
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
275 if (data == null) {
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
276 System.out.println("Manager_run: data is null");
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
277 }
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
278 }
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
279 int send_size = LINDA_HEADER_SIZE;
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
280 int count = 0;
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
281
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
282 //command Send
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
283 command.rewind();
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
284 while(send_size > 0){
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
285 count = ch.write(command);
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
286 if(count < 0){
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
287 System.out.println("Write Falied! close ch:"+ch);
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
288 ch.close();
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
289 return;
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
290 }
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
291 send_size -= count;
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
292 }
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
293
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
294 //data Send
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
295 data.rewind();
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
296 if(data != null) {
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
297 data.rewind();
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
298 ch.write(data);
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
299 }
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
300 }
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
301
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
302 public void send(SelectionKey key, ByteBuffer command, ByteBuffer data)
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
303 throws IOException {
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
304 SocketChannel ch = (SocketChannel)key.channel();
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
305 send(ch,command,data);
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
306 }
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
307
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
308 private String getdataString(ByteBuffer data) {
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
309 String sendtext;
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
310 data.rewind();
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
311 //set sendtext
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
312 //CharBuffer chardata = data.asCharBuffer();
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
313
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
314 //Decode UTF-8 to System Encoding(UTF-16)
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
315 Charset charset = Charset.forName("UTF-8");
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
316 CharsetDecoder decoder = charset.newDecoder();
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
317 CharBuffer cb = null;
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
318 try {
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
319 cb = decoder.decode(data);
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
320 } catch (CharacterCodingException e) {
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
321 e.printStackTrace();
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
322 }
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
323 cb.rewind();
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
324
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
325 sendtext = cb.toString();
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
326 return sendtext;
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
327 }
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
328
cccf34386cad *** empty log message ***
kono
parents:
diff changeset
329 }