annotate rep/REPCommandPacker.java @ 380:537a9c6c6d9c

*** empty log message ***
author kono
date Thu, 23 Oct 2008 10:19:04 +0900
parents 5ba5b7a9761b
children 4b87f89b3afd
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;
186
d22384c0026c *** empty log message ***
kent
parents:
diff changeset
35
311
7107faaf3feb *** empty log message ***
kono
parents: 295
diff changeset
36 Charset charset = Charset.forName("UTF-8");
7107faaf3feb *** empty log message ***
kono
parents: 295
diff changeset
37 CharsetEncoder encoder = charset.newEncoder();
7107faaf3feb *** empty log message ***
kono
parents: 295
diff changeset
38 CharsetDecoder decoder = charset.newDecoder();
186
d22384c0026c *** empty log message ***
kent
parents:
diff changeset
39
d22384c0026c *** empty log message ***
kent
parents:
diff changeset
40 /* (non-Javadoc)
d22384c0026c *** empty log message ***
kent
parents:
diff changeset
41 * @see rep.REPPack#packUConv(rep.REPCommand)
d22384c0026c *** empty log message ***
kent
parents:
diff changeset
42 */
312
f39a8045175d *** empty log message ***
kono
parents: 311
diff changeset
43 public ByteBuffer packUConv(REPCommand command){
380
537a9c6c6d9c *** empty log message ***
kono
parents: 337
diff changeset
44 int size = 0;
537a9c6c6d9c *** empty log message ***
kono
parents: 337
diff changeset
45 if (command.string!=null) size = command.string.length()*CHARSIZE;
537a9c6c6d9c *** empty log message ***
kono
parents: 337
diff changeset
46 ByteBuffer buffer = ByteBuffer.allocateDirect(HEADER_SIZE+size);
186
d22384c0026c *** empty log message ***
kent
parents:
diff changeset
47 buffer.clear(); // position = 0
271
kono
parents: 267
diff changeset
48 buffer.putInt(command.cmd.id);
224
6b0dd92b8e45 add optimizer to Editor
kent
parents: 186
diff changeset
49 buffer.putInt(command.sid);
6b0dd92b8e45 add optimizer to Editor
kent
parents: 186
diff changeset
50 buffer.putInt(command.eid);
6b0dd92b8e45 add optimizer to Editor
kent
parents: 186
diff changeset
51 buffer.putInt(command.seq);
6b0dd92b8e45 add optimizer to Editor
kent
parents: 186
diff changeset
52 buffer.putInt(command.lineno);
186
d22384c0026c *** empty log message ***
kent
parents:
diff changeset
53
d22384c0026c *** empty log message ***
kent
parents:
diff changeset
54 int pos = buffer.position();
224
6b0dd92b8e45 add optimizer to Editor
kent
parents: 186
diff changeset
55 buffer.putInt(0);
311
7107faaf3feb *** empty log message ***
kono
parents: 295
diff changeset
56 int pos1 = buffer.position();
337
5ba5b7a9761b use REPLogger
kono
parents: 312
diff changeset
57
5ba5b7a9761b use REPLogger
kono
parents: 312
diff changeset
58 if (command.string!=null) {
5ba5b7a9761b use REPLogger
kono
parents: 312
diff changeset
59 //Encode to UTF8
5ba5b7a9761b use REPLogger
kono
parents: 312
diff changeset
60 CharBuffer cb = CharBuffer.wrap(command.string);
5ba5b7a9761b use REPLogger
kono
parents: 312
diff changeset
61 try {
5ba5b7a9761b use REPLogger
kono
parents: 312
diff changeset
62 encoder.encode(cb, buffer, true);
5ba5b7a9761b use REPLogger
kono
parents: 312
diff changeset
63 } catch (IllegalStateException e) {
5ba5b7a9761b use REPLogger
kono
parents: 312
diff changeset
64 buffer.position(pos1);
5ba5b7a9761b use REPLogger
kono
parents: 312
diff changeset
65 }
5ba5b7a9761b use REPLogger
kono
parents: 312
diff changeset
66 }
186
d22384c0026c *** empty log message ***
kent
parents:
diff changeset
67
d22384c0026c *** empty log message ***
kent
parents:
diff changeset
68 //Encoded string length set
311
7107faaf3feb *** empty log message ***
kono
parents: 295
diff changeset
69 int length = buffer.position() -pos1 ;
186
d22384c0026c *** empty log message ***
kent
parents:
diff changeset
70 buffer.putInt(pos, length);
d22384c0026c *** empty log message ***
kent
parents:
diff changeset
71 buffer.limit(HEADER_SIZE+length);
d22384c0026c *** empty log message ***
kent
parents:
diff changeset
72 buffer.rewind();
d22384c0026c *** empty log message ***
kent
parents:
diff changeset
73
d22384c0026c *** empty log message ***
kent
parents:
diff changeset
74 return buffer;
d22384c0026c *** empty log message ***
kent
parents:
diff changeset
75 }
d22384c0026c *** empty log message ***
kent
parents:
diff changeset
76
d22384c0026c *** empty log message ***
kent
parents:
diff changeset
77
d22384c0026c *** empty log message ***
kent
parents:
diff changeset
78 public REPCommand unpackUConv(SocketChannel sc) throws IOException {
d22384c0026c *** empty log message ***
kent
parents:
diff changeset
79 ByteBuffer header = ByteBuffer.allocateDirect(HEADER_SIZE);
d22384c0026c *** empty log message ***
kent
parents:
diff changeset
80 header.clear();
311
7107faaf3feb *** empty log message ***
kono
parents: 295
diff changeset
81
224
6b0dd92b8e45 add optimizer to Editor
kent
parents: 186
diff changeset
82 while(header.remaining()>0){
267
c513cf1ce9cc call handle.cancel() on socket channel close.
kono
parents: 252
diff changeset
83 if (sc.read(header)<0) throw new IOException();
312
f39a8045175d *** empty log message ***
kono
parents: 311
diff changeset
84 }
224
6b0dd92b8e45 add optimizer to Editor
kent
parents: 186
diff changeset
85
186
d22384c0026c *** empty log message ***
kent
parents:
diff changeset
86 header.rewind(); // position = 0
d22384c0026c *** empty log message ***
kent
parents:
diff changeset
87
d22384c0026c *** empty log message ***
kent
parents:
diff changeset
88 int cmd = header.getInt();
d22384c0026c *** empty log message ***
kent
parents:
diff changeset
89 int sid = header.getInt();
d22384c0026c *** empty log message ***
kent
parents:
diff changeset
90 int eid = header.getInt();
d22384c0026c *** empty log message ***
kent
parents:
diff changeset
91 int seqid = header.getInt();
d22384c0026c *** empty log message ***
kent
parents:
diff changeset
92 int lineno = header.getInt();
d22384c0026c *** empty log message ***
kent
parents:
diff changeset
93 int textsiz = header.getInt();
d22384c0026c *** empty log message ***
kent
parents:
diff changeset
94
311
7107faaf3feb *** empty log message ***
kono
parents: 295
diff changeset
95 if (textsiz>TEXTSIZELIMIT||textsiz<0) {
7107faaf3feb *** empty log message ***
kono
parents: 295
diff changeset
96 // corrupted packet
7107faaf3feb *** empty log message ***
kono
parents: 295
diff changeset
97 throw new IOException();
7107faaf3feb *** empty log message ***
kono
parents: 295
diff changeset
98 }
186
d22384c0026c *** empty log message ***
kent
parents:
diff changeset
99 ByteBuffer textBuffer = ByteBuffer.allocateDirect(textsiz);
224
6b0dd92b8e45 add optimizer to Editor
kent
parents: 186
diff changeset
100
6b0dd92b8e45 add optimizer to Editor
kent
parents: 186
diff changeset
101 while(textBuffer.remaining()>0){
267
c513cf1ce9cc call handle.cancel() on socket channel close.
kono
parents: 252
diff changeset
102 if (sc.read(textBuffer)<0) throw new IOException();
186
d22384c0026c *** empty log message ***
kent
parents:
diff changeset
103 }
d22384c0026c *** empty log message ***
kent
parents:
diff changeset
104 textBuffer.rewind();
d22384c0026c *** empty log message ***
kent
parents:
diff changeset
105
d22384c0026c *** empty log message ***
kent
parents:
diff changeset
106 //Decode UTF-8 to System Encoding(UTF-16)
311
7107faaf3feb *** empty log message ***
kono
parents: 295
diff changeset
107 String string;
186
d22384c0026c *** empty log message ***
kent
parents:
diff changeset
108 try {
312
f39a8045175d *** empty log message ***
kono
parents: 311
diff changeset
109 CharBuffer cb;
186
d22384c0026c *** empty log message ***
kent
parents:
diff changeset
110 cb = decoder.decode(textBuffer);
311
7107faaf3feb *** empty log message ***
kono
parents: 295
diff changeset
111 cb.rewind();
7107faaf3feb *** empty log message ***
kono
parents: 295
diff changeset
112 string = cb.toString();
186
d22384c0026c *** empty log message ***
kent
parents:
diff changeset
113 } catch (CharacterCodingException e) {
311
7107faaf3feb *** empty log message ***
kono
parents: 295
diff changeset
114 string = "";
186
d22384c0026c *** empty log message ***
kent
parents:
diff changeset
115 }
d22384c0026c *** empty log message ***
kent
parents:
diff changeset
116 textsiz = string.length();
d22384c0026c *** empty log message ***
kent
parents:
diff changeset
117 REPCommand repcommand = new REPCommand(cmd, sid, eid, seqid, lineno, textsiz, string);
337
5ba5b7a9761b use REPLogger
kono
parents: 312
diff changeset
118 //if (isLogging)
5ba5b7a9761b use REPLogger
kono
parents: 312
diff changeset
119 //System.out.println("Reading: "+repcommand);
186
d22384c0026c *** empty log message ***
kent
parents:
diff changeset
120 return repcommand;
d22384c0026c *** empty log message ***
kent
parents:
diff changeset
121 }
d22384c0026c *** empty log message ***
kent
parents:
diff changeset
122
d22384c0026c *** empty log message ***
kent
parents:
diff changeset
123 }