annotate rep/REPCommandPacker.java @ 312:f39a8045175d

*** empty log message ***
author kono
date Sun, 05 Oct 2008 11:39:18 +0900
parents 7107faaf3feb
children 5ba5b7a9761b
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
186
d22384c0026c *** empty log message ***
kent
parents:
diff changeset
1 package rep;
d22384c0026c *** empty log message ***
kent
parents:
diff changeset
2
d22384c0026c *** empty log message ***
kent
parents:
diff changeset
3 import java.io.IOException;
d22384c0026c *** empty log message ***
kent
parents:
diff changeset
4 import java.nio.ByteBuffer;
d22384c0026c *** empty log message ***
kent
parents:
diff changeset
5 import java.nio.CharBuffer;
d22384c0026c *** empty log message ***
kent
parents:
diff changeset
6 import java.nio.channels.SocketChannel;
d22384c0026c *** empty log message ***
kent
parents:
diff changeset
7 import java.nio.charset.CharacterCodingException;
d22384c0026c *** empty log message ***
kent
parents:
diff changeset
8 import java.nio.charset.Charset;
d22384c0026c *** empty log message ***
kent
parents:
diff changeset
9 import java.nio.charset.CharsetDecoder;
d22384c0026c *** empty log message ***
kent
parents:
diff changeset
10 import java.nio.charset.CharsetEncoder;
d22384c0026c *** empty log message ***
kent
parents:
diff changeset
11
d22384c0026c *** empty log message ***
kent
parents:
diff changeset
12 import rep.channel.REPPack;
d22384c0026c *** empty log message ***
kent
parents:
diff changeset
13
224
6b0dd92b8e45 add optimizer to Editor
kent
parents: 186
diff changeset
14 /*
6b0dd92b8e45 add optimizer to Editor
kent
parents: 186
diff changeset
15 //+-------+--------+--------+-------+--------+---------+------+
6b0dd92b8e45 add optimizer to Editor
kent
parents: 186
diff changeset
16 //| cmd | session| editor | seqid | lineno | textsiz | text |
6b0dd92b8e45 add optimizer to Editor
kent
parents: 186
diff changeset
17 //| | id | id | | | | |
6b0dd92b8e45 add optimizer to Editor
kent
parents: 186
diff changeset
18 //+-------+--------+--------+-------+--------+---------+------+
6b0dd92b8e45 add optimizer to Editor
kent
parents: 186
diff changeset
19 //o-------header section (network order)-------------o
6b0dd92b8e45 add optimizer to Editor
kent
parents: 186
diff changeset
20 int cmd; // command
6b0dd92b8e45 add optimizer to Editor
kent
parents: 186
diff changeset
21 int sid; // session ID : uniqu to editing file
6b0dd92b8e45 add optimizer to Editor
kent
parents: 186
diff changeset
22 int eid; // editor ID : owner editor ID = 1。Session に対して unique
6b0dd92b8e45 add optimizer to Editor
kent
parents: 186
diff changeset
23 int seqno; // Sequence number : sequence number はエディタごとに管理
6b0dd92b8e45 add optimizer to Editor
kent
parents: 186
diff changeset
24 int lineno; // line number
6b0dd92b8e45 add optimizer to Editor
kent
parents: 186
diff changeset
25 int textsize; // textsize : bytesize
6b0dd92b8e45 add optimizer to Editor
kent
parents: 186
diff changeset
26 byte[] text;
6b0dd92b8e45 add optimizer to Editor
kent
parents: 186
diff changeset
27 */
6b0dd92b8e45 add optimizer to Editor
kent
parents: 186
diff changeset
28
186
d22384c0026c *** empty log message ***
kent
parents:
diff changeset
29
d22384c0026c *** empty log message ***
kent
parents:
diff changeset
30 public class REPCommandPacker implements REPPack<REPCommand> {
311
7107faaf3feb *** empty log message ***
kono
parents: 295
diff changeset
31 private static final int TEXTSIZELIMIT = 0x7000000;
312
f39a8045175d *** empty log message ***
kono
parents: 311
diff changeset
32 private static final int HEADER_SIZE = 24;
186
d22384c0026c *** empty log message ***
kent
parents:
diff changeset
33 // JIS/S-JIS = 2, UTF-8 = 3, UTF-?? = 5
312
f39a8045175d *** empty log message ***
kono
parents: 311
diff changeset
34 private static final int CHARSIZE = 5;
f39a8045175d *** empty log message ***
kono
parents: 311
diff changeset
35 private static final boolean isLogging=false;
186
d22384c0026c *** empty log message ***
kent
parents:
diff changeset
36
311
7107faaf3feb *** empty log message ***
kono
parents: 295
diff changeset
37 Charset charset = Charset.forName("UTF-8");
7107faaf3feb *** empty log message ***
kono
parents: 295
diff changeset
38 CharsetEncoder encoder = charset.newEncoder();
7107faaf3feb *** empty log message ***
kono
parents: 295
diff changeset
39 CharsetDecoder decoder = charset.newDecoder();
186
d22384c0026c *** empty log message ***
kent
parents:
diff changeset
40
d22384c0026c *** empty log message ***
kent
parents:
diff changeset
41 /* (non-Javadoc)
d22384c0026c *** empty log message ***
kent
parents:
diff changeset
42 * @see rep.REPPack#packUConv(rep.REPCommand)
d22384c0026c *** empty log message ***
kent
parents:
diff changeset
43 */
312
f39a8045175d *** empty log message ***
kono
parents: 311
diff changeset
44 public ByteBuffer packUConv(REPCommand command){
f39a8045175d *** empty log message ***
kono
parents: 311
diff changeset
45 if (isLogging)
f39a8045175d *** empty log message ***
kono
parents: 311
diff changeset
46 System.out.println("Sending: " + command);
186
d22384c0026c *** empty log message ***
kent
parents:
diff changeset
47 if(command.string == null){
311
7107faaf3feb *** empty log message ***
kono
parents: 295
diff changeset
48 command.setString("");
186
d22384c0026c *** empty log message ***
kent
parents:
diff changeset
49 }
312
f39a8045175d *** empty log message ***
kono
parents: 311
diff changeset
50 ByteBuffer buffer = ByteBuffer.allocateDirect(HEADER_SIZE+(command.string.length()*CHARSIZE));
186
d22384c0026c *** empty log message ***
kent
parents:
diff changeset
51 buffer.clear(); // position = 0
271
kono
parents: 267
diff changeset
52 buffer.putInt(command.cmd.id);
224
6b0dd92b8e45 add optimizer to Editor
kent
parents: 186
diff changeset
53 buffer.putInt(command.sid);
6b0dd92b8e45 add optimizer to Editor
kent
parents: 186
diff changeset
54 buffer.putInt(command.eid);
6b0dd92b8e45 add optimizer to Editor
kent
parents: 186
diff changeset
55 buffer.putInt(command.seq);
6b0dd92b8e45 add optimizer to Editor
kent
parents: 186
diff changeset
56 buffer.putInt(command.lineno);
186
d22384c0026c *** empty log message ***
kent
parents:
diff changeset
57
d22384c0026c *** empty log message ***
kent
parents:
diff changeset
58 int pos = buffer.position();
224
6b0dd92b8e45 add optimizer to Editor
kent
parents: 186
diff changeset
59 buffer.putInt(0);
311
7107faaf3feb *** empty log message ***
kono
parents: 295
diff changeset
60 int pos1 = buffer.position();
186
d22384c0026c *** empty log message ***
kent
parents:
diff changeset
61
d22384c0026c *** empty log message ***
kent
parents:
diff changeset
62 //Encode to UTF8
d22384c0026c *** empty log message ***
kent
parents:
diff changeset
63 CharBuffer cb = CharBuffer.wrap(command.string);
d22384c0026c *** empty log message ***
kent
parents:
diff changeset
64 try {
d22384c0026c *** empty log message ***
kent
parents:
diff changeset
65 encoder.encode(cb, buffer, true);
d22384c0026c *** empty log message ***
kent
parents:
diff changeset
66 } catch (IllegalStateException e) {
311
7107faaf3feb *** empty log message ***
kono
parents: 295
diff changeset
67 buffer.position(pos1);
186
d22384c0026c *** empty log message ***
kent
parents:
diff changeset
68 }
d22384c0026c *** empty log message ***
kent
parents:
diff changeset
69
d22384c0026c *** empty log message ***
kent
parents:
diff changeset
70 //Encoded string length set
311
7107faaf3feb *** empty log message ***
kono
parents: 295
diff changeset
71 int length = buffer.position() -pos1 ;
186
d22384c0026c *** empty log message ***
kent
parents:
diff changeset
72 buffer.putInt(pos, length);
d22384c0026c *** empty log message ***
kent
parents:
diff changeset
73 buffer.limit(HEADER_SIZE+length);
d22384c0026c *** empty log message ***
kent
parents:
diff changeset
74 buffer.rewind();
d22384c0026c *** empty log message ***
kent
parents:
diff changeset
75
d22384c0026c *** empty log message ***
kent
parents:
diff changeset
76 return buffer;
d22384c0026c *** empty log message ***
kent
parents:
diff changeset
77 }
d22384c0026c *** empty log message ***
kent
parents:
diff changeset
78
d22384c0026c *** empty log message ***
kent
parents:
diff changeset
79
d22384c0026c *** empty log message ***
kent
parents:
diff changeset
80 public REPCommand unpackUConv(SocketChannel sc) throws IOException {
d22384c0026c *** empty log message ***
kent
parents:
diff changeset
81 ByteBuffer header = ByteBuffer.allocateDirect(HEADER_SIZE);
d22384c0026c *** empty log message ***
kent
parents:
diff changeset
82 header.clear();
311
7107faaf3feb *** empty log message ***
kono
parents: 295
diff changeset
83
224
6b0dd92b8e45 add optimizer to Editor
kent
parents: 186
diff changeset
84 while(header.remaining()>0){
267
c513cf1ce9cc call handle.cancel() on socket channel close.
kono
parents: 252
diff changeset
85 if (sc.read(header)<0) throw new IOException();
312
f39a8045175d *** empty log message ***
kono
parents: 311
diff changeset
86 }
224
6b0dd92b8e45 add optimizer to Editor
kent
parents: 186
diff changeset
87
186
d22384c0026c *** empty log message ***
kent
parents:
diff changeset
88 header.rewind(); // position = 0
d22384c0026c *** empty log message ***
kent
parents:
diff changeset
89
d22384c0026c *** empty log message ***
kent
parents:
diff changeset
90 int cmd = header.getInt();
d22384c0026c *** empty log message ***
kent
parents:
diff changeset
91 int sid = header.getInt();
d22384c0026c *** empty log message ***
kent
parents:
diff changeset
92 int eid = header.getInt();
d22384c0026c *** empty log message ***
kent
parents:
diff changeset
93 int seqid = header.getInt();
d22384c0026c *** empty log message ***
kent
parents:
diff changeset
94 int lineno = header.getInt();
d22384c0026c *** empty log message ***
kent
parents:
diff changeset
95 int textsiz = header.getInt();
d22384c0026c *** empty log message ***
kent
parents:
diff changeset
96
311
7107faaf3feb *** empty log message ***
kono
parents: 295
diff changeset
97 if (textsiz>TEXTSIZELIMIT||textsiz<0) {
7107faaf3feb *** empty log message ***
kono
parents: 295
diff changeset
98 // corrupted packet
7107faaf3feb *** empty log message ***
kono
parents: 295
diff changeset
99 throw new IOException();
7107faaf3feb *** empty log message ***
kono
parents: 295
diff changeset
100 }
186
d22384c0026c *** empty log message ***
kent
parents:
diff changeset
101 ByteBuffer textBuffer = ByteBuffer.allocateDirect(textsiz);
224
6b0dd92b8e45 add optimizer to Editor
kent
parents: 186
diff changeset
102
6b0dd92b8e45 add optimizer to Editor
kent
parents: 186
diff changeset
103 while(textBuffer.remaining()>0){
267
c513cf1ce9cc call handle.cancel() on socket channel close.
kono
parents: 252
diff changeset
104 if (sc.read(textBuffer)<0) throw new IOException();
186
d22384c0026c *** empty log message ***
kent
parents:
diff changeset
105 }
d22384c0026c *** empty log message ***
kent
parents:
diff changeset
106 textBuffer.rewind();
d22384c0026c *** empty log message ***
kent
parents:
diff changeset
107
d22384c0026c *** empty log message ***
kent
parents:
diff changeset
108 //Decode UTF-8 to System Encoding(UTF-16)
311
7107faaf3feb *** empty log message ***
kono
parents: 295
diff changeset
109 String string;
186
d22384c0026c *** empty log message ***
kent
parents:
diff changeset
110 try {
312
f39a8045175d *** empty log message ***
kono
parents: 311
diff changeset
111 CharBuffer cb;
186
d22384c0026c *** empty log message ***
kent
parents:
diff changeset
112 cb = decoder.decode(textBuffer);
311
7107faaf3feb *** empty log message ***
kono
parents: 295
diff changeset
113 cb.rewind();
7107faaf3feb *** empty log message ***
kono
parents: 295
diff changeset
114 string = cb.toString();
186
d22384c0026c *** empty log message ***
kent
parents:
diff changeset
115 } catch (CharacterCodingException e) {
311
7107faaf3feb *** empty log message ***
kono
parents: 295
diff changeset
116 string = "";
186
d22384c0026c *** empty log message ***
kent
parents:
diff changeset
117 }
d22384c0026c *** empty log message ***
kent
parents:
diff changeset
118 textsiz = string.length();
d22384c0026c *** empty log message ***
kent
parents:
diff changeset
119 REPCommand repcommand = new REPCommand(cmd, sid, eid, seqid, lineno, textsiz, string);
312
f39a8045175d *** empty log message ***
kono
parents: 311
diff changeset
120 if (isLogging)
f39a8045175d *** empty log message ***
kono
parents: 311
diff changeset
121 System.out.println("Reading: "+repcommand);
186
d22384c0026c *** empty log message ***
kent
parents:
diff changeset
122 return repcommand;
d22384c0026c *** empty log message ***
kent
parents:
diff changeset
123 }
d22384c0026c *** empty log message ***
kent
parents:
diff changeset
124
d22384c0026c *** empty log message ***
kent
parents:
diff changeset
125 }