blob: 2dd89e1cd4d2d92d4278506234e6832d19a1deab (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
|
package f00f.net.irc.martyr.replies;
import java.util.Date;
import java.util.StringTokenizer;
import f00f.net.irc.martyr.InCommand;
import f00f.net.irc.martyr.clientstate.Channel;
import f00f.net.irc.martyr.clientstate.ClientState;
/**
* ChannelCreationReply sets the creation time of the channel. It is sent
* automatically on a MODE discovery request.
*/
public class ChannelCreationReply extends GenericReply
{
private String channelName;
private Date date;
/** For use as a factory. */
public ChannelCreationReply()
{
}
public ChannelCreationReply( String channelName, Date date )
{
this.channelName = channelName;
this.date = date;
}
public String getIrcIdentifier()
{
return "329";
}
/**
* This is a factory that passes the command off to a
* ChannelModeCommand.
*/
public InCommand parse( String prefix, String identifier, String params )
{
StringTokenizer tokens = new StringTokenizer( params );
// Our nick. We don't need that, I think.
tokens.nextToken();
// The channel.
String chan = tokens.nextToken();
// The date.
Date date;
try
{
date = new Date( Long.parseLong( tokens.nextToken() ) * 1000 );
}
catch( NumberFormatException nfe )
{
// riiiight...
date = new Date(0);
}
return new ChannelCreationReply( chan, date );
}
/**
* This should, theoretically, never be called, because this command is
* only ever used as a factory.
*/
public boolean updateClientState( ClientState state )
{
Channel channel = state.getChannel( channelName );
channel.setCreationDate( date );
return true;
}
}
|