ViewVC Help
View File | Revision Log | Show Annotations | Download File
/cvs/deliantra/server/server/commands.C
(Generate patch)

Comparing deliantra/server/server/commands.C (file contents):
Revision 1.13 by root, Sun Oct 1 23:44:36 2006 UTC vs.
Revision 1.19 by root, Thu Dec 14 22:45:41 2006 UTC

23 23
24/* 24/*
25 * Command parser 25 * Command parser
26 */ 26 */
27 27
28#include <cctype>
29
28#include <global.h> 30#include <global.h>
29#include <commands.h> 31#include <commands.h>
30#ifndef __CEXTRACT__
31# include <sproto.h> 32#include <sproto.h>
32#endif
33#include <ctype.h>
34 33
35/* Added times to all the commands. However, this was quickly done, 34/* Added times to all the commands. However, this was quickly done,
36 * and probably needs more refinements. All socket and DM commands 35 * and probably needs more refinements. All socket and DM commands
37 * take 0 time. 36 * take 0 time.
38 */ 37 */
112 {"northeast", command_northeast, 1.0}, 111 {"northeast", command_northeast, 1.0},
113 {"southeast", command_southeast, 1.0}, 112 {"southeast", command_southeast, 1.0},
114 {"southwest", command_southwest, 1.0}, 113 {"southwest", command_southwest, 1.0},
115 {"northwest", command_northwest, 1.0}, 114 {"northwest", command_northwest, 1.0},
116}; 115};
117
118const int CommandsSize = sizeof (Commands) / sizeof (CommArray_s); 116const int CommandsSize = sizeof (Commands) / sizeof (CommArray_s);
119 117
120CommArray_s CommunicationCommands[] = { 118CommArray_s CommunicationCommands[] = {
121 /* begin emotions */ 119 /* begin emotions */
122 {"me", command_me, 0.1}, 120 {"me", command_me, 0.1},
176 {"think", command_think, 0.0}, 174 {"think", command_think, 0.0},
177 {"cointoss", command_cointoss, 0.0}, 175 {"cointoss", command_cointoss, 0.0},
178 {"orcknuckle", command_orcknuckle, 0.0}, 176 {"orcknuckle", command_orcknuckle, 0.0},
179 {"printlos", command_printlos, 0.0}, 177 {"printlos", command_printlos, 0.0},
180}; 178};
181
182const int CommunicationCommandSize = sizeof (CommunicationCommands) / sizeof (CommArray_s); 179const int CommunicationCommandSize = sizeof (CommunicationCommands) / sizeof (CommArray_s);
183 180
184CommArray_s NewServerCommands[] = { 181CommArray_s NewServerCommands[] = {
185 {"run", command_run, 1.0}, 182 {"run", command_run, 1.0},
186 {"run_stop", command_run_stop, 0.0}, 183 {"run_stop", command_run_stop, 0.0},
187 {"fire", command_fire, 1.0}, 184 {"fire", command_fire, 1.0},
188 {"fire_stop", command_fire_stop, 0.0}, 185 {"fire_stop", command_fire_stop, 0.0},
189}; 186};
190
191const int NewServerCommandSize = sizeof (NewServerCommands) / sizeof (CommArray_s); 187const int NewServerCommandSize = sizeof (NewServerCommands) / sizeof (CommArray_s);
192 188
193/* 189/*
194 * Wizard commands (for both) 190 * Wizard commands (for both)
195 */ 191 */
201 {"create", command_create, 0.0}, 197 {"create", command_create, 0.0},
202 {"debug", command_debug, 0.0}, 198 {"debug", command_debug, 0.0},
203 {"dump", command_dump, 0.0}, 199 {"dump", command_dump, 0.0},
204 {"dumpbelow", command_dumpbelow, 0.0}, 200 {"dumpbelow", command_dumpbelow, 0.0},
205 {"dumpfriendlyobjects", command_dumpfriendlyobjects, 0.0}, 201 {"dumpfriendlyobjects", command_dumpfriendlyobjects, 0.0},
206 {"dumpallarchetypes", command_dumpallarchetypes, 0.0},
207 {"dumpallmaps", command_dumpallmaps, 0.0}, 202 {"dumpallmaps", command_dumpallmaps, 0.0},
208 {"dumpallobjects", command_dumpallobjects, 0.0},
209 {"dumpmap", command_dumpmap, 0.0}, 203 {"dumpmap", command_dumpmap, 0.0},
210 {"forget_spell", command_forget_spell, 0.0}, 204 {"forget_spell", command_forget_spell, 0.0},
211 {"free", command_free, 0.0}, 205 {"free", command_free, 0.0},
212 {"freeze", command_freeze, 0.0}, 206 {"freeze", command_freeze, 0.0},
213 {"hide", command_hide, 0.0}, 207 {"hide", command_hide, 0.0},
236 {"stack_push", command_stack_push, 0.0}, 230 {"stack_push", command_stack_push, 0.0},
237 {"stats", command_stats, 0.0}, 231 {"stats", command_stats, 0.0},
238 {"style_info", command_style_map_info, 0.0}, /* Costly command, so make it wiz only */ 232 {"style_info", command_style_map_info, 0.0}, /* Costly command, so make it wiz only */
239 {"summon", command_summon, 0.0}, 233 {"summon", command_summon, 0.0},
240 {"teleport", command_teleport, 0.0}, 234 {"teleport", command_teleport, 0.0},
241 {"wizpass", command_wizpass, 0.0},
242 {"wizcast", command_wizcast, 0.0},
243 {"overlay_save", command_save_overlay, 0.0}, 235 {"overlay_save", command_save_overlay, 0.0},
244 236
245/* {"possess", command_possess, 0.0}, */ 237/* {"possess", command_possess, 0.0}, */
246 {"mon_aggr", command_mon_aggr, 0.0}, 238 {"mon_aggr", command_mon_aggr, 0.0},
247}; 239};
256 {"maps", command_maps, 0.0}, 248 {"maps", command_maps, 0.0},
257 {"motd", command_motd, 0.0}, 249 {"motd", command_motd, 0.0},
258 {"players", command_players, 0.0}, 250 {"players", command_players, 0.0},
259 {"version", command_version, 0.0}, 251 {"version", command_version, 0.0},
260}; 252};
261
262const int Socket_CommandsSize = sizeof (Socket_Commands) / sizeof (CommArray_s); 253const int Socket_CommandsSize = sizeof (Socket_Commands) / sizeof (CommArray_s);
263
264 254
265/* Socket commands - these should really do nothing more than output things 255/* Socket commands - these should really do nothing more than output things
266 * to the various players/sockets. 256 * to the various players/sockets.
267 */ 257 */
268CommArray_s Socket2_Commands[] = { 258CommArray_s Socket2_Commands[] = {
269}; 259};
270
271const int Socket2_CommandsSize = sizeof (Socket2_Commands) / sizeof (CommArray_s); 260const int Socket2_CommandsSize = sizeof (Socket2_Commands) / sizeof (CommArray_s);
272
273
274 261
275static int 262static int
276compare_A (const void *a, const void *b) 263compare_A (const void *a, const void *b)
277{ 264{
278 return strcmp (((CommArray_s *) a)->name, ((CommArray_s *) b)->name); 265 return strcmp (((CommArray_s *)a)->name, ((CommArray_s *)b)->name);
279} 266}
280 267
281void 268void
282init_commands (void) 269init_commands (void)
283{ 270{
287 qsort (WizCommands, WizCommandsSize, sizeof (CommArray_s), compare_A); 274 qsort (WizCommands, WizCommandsSize, sizeof (CommArray_s), compare_A);
288 qsort (Socket_Commands, Socket_CommandsSize, sizeof (CommArray_s), compare_A); 275 qsort (Socket_Commands, Socket_CommandsSize, sizeof (CommArray_s), compare_A);
289 qsort (Socket2_Commands, Socket2_CommandsSize, sizeof (CommArray_s), compare_A); 276 qsort (Socket2_Commands, Socket2_CommandsSize, sizeof (CommArray_s), compare_A);
290} 277}
291 278
292#ifndef tolower
293# define tolower(C) (((C) >= 'A' && (C) <= 'Z')? (C) - 'A' + 'a': (C))
294#endif
295
296
297CommFunc
298find_oldsocket_command (char *cmd)
299{
300 CommArray_s *asp, dummy;
301 char *cp;
302
303 for (cp = cmd; *cp; cp++)
304 {
305 *cp = tolower (*cp);
306 }
307
308 dummy.name = cmd;
309 asp = (CommArray_s *) bsearch ((void *) &dummy, (void *) Socket_Commands, Socket_CommandsSize, sizeof (CommArray_s), compare_A);
310 if (asp)
311 return asp->func;
312 return NULL;
313}
314
315CommFunc
316find_oldsocket_command2 (char *cmd)
317{
318 CommArray_s *asp, dummy;
319 char *cp;
320
321 for (cp = cmd; *cp; cp++)
322 {
323 *cp = tolower (*cp);
324 }
325
326 dummy.name = cmd;
327 asp = (CommArray_s *) bsearch ((void *) &dummy, (void *) Socket2_Commands, Socket2_CommandsSize, sizeof (CommArray_s), compare_A);
328 if (asp)
329 return asp->func;
330 return NULL;
331}

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines