… | |
… | |
180 | {"reply", SC(ReplyCmd) 0 }, |
180 | {"reply", SC(ReplyCmd) 0 }, |
181 | {"exti", SC(ExtiCmd) 0 }, // CF+ |
181 | {"exti", SC(ExtiCmd) 0 }, // CF+ |
182 | {"addme", SC(AddMeCmd) 0 }, |
182 | {"addme", SC(AddMeCmd) 0 }, |
183 | {"askface", SC(AskFaceCmd) 0 }, |
183 | {"askface", SC(AskFaceCmd) 0 }, |
184 | {"requestinfo", SC(RequestInfo) 0 }, |
184 | {"requestinfo", SC(RequestInfo) 0 }, |
185 | {"setfacemode", SC(SetFaceMode) 0 }, |
|
|
186 | {"setsound", SC(SetSound) 0 }, |
185 | {"setsound", SC(SetSound) 0 }, |
187 | {"setup", SC(SetUp) 0 }, |
186 | {"setup", SC(SetUp) 0 }, |
188 | {"version", SC(VersionCmd) 0 }, |
187 | {"version", SC(VersionCmd) 0 }, |
189 | {"toggleextendedinfos", SC(ToggleExtendedInfos) 0 }, /*Added: tchize */ |
|
|
190 | {"toggleextendedtext", SC(ToggleExtendedText) 0 }, /*Added: tchize */ |
188 | {"toggleextendedtext", SC(ToggleExtendedText) 0 }, /*Added: tchize */ |
191 | {"asksmooth", SC(AskSmooth) 0 }, /*Added: tchize (smoothing technologies) */ |
|
|
192 | }; |
189 | }; |
193 | |
190 | |
194 | bool |
191 | bool |
195 | client::may_execute (const packet_type *pkt) const |
192 | client::may_execute (const packet_type *pkt) const |
196 | { |
193 | { |
… | |
… | |
216 | { |
213 | { |
217 | data += 6; |
214 | data += 6; |
218 | len -= 6; |
215 | len -= 6; |
219 | } |
216 | } |
220 | |
217 | |
221 | if (len > 4 && data [3] == ' ' && !strncmp (data, "say " , 4)) return true; |
218 | if (len > 4 && data [ 3] == ' ' && !strncmp (data, "say " , 4)) return true; |
222 | if (len > 5 && data [4] == ' ' && !strncmp (data, "chat " , 5)) return true; |
219 | if (len > 5 && data [ 4] == ' ' && !strncmp (data, "chat " , 5)) return true; |
223 | if (len > 6 && data [5] == ' ' && !strncmp (data, "shout ", 6)) return true; |
220 | if (len > 6 && data [ 5] == ' ' && !strncmp (data, "shout " , 6)) return true; |
|
|
221 | if (len > 8 && data [ 7] == ' ' && !strncmp (data, "suicide " , 8)) return true; |
|
|
222 | if (len > 18 && data [17] == ' ' && !strncmp (data, "accept-invitation ", 18)) return true; |
224 | |
223 | |
225 | if (len == 7 && !strcmp (data, "suicide")) return true; |
224 | if (len == 7 && !strcmp (data, "suicide")) return true; |
226 | |
225 | |
227 | return false; |
226 | return false; |
228 | } |
227 | } |
… | |
… | |
489 | |
488 | |
490 | if (!(color & NDI_VERBATIM) |
489 | if (!(color & NDI_VERBATIM) |
491 | && (msg_is_special (msg) |
490 | && (msg_is_special (msg) |
492 | || (type [0] == 'c' && type [1] == '/') || len > (MAXSOCKBUF - 128))) |
491 | || (type [0] == 'c' && type [1] == '/') || len > (MAXSOCKBUF - 128))) |
493 | cfperl_send_msg (this, color, type, msg); |
492 | cfperl_send_msg (this, color, type, msg); |
494 | else if (can_msg) |
493 | else |
495 | send_packet_printf ("msg %d %s %s", color & NDI_CLIENT_MASK, type, msg); |
494 | send_packet_printf ("msg %d %s %s", color & NDI_CLIENT_MASK, type, msg); |
496 | else if (color < 0) |
|
|
497 | return; // client cannot handle this |
|
|
498 | else |
|
|
499 | send_packet_printf ("drawinfo %d %s", color & NDI_COLOR_MASK, msg); |
|
|
500 | } |
495 | } |
501 | |
496 | |
502 | void |
497 | void |
503 | client::send_drawinfo (const char *msg, int flags) |
498 | client::send_drawinfo (const char *msg, int flags) |
504 | { |
499 | { |